| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* | 
|  | 2 | *	linux/arch/alpha/kernel/pci_impl.h | 
|  | 3 | * | 
|  | 4 | * This file contains declarations and inline functions for interfacing | 
|  | 5 | * with the PCI initialization routines. | 
|  | 6 | */ | 
|  | 7 |  | 
|  | 8 | struct pci_dev; | 
|  | 9 | struct pci_controller; | 
|  | 10 | struct pci_iommu_arena; | 
|  | 11 |  | 
|  | 12 | /* | 
|  | 13 | * We can't just blindly use 64K for machines with EISA busses; they | 
|  | 14 | * may also have PCI-PCI bridges present, and then we'd configure the | 
|  | 15 | * bridge incorrectly. | 
|  | 16 | * | 
|  | 17 | * Also, we start at 0x8000 or 0x9000, in hopes to get all devices' | 
|  | 18 | * IO space areas allocated *before* 0xC000; this is because certain | 
|  | 19 | * BIOSes (Millennium for one) use PCI Config space "mechanism #2" | 
|  | 20 | * accesses to probe the bus. If a device's registers appear at 0xC000, | 
|  | 21 | * it may see an INx/OUTx at that address during BIOS emulation of the | 
|  | 22 | * VGA BIOS, and some cards, notably Adaptec 2940UW, take mortal offense. | 
|  | 23 | */ | 
|  | 24 |  | 
|  | 25 | #define EISA_DEFAULT_IO_BASE	0x9000	/* start above 8th slot */ | 
|  | 26 | #define DEFAULT_IO_BASE		0x8000	/* start at 8th slot */ | 
|  | 27 |  | 
|  | 28 | /* | 
|  | 29 | * We try to make the DEFAULT_MEM_BASE addresses *always* have more than | 
|  | 30 | * a single bit set. This is so that devices like the broken Myrinet card | 
|  | 31 | * will always have a PCI memory address that will never match a IDSEL | 
|  | 32 | * address in PCI Config space, which can cause problems with early rev cards. | 
|  | 33 | */ | 
|  | 34 |  | 
|  | 35 | /* | 
|  | 36 | * An XL is AVANTI (APECS) family, *but* it has only 27 bits of ISA address | 
|  | 37 | * that get passed through the PCI<->ISA bridge chip. Although this causes | 
|  | 38 | * us to set the PCI->Mem window bases lower than normal, we still allocate | 
|  | 39 | * PCI bus devices' memory addresses *below* the low DMA mapping window, | 
|  | 40 | * and hope they fit below 64Mb (to avoid conflicts), and so that they can | 
|  | 41 | * be accessed via SPARSE space. | 
|  | 42 | * | 
|  | 43 | * We accept the risk that a broken Myrinet card will be put into a true XL | 
|  | 44 | * and thus can more easily run into the problem described below. | 
|  | 45 | */ | 
|  | 46 | #define XL_DEFAULT_MEM_BASE ((16+2)*1024*1024) /* 16M to 64M-1 is avail */ | 
|  | 47 |  | 
|  | 48 | /* | 
|  | 49 | * APECS and LCA have only 34 bits for physical addresses, thus limiting PCI | 
|  | 50 | * bus memory addresses for SPARSE access to be less than 128Mb. | 
|  | 51 | */ | 
|  | 52 | #define APECS_AND_LCA_DEFAULT_MEM_BASE ((16+2)*1024*1024) | 
|  | 53 |  | 
|  | 54 | /* | 
|  | 55 | * Because MCPCIA and T2 core logic support more bits for | 
|  | 56 | * physical addresses, they should allow an expanded range of SPARSE | 
|  | 57 | * memory addresses.  However, we do not use them all, in order to | 
|  | 58 | * avoid the HAE manipulation that would be needed. | 
|  | 59 | */ | 
|  | 60 | #define MCPCIA_DEFAULT_MEM_BASE ((32+2)*1024*1024) | 
|  | 61 | #define T2_DEFAULT_MEM_BASE ((16+1)*1024*1024) | 
|  | 62 |  | 
|  | 63 | /* | 
|  | 64 | * Because CIA and PYXIS have more bits for physical addresses, | 
|  | 65 | * they support an expanded range of SPARSE memory addresses. | 
|  | 66 | */ | 
|  | 67 | #define DEFAULT_MEM_BASE ((128+16)*1024*1024) | 
|  | 68 |  | 
|  | 69 | /* ??? Experimenting with no HAE for CIA.  */ | 
|  | 70 | #define CIA_DEFAULT_MEM_BASE ((32+2)*1024*1024) | 
|  | 71 |  | 
|  | 72 | #define IRONGATE_DEFAULT_MEM_BASE ((256*8-16)*1024*1024) | 
|  | 73 |  | 
|  | 74 | #define DEFAULT_AGP_APER_SIZE	(64*1024*1024) | 
|  | 75 |  | 
|  | 76 | /* | 
|  | 77 | * A small note about bridges and interrupts.  The DECchip 21050 (and | 
|  | 78 | * later) adheres to the PCI-PCI bridge specification.  This says that | 
|  | 79 | * the interrupts on the other side of a bridge are swizzled in the | 
|  | 80 | * following manner: | 
|  | 81 | * | 
|  | 82 | * Dev    Interrupt   Interrupt | 
|  | 83 | *        Pin on      Pin on | 
|  | 84 | *        Device      Connector | 
|  | 85 | * | 
|  | 86 | *   4    A           A | 
|  | 87 | *        B           B | 
|  | 88 | *        C           C | 
|  | 89 | *        D           D | 
|  | 90 | * | 
|  | 91 | *   5    A           B | 
|  | 92 | *        B           C | 
|  | 93 | *        C           D | 
|  | 94 | *        D           A | 
|  | 95 | * | 
|  | 96 | *   6    A           C | 
|  | 97 | *        B           D | 
|  | 98 | *        C           A | 
|  | 99 | *        D           B | 
|  | 100 | * | 
|  | 101 | *   7    A           D | 
|  | 102 | *        B           A | 
|  | 103 | *        C           B | 
|  | 104 | *        D           C | 
|  | 105 | * | 
|  | 106 | *   Where A = pin 1, B = pin 2 and so on and pin=0 = default = A. | 
|  | 107 | *   Thus, each swizzle is ((pin-1) + (device#-4)) % 4 | 
|  | 108 | * | 
|  | 109 | *   The following code swizzles for exactly one bridge.  The routine | 
|  | 110 | *   common_swizzle below handles multiple bridges.  But there are a | 
|  | 111 | *   couple boards that do strange things, so we define this here. | 
|  | 112 | */ | 
|  | 113 |  | 
|  | 114 | static inline u8 bridge_swizzle(u8 pin, u8 slot) | 
|  | 115 | { | 
|  | 116 | return (((pin-1) + slot) % 4) + 1; | 
|  | 117 | } | 
|  | 118 |  | 
|  | 119 |  | 
|  | 120 | /* The following macro is used to implement the table-based irq mapping | 
|  | 121 | function for all single-bus Alphas.  */ | 
|  | 122 |  | 
|  | 123 | #define COMMON_TABLE_LOOKUP						\ | 
|  | 124 | ({ long _ctl_ = -1; 							\ | 
|  | 125 | if (slot >= min_idsel && slot <= max_idsel && pin < irqs_per_slot)	\ | 
|  | 126 | _ctl_ = irq_tab[slot - min_idsel][pin];				\ | 
|  | 127 | _ctl_; }) | 
|  | 128 |  | 
|  | 129 |  | 
|  | 130 | /* A PCI IOMMU allocation arena.  There are typically two of these | 
|  | 131 | regions per bus.  */ | 
|  | 132 | /* ??? The 8400 has a 32-byte pte entry, and the entire table apparently | 
|  | 133 | lives directly on the host bridge (no tlb?).  We don't support this | 
|  | 134 | machine, but if we ever did, we'd need to parameterize all this quite | 
|  | 135 | a bit further.  Probably with per-bus operation tables.  */ | 
|  | 136 |  | 
|  | 137 | struct pci_iommu_arena | 
|  | 138 | { | 
|  | 139 | spinlock_t lock; | 
|  | 140 | struct pci_controller *hose; | 
|  | 141 | #define IOMMU_INVALID_PTE 0x2 /* 32:63 bits MBZ */ | 
|  | 142 | #define IOMMU_RESERVED_PTE 0xface | 
|  | 143 | unsigned long *ptes; | 
|  | 144 | dma_addr_t dma_base; | 
|  | 145 | unsigned int size; | 
|  | 146 | unsigned int next_entry; | 
|  | 147 | unsigned int align_entry; | 
|  | 148 | }; | 
|  | 149 |  | 
|  | 150 | #if defined(CONFIG_ALPHA_SRM) && \ | 
|  | 151 | (defined(CONFIG_ALPHA_CIA) || defined(CONFIG_ALPHA_LCA)) | 
|  | 152 | # define NEED_SRM_SAVE_RESTORE | 
|  | 153 | #else | 
|  | 154 | # undef NEED_SRM_SAVE_RESTORE | 
|  | 155 | #endif | 
|  | 156 |  | 
|  | 157 | #if defined(CONFIG_ALPHA_GENERIC) || defined(NEED_SRM_SAVE_RESTORE) | 
|  | 158 | # define ALPHA_RESTORE_SRM_SETUP | 
|  | 159 | #else | 
|  | 160 | # undef ALPHA_RESTORE_SRM_SETUP | 
|  | 161 | #endif | 
|  | 162 |  | 
|  | 163 | #ifdef ALPHA_RESTORE_SRM_SETUP | 
|  | 164 | /* Store PCI device configuration left by SRM here. */ | 
|  | 165 | struct pdev_srm_saved_conf | 
|  | 166 | { | 
|  | 167 | struct pdev_srm_saved_conf *next; | 
|  | 168 | struct pci_dev *dev; | 
|  | 169 | }; | 
|  | 170 |  | 
|  | 171 | extern void pci_restore_srm_config(void); | 
|  | 172 | #else | 
|  | 173 | #define pdev_save_srm_config(dev)	do {} while (0) | 
|  | 174 | #define pci_restore_srm_config()	do {} while (0) | 
|  | 175 | #endif | 
|  | 176 |  | 
|  | 177 | /* The hose list.  */ | 
|  | 178 | extern struct pci_controller *hose_head, **hose_tail; | 
|  | 179 | extern struct pci_controller *pci_isa_hose; | 
|  | 180 |  | 
|  | 181 | /* Indicate that we trust the console to configure things properly.  */ | 
|  | 182 | extern int pci_probe_only; | 
|  | 183 |  | 
|  | 184 | extern unsigned long alpha_agpgart_size; | 
|  | 185 |  | 
|  | 186 | extern void common_init_pci(void); | 
|  | 187 | extern u8 common_swizzle(struct pci_dev *, u8 *); | 
|  | 188 | extern struct pci_controller *alloc_pci_controller(void); | 
|  | 189 | extern struct resource *alloc_resource(void); | 
|  | 190 |  | 
|  | 191 | extern struct pci_iommu_arena *iommu_arena_new_node(int, | 
|  | 192 | struct pci_controller *, | 
|  | 193 | dma_addr_t, unsigned long, | 
|  | 194 | unsigned long); | 
|  | 195 | extern struct pci_iommu_arena *iommu_arena_new(struct pci_controller *, | 
|  | 196 | dma_addr_t, unsigned long, | 
|  | 197 | unsigned long); | 
|  | 198 | extern const char *const pci_io_names[]; | 
|  | 199 | extern const char *const pci_mem_names[]; | 
|  | 200 | extern const char pci_hae0_name[]; | 
|  | 201 |  | 
|  | 202 | extern unsigned long size_for_memory(unsigned long max); | 
|  | 203 |  | 
|  | 204 | extern int iommu_reserve(struct pci_iommu_arena *, long, long); | 
|  | 205 | extern int iommu_release(struct pci_iommu_arena *, long, long); | 
|  | 206 | extern int iommu_bind(struct pci_iommu_arena *, long, long, unsigned long *); | 
|  | 207 | extern int iommu_unbind(struct pci_iommu_arena *, long, long); | 
|  | 208 |  | 
|  | 209 |  |