Rev 1692 | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
9503 | turbocat | 1 | #ifndef _GEODE_PCI_ |
2 | #define _GEODE_PCI_ |
||
981 | serge | 3 | |
1692 | serge | 4 | typedef int Bool; |
9503 | turbocat | 5 | typedef unsigned char u8_t; |
6 | typedef unsigned short u16_t; |
||
7 | typedef unsigned int u32_t; |
||
981 | serge | 8 | |
1692 | serge | 9 | #define TRUE 1 |
10 | #define FALSE 0 |
||
11 | |||
981 | serge | 12 | #pragma pack(push, 1) |
13 | typedef struct |
||
14 | { |
||
15 | u16_t device; |
||
16 | u16_t ChipSet; |
||
17 | }PciChipset_t; |
||
18 | #pragma pack(pop) |
||
19 | |||
20 | #define VENDOR_ATI 0x1002 |
||
21 | |||
22 | |||
23 | #define PCI_CLASS_DISPLAY_VGA 0x0300 |
||
24 | /* |
||
25 | * Under PCI, each device has 256 bytes of configuration address space, |
||
26 | * of which the first 64 bytes are standardized as follows: |
||
27 | */ |
||
28 | #define PCI_VENDOR_ID 0x00 /* 16 bits */ |
||
29 | #define PCI_DEVICE_ID 0x02 /* 16 bits */ |
||
30 | #define PCI_COMMAND 0x04 /* 16 bits */ |
||
31 | #define PCI_COMMAND_IO 0x01 /* Enable response in I/O space */ |
||
32 | #define PCI_COMMAND_MEMORY 0x02 /* Enable response in Memory space */ |
||
33 | #define PCI_COMMAND_MASTER 0x04 /* Enable bus mastering */ |
||
34 | #define PCI_COMMAND_SPECIAL 0x08 /* Enable response to special cycles */ |
||
35 | #define PCI_COMMAND_INVALIDATE 0x10 /* Use memory write and invalidate */ |
||
36 | #define PCI_COMMAND_VGA_PALETTE 0x20 /* Enable palette snooping */ |
||
37 | #define PCI_COMMAND_PARITY 0x40 /* Enable parity checking */ |
||
38 | #define PCI_COMMAND_WAIT 0x80 /* Enable address/data stepping */ |
||
39 | #define PCI_COMMAND_SERR 0x100 /* Enable SERR */ |
||
40 | #define PCI_COMMAND_FAST_BACK 0x200 /* Enable back-to-back writes */ |
||
41 | #define PCI_COMMAND_INTX_DISABLE 0x400 /* INTx Emulation Disable */ |
||
42 | |||
43 | #define PCI_STATUS 0x06 /* 16 bits */ |
||
44 | #define PCI_STATUS_CAP_LIST 0x10 /* Support Capability List */ |
||
45 | #define PCI_STATUS_66MHZ 0x20 /* Support 66 Mhz PCI 2.1 bus */ |
||
46 | #define PCI_STATUS_UDF 0x40 /* Support User Definable Features [obsolete] */ |
||
47 | #define PCI_STATUS_FAST_BACK 0x80 /* Accept fast-back to back */ |
||
48 | #define PCI_STATUS_PARITY 0x100 /* Detected parity error */ |
||
49 | #define PCI_STATUS_DEVSEL_MASK 0x600 /* DEVSEL timing */ |
||
50 | #define PCI_STATUS_DEVSEL_FAST 0x000 |
||
51 | #define PCI_STATUS_DEVSEL_MEDIUM 0x200 |
||
52 | #define PCI_STATUS_DEVSEL_SLOW 0x400 |
||
53 | #define PCI_STATUS_SIG_TARGET_ABORT 0x800 /* Set on target abort */ |
||
54 | #define PCI_STATUS_REC_TARGET_ABORT 0x1000 /* Master ack of " */ |
||
55 | #define PCI_STATUS_REC_MASTER_ABORT 0x2000 /* Set on master abort */ |
||
56 | #define PCI_STATUS_SIG_SYSTEM_ERROR 0x4000 /* Set when we drive SERR */ |
||
57 | #define PCI_STATUS_DETECTED_PARITY 0x8000 /* Set on parity error */ |
||
58 | |||
59 | #define PCI_CLASS_REVISION 0x08 /* High 24 bits are class, low 8 revision */ |
||
60 | #define PCI_REVISION_ID 0x08 /* Revision ID */ |
||
61 | #define PCI_CLASS_PROG 0x09 /* Reg. Level Programming Interface */ |
||
62 | #define PCI_CLASS_DEVICE 0x0a /* Device class */ |
||
63 | |||
64 | #define PCI_CACHE_LINE_SIZE 0x0c /* 8 bits */ |
||
65 | #define PCI_LATENCY_TIMER 0x0d /* 8 bits */ |
||
66 | #define PCI_HEADER_TYPE 0x0e /* 8 bits */ |
||
67 | #define PCI_HEADER_TYPE_NORMAL 0 |
||
68 | #define PCI_HEADER_TYPE_BRIDGE 1 |
||
69 | #define PCI_HEADER_TYPE_CARDBUS 2 |
||
70 | |||
71 | #define PCI_BIST 0x0f /* 8 bits */ |
||
72 | #define PCI_BIST_CODE_MASK 0x0f /* Return result */ |
||
73 | #define PCI_BIST_START 0x40 /* 1 to start BIST, 2 secs or less */ |
||
74 | #define PCI_BIST_CAPABLE 0x80 /* 1 if BIST capable */ |
||
75 | |||
76 | #define PCI_CAPABILITY_LIST 0x34 /* Offset of first capability list entry */ |
||
77 | #define PCI_CB_CAPABILITY_LIST 0x14 |
||
78 | /* Capability lists */ |
||
79 | |||
80 | #define PCI_CAP_LIST_ID 0 /* Capability ID */ |
||
81 | #define PCI_CAP_ID_PM 0x01 /* Power Management */ |
||
82 | #define PCI_CAP_ID_AGP 0x02 /* Accelerated Graphics Port */ |
||
83 | #define PCI_CAP_ID_VPD 0x03 /* Vital Product Data */ |
||
84 | #define PCI_CAP_ID_SLOTID 0x04 /* Slot Identification */ |
||
85 | #define PCI_CAP_ID_MSI 0x05 /* Message Signalled Interrupts */ |
||
86 | #define PCI_CAP_ID_CHSWP 0x06 /* CompactPCI HotSwap */ |
||
87 | #define PCI_CAP_ID_PCIX 0x07 /* PCI-X */ |
||
88 | #define PCI_CAP_ID_HT 0x08 /* HyperTransport */ |
||
89 | #define PCI_CAP_ID_VNDR 0x09 /* Vendor specific capability */ |
||
90 | #define PCI_CAP_ID_SHPC 0x0C /* PCI Standard Hot-Plug Controller */ |
||
91 | #define PCI_CAP_ID_EXP 0x10 /* PCI Express */ |
||
92 | #define PCI_CAP_ID_MSIX 0x11 /* MSI-X */ |
||
93 | #define PCI_CAP_LIST_NEXT 1 /* Next capability in the list */ |
||
94 | #define PCI_CAP_FLAGS 2 /* Capability defined flags (16 bits) */ |
||
95 | #define PCI_CAP_SIZEOF 4 |
||
96 | |||
97 | |||
98 | /* AGP registers */ |
||
99 | |||
100 | #define PCI_AGP_VERSION 2 /* BCD version number */ |
||
101 | #define PCI_AGP_RFU 3 /* Rest of capability flags */ |
||
102 | #define PCI_AGP_STATUS 4 /* Status register */ |
||
103 | #define PCI_AGP_STATUS_RQ_MASK 0xff000000 /* Maximum number of requests - 1 */ |
||
104 | #define PCI_AGP_STATUS_SBA 0x0200 /* Sideband addressing supported */ |
||
105 | #define PCI_AGP_STATUS_64BIT 0x0020 /* 64-bit addressing supported */ |
||
106 | #define PCI_AGP_STATUS_FW 0x0010 /* FW transfers supported */ |
||
107 | #define PCI_AGP_STATUS_RATE4 0x0004 /* 4x transfer rate supported */ |
||
108 | #define PCI_AGP_STATUS_RATE2 0x0002 /* 2x transfer rate supported */ |
||
109 | #define PCI_AGP_STATUS_RATE1 0x0001 /* 1x transfer rate supported */ |
||
110 | #define PCI_AGP_COMMAND 8 /* Control register */ |
||
111 | #define PCI_AGP_COMMAND_RQ_MASK 0xff000000 /* Master: Maximum number of requests */ |
||
112 | #define PCI_AGP_COMMAND_SBA 0x0200 /* Sideband addressing enabled */ |
||
113 | #define PCI_AGP_COMMAND_AGP 0x0100 /* Allow processing of AGP transactions */ |
||
114 | #define PCI_AGP_COMMAND_64BIT 0x0020 /* Allow processing of 64-bit addresses */ |
||
115 | #define PCI_AGP_COMMAND_FW 0x0010 /* Force FW transfers */ |
||
116 | #define PCI_AGP_COMMAND_RATE4 0x0004 /* Use 4x rate */ |
||
117 | #define PCI_AGP_COMMAND_RATE2 0x0002 /* Use 2x rate */ |
||
118 | #define PCI_AGP_COMMAND_RATE1 0x0001 /* Use 1x rate */ |
||
119 | #define PCI_AGP_SIZEOF 12 |
||
120 | |||
121 | |||
122 | #define PCI_MAP_REG_START 0x10 |
||
123 | #define PCI_MAP_REG_END 0x28 |
||
124 | #define PCI_MAP_ROM_REG 0x30 |
||
125 | |||
126 | #define PCI_MAP_MEMORY 0x00000000 |
||
127 | #define PCI_MAP_IO 0x00000001 |
||
128 | |||
129 | #define PCI_MAP_MEMORY_TYPE 0x00000007 |
||
130 | #define PCI_MAP_IO_TYPE 0x00000003 |
||
131 | |||
132 | #define PCI_MAP_MEMORY_TYPE_32BIT 0x00000000 |
||
133 | #define PCI_MAP_MEMORY_TYPE_32BIT_1M 0x00000002 |
||
134 | #define PCI_MAP_MEMORY_TYPE_64BIT 0x00000004 |
||
135 | #define PCI_MAP_MEMORY_TYPE_MASK 0x00000006 |
||
136 | #define PCI_MAP_MEMORY_CACHABLE 0x00000008 |
||
137 | #define PCI_MAP_MEMORY_ATTR_MASK 0x0000000e |
||
138 | #define PCI_MAP_MEMORY_ADDRESS_MASK 0xfffffff0 |
||
139 | |||
140 | #define PCI_MAP_IO_ATTR_MASK 0x00000003 |
||
141 | |||
142 | #define PCI_MAP_IS_IO(b) ((b) & PCI_MAP_IO) |
||
143 | #define PCI_MAP_IS_MEM(b) (!PCI_MAP_IS_IO(b)) |
||
144 | |||
145 | #define PCI_MAP_IS64BITMEM(b) \ |
||
146 | (((b) & PCI_MAP_MEMORY_TYPE_MASK) == PCI_MAP_MEMORY_TYPE_64BIT) |
||
147 | |||
148 | #define PCIGETMEMORY(b) ((b) & PCI_MAP_MEMORY_ADDRESS_MASK) |
||
149 | #define PCIGETMEMORY64HIGH(b) (*((CARD32*)&b + 1)) |
||
150 | #define PCIGETMEMORY64(b) \ |
||
151 | (PCIGETMEMORY(b) | ((CARD64)PCIGETMEMORY64HIGH(b) << 32)) |
||
152 | |||
153 | #define PCI_MAP_IO_ADDRESS_MASK 0xfffffffc |
||
154 | |||
155 | #define PCIGETIO(b) ((b) & PCI_MAP_IO_ADDRESS_MASK) |
||
156 | |||
157 | #define PCI_MAP_ROM_DECODE_ENABLE 0x00000001 |
||
158 | #define PCI_MAP_ROM_ADDRESS_MASK 0xfffff800 |
||
159 | |||
160 | #define PCIGETROM(b) ((b) & PCI_MAP_ROM_ADDRESS_MASK) |
||
161 | |||
162 | |||
163 | #ifndef PCI_DOM_MASK |
||
164 | # define PCI_DOM_MASK 0x0ffu |
||
165 | #endif |
||
166 | #define PCI_DOMBUS_MASK (((PCI_DOM_MASK) << 8) | 0x0ffu) |
||
167 | |||
168 | #define PCI_MAKE_TAG(b,d,f) ((((b) & (PCI_DOMBUS_MASK)) << 16) | \ |
||
169 | (((d) & 0x00001fu) << 11) | \ |
||
170 | (((f) & 0x000007u) << 8)) |
||
171 | |||
172 | #define PCI_BUS_FROM_TAG(tag) (((tag) >> 16) & (PCI_DOMBUS_MASK)) |
||
173 | #define PCI_DEV_FROM_TAG(tag) (((tag) & 0x0000f800u) >> 11) |
||
174 | #define PCI_FUNC_FROM_TAG(tag) (((tag) & 0x00000700u) >> 8) |
||
175 | #define PCI_DFN_FROM_TAG(tag) (((tag) & 0x0000ff00u) >> 8) |
||
176 | |||
177 | |||
178 | typedef unsigned int PCITAG; |
||
179 | |||
180 | extern inline PCITAG |
||
181 | pciTag(int busnum, int devnum, int funcnum) |
||
182 | { |
||
183 | return(PCI_MAKE_TAG(busnum,devnum,funcnum)); |
||
184 | } |
||
185 | |||
186 | const PciChipset_t *PciDevMatch(u16_t dev,const PciChipset_t *list); |
||
187 | u32_t pciGetBaseSize(int bus, int devfn, int index, Bool destructive, Bool *min); |
||
188 | |||
189 | #define PCI_ANY_ID (~0) |
||
190 | |||
191 | #define for_each_pci_dev(d) while ((d = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, d))!=-1) |
||
9503 | turbocat | 192 | |
193 | #endif // _GEODE_PCI_><>><>><>><>><> |