Make sure and generate the kernel resource headers before exec is compiled
[tangerine.git] / arch / common / hidd.pci / include / pci_hidd.h
blob33aac84bcb46a7e92b845c657924c82e34844c44
1 #ifndef HIDD_PCI_H
2 #define HIDD_PCI_H
4 /*
5 Copyright © 2003, The AROS Development Team. All rights reserved.
6 $Id$
7 */
9 #ifndef EXEC_TYPES_H
10 #include <exec/types.h>
11 #endif
13 #ifndef HIDD_HIDD_H
14 #include <hidd/hidd.h>
15 #endif
17 #ifndef OOP_OOP_H
18 #include <oop/oop.h>
19 #endif
21 #ifndef UTILITY_HOOKS_H
22 #include <utility/hooks.h>
23 #endif
25 #ifndef UTILITY_TAGITEM_H
26 #include <utility/tagitem.h>
27 #endif
29 /* Base PCI class */
31 #define CLID_Hidd_PCI "hidd.pci"
32 #define IID_Hidd_PCI "hidd.pci"
34 #define HiddPCIAttrBase __IHidd_PCI
36 #ifndef __OOP_NOATTRBASES__
37 extern OOP_AttrBase HiddPCIAttrBase;
38 #endif
40 /* PCI Class methods */
41 enum
43 moHidd_PCI_AddHardwareDriver = 0,
44 moHidd_PCI_EnumDevices,
45 moHidd_PCI_RemHardwareDriver,
47 NUM_PCI_METHODS
50 /* Tags for EnumDevices method */
51 enum
53 tHidd_PCI_VendorID = TAG_USER,
54 tHidd_PCI_ProductID,
55 tHidd_PCI_RevisionID,
56 tHidd_PCI_Interface,
57 tHidd_PCI_Class,
58 tHidd_PCI_SubClass,
59 tHidd_PCI_SubsystemVendorID,
60 tHidd_PCI_SubsystemID
63 struct pHidd_PCI_AddHardwareDriver
65 OOP_MethodID mID;
66 OOP_Class *driverClass;
69 struct pHidd_PCI_EnumDevices
71 OOP_MethodID mID;
72 struct Hook *callback;
73 struct TagItem *requirements;
76 struct pHidd_PCI_RemHardwareDriver
78 OOP_MethodID mID;
79 OOP_Class *driverClass;
82 /* PCI device class */
84 #define CLID_Hidd_PCIDevice "hidd.pci.device"
85 #define IID_Hidd_PCIDevice "hidd.pci.device"
87 #define HiddPCIDeviceAttrBase __IHidd_PCIDev
89 #ifndef __OOP_NOATTRBASES__
90 extern OOP_AttrBase HiddPCIDeviceAttrBase;
91 #endif
93 enum
95 moHidd_PCIDevice_ReadConfigByte,
96 moHidd_PCIDevice_ReadConfigWord,
97 moHidd_PCIDevice_ReadConfigLong,
98 moHidd_PCIDevice_WriteConfigByte,
99 moHidd_PCIDevice_WriteConfigWord,
100 moHidd_PCIDevice_WriteConfigLong,
102 NUM_PCIDEVICE_METHODS
105 enum
107 aoHidd_PCIDevice_Driver, /* [I.G] Hardware PCI driver that handles this device */
108 aoHidd_PCIDevice_Bus, /* [I.G] Bus the device is on */
109 aoHidd_PCIDevice_Dev, /* [I.G] Device number */
110 aoHidd_PCIDevice_Sub, /* [I.G] Function number */
112 aoHidd_PCIDevice_VendorID, /* [..G] VendorID of device as defined in PCI specs */
113 aoHidd_PCIDevice_ProductID, /* [..G] ProductID */
114 aoHidd_PCIDevice_RevisionID,/* [..G] RevisionID */
116 aoHidd_PCIDevice_Interface, /* [..G] */
117 aoHidd_PCIDevice_Class, /* [..G] */
118 aoHidd_PCIDevice_SubClass, /* [..G] */
120 aoHidd_PCIDevice_SubsystemVendorID, /* [..G] */
121 aoHidd_PCIDevice_SubsystemID, /* [..G] */
123 aoHidd_PCIDevice_INTLine, /* [..G] */
124 aoHidd_PCIDevice_IRQLine, /* [..G] */
126 aoHidd_PCIDevice_RomBase, /* [.SG] Location of ROM on the PCI bus (if ROM exists) */
127 aoHidd_PCIDevice_RomSize, /* [..G] Size of ROM area */
129 aoHidd_PCIDevice_Base0, /* [.SG] Location of Memory Area 0 */
130 aoHidd_PCIDevice_Size0, /* [..G] Size of Memory Area 0 */
131 aoHidd_PCIDevice_Type0, /* [..G] Type of Memory Area 0 */
132 aoHidd_PCIDevice_Base1, /* [.SG] Ditto */
133 aoHidd_PCIDevice_Size1, /* [..G] */
134 aoHidd_PCIDevice_Type1, /* [..G] */
135 aoHidd_PCIDevice_Base2, /* [.SG] */
136 aoHidd_PCIDevice_Size2, /* [..G] */
137 aoHidd_PCIDevice_Type2, /* [..G] */
138 aoHidd_PCIDevice_Base3, /* [.SG] */
139 aoHidd_PCIDevice_Size3, /* [..G] */
140 aoHidd_PCIDevice_Type3, /* [..G] */
141 aoHidd_PCIDevice_Base4, /* [.SG] */
142 aoHidd_PCIDevice_Size4, /* [..G] */
143 aoHidd_PCIDevice_Type4, /* [..G] */
144 aoHidd_PCIDevice_Base5, /* [.SG] */
145 aoHidd_PCIDevice_Size5, /* [..G] */
146 aoHidd_PCIDevice_Type5, /* [..G] */
148 aoHidd_PCIDevice_isIO, /* [.SG] Can device access IO space? */
149 aoHidd_PCIDevice_isMEM, /* [.SG] Can device access Mem space? */
150 aoHidd_PCIDevice_isMaster, /* [.SG] Can device work in BusMaster mode? */
151 aoHidd_PCIDevice_paletteSnoop, /* [.SG] Should VGA compatible card snoop the palette? */
153 aoHidd_PCIDevice_is66MHz, /* [..G] Is device 66MHz capable? */
155 aoHidd_PCIDevice_ClassDesc, /* [..G] String description of device Class */
156 aoHidd_PCIDevice_SubClassDesc, /* [..G] String description of device SubClass */
157 aoHidd_PCIDevice_InterfaceDesc, /* [..G] String description of defice Interface */
159 aoHidd_PCIDevice_isBridge, /* [..G] Is the device a PCI-PCI bridge? */
160 aoHidd_PCIDevice_SubBus, /* [..G] Bus number managed by bridge */
161 aoHidd_PCIDevice_MemoryBase,/* [.SG] PCI bridge will forwart addresses from MemoryBase to */
162 aoHidd_PCIDevice_MemoryLimit,/*[.SG] MemoryLimit through */
163 aoHidd_PCIDevice_PrefetchableBase, /* [.SG] like above, regarding the prefetchable memory */
164 aoHidd_PCIDevice_PrefetchableLimit,/* [.SG] */
165 aoHidd_PCIDevice_IOBase, /* [.SG] PCI bridge will forward IO accesses from IOBase to IOLimit */
166 aoHidd_PCIDevice_IOLimit, /* [.SG] */
167 aoHidd_PCIDevice_ISAEnable, /* [.SG] Enable ISA-specific IO forwarding */
168 aoHidd_PCIDevice_VGAEnable, /* [.SG] Enable VGA-specific IO/MEM forwarding regardless of limits */
170 num_Hidd_PCIDevice_Attrs
173 #define aHidd_PCIDevice_Driver (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Driver)
174 #define aHidd_PCIDevice_Bus (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Bus)
175 #define aHidd_PCIDevice_Dev (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Dev)
176 #define aHidd_PCIDevice_Sub (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Sub)
177 #define aHidd_PCIDevice_VendorID (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_VendorID)
178 #define aHidd_PCIDevice_ProductID (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_ProductID)
179 #define aHidd_PCIDevice_RevisionID (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_RevisionID)
180 #define aHidd_PCIDevice_Interface (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Interface)
181 #define aHidd_PCIDevice_Class (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Class)
182 #define aHidd_PCIDevice_SubClass (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_SubClass)
183 #define aHidd_PCIDevice_SubsystemVendorID (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_SubsystemVendorID)
184 #define aHidd_PCIDevice_SubsystemID (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_SubsystemID)
185 #define aHidd_PCIDevice_INTLine (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_INTLine)
186 #define aHidd_PCIDevice_IRQLine (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_IRQLine)
187 #define aHidd_PCIDevice_RomBase (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_RomBase)
188 #define aHidd_PCIDevice_RomSize (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_RomSize)
190 #define aHidd_PCIDevice_Base0 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Base0)
191 #define aHidd_PCIDevice_Base1 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Base1)
192 #define aHidd_PCIDevice_Base2 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Base2)
193 #define aHidd_PCIDevice_Base3 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Base3)
194 #define aHidd_PCIDevice_Base4 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Base4)
195 #define aHidd_PCIDevice_Base5 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Base5)
197 #define aHidd_PCIDevice_Size0 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Size0)
198 #define aHidd_PCIDevice_Size1 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Size1)
199 #define aHidd_PCIDevice_Size2 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Size2)
200 #define aHidd_PCIDevice_Size3 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Size3)
201 #define aHidd_PCIDevice_Size4 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Size4)
202 #define aHidd_PCIDevice_Size5 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Size5)
204 #define aHidd_PCIDevice_Type0 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Type0)
205 #define aHidd_PCIDevice_Type1 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Type1)
206 #define aHidd_PCIDevice_Type2 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Type2)
207 #define aHidd_PCIDevice_Type3 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Type3)
208 #define aHidd_PCIDevice_Type4 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Type4)
209 #define aHidd_PCIDevice_Type5 (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_Type5)
211 #define aHidd_PCIDevice_isIO (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_isIO)
212 #define aHidd_PCIDevice_isMEM (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_isMEM)
213 #define aHidd_PCIDevice_isMaster (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_isMaster)
214 #define aHidd_PCIDevice_paletteSnoop (HiddPCIDeviceAttrBase +aoHidd_PCIDevice_paletteSnoop)
215 #define aHidd_PCIDevice_is66MHz (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_is66MHz)
217 #define aHidd_PCIDevice_ClassDesc (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_ClassDesc)
218 #define aHidd_PCIDevice_SubClassDesc (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_SubClassDesc)
219 #define aHidd_PCIDevice_InterfaceDesc (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_InterfaceDesc)
221 #define aHidd_PCIDevice_isBridge (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_isBridge)
222 #define aHidd_PCIDevice_SubBus (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_SubBus)
223 #define aHidd_PCIDevice_MemoryBase (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_MemoryBase)
224 #define aHidd_PCIDevice_MemoryLimit (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_MemoryLimit)
225 #define aHidd_PCIDevice_PrefetchableBase (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_PrefetchableBase)
226 #define aHidd_PCIDevice_PrefetchableLimit (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_PrefetchableLimit)
227 #define aHidd_PCIDevice_IOBase (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_IOBase)
228 #define aHidd_PCIDevice_IOLimit (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_IOLimit)
229 #define aHidd_PCIDevice_ISAEnable (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_ISAEnable)
230 #define aHidd_PCIDevice_VGAEnable (HiddPCIDeviceAttrBase + aoHidd_PCIDevice_VGAEnable)
232 #define IS_PCIDEV_ATTR(attr, idx) \
233 (((idx) = (attr) - HiddPCIDeviceAttrBase) < num_Hidd_PCIDevice_Attrs)
235 /* Types of BaseAddresses */
236 #define ADDRB_IO 0
237 #define ADDRB_PREFETCH 3
239 #define ADDRF_IO (1 << ADDRB_IO)
240 #define ADDRF_PREFETCH (1 << ADDRB_PREFETCH)
242 struct pHidd_PCIDevice_ReadConfigByte
244 OOP_MethodID mID;
245 UBYTE reg; /* Register number */
248 struct pHidd_PCIDevice_ReadConfigWord
250 OOP_MethodID mID;
251 UBYTE reg; /* Register number */
254 struct pHidd_PCIDevice_ReadConfigLong
256 OOP_MethodID mID;
257 UBYTE reg; /* Register number */
260 struct pHidd_PCIDevice_WriteConfigByte
262 OOP_MethodID mID;
263 UBYTE reg; /* Register number */
264 UBYTE val; /* Value to be written */
267 struct pHidd_PCIDevice_WriteConfigWord
269 OOP_MethodID mID;
270 UBYTE reg; /* Register number */
271 UWORD val; /* Value to be written */
275 struct pHidd_PCIDevice_WriteConfigLong
277 OOP_MethodID mID;
278 UBYTE reg; /* Register number */
279 ULONG val; /* Value to be written */
283 /* PCI driver class */
285 #define CLID_Hidd_PCIDriver "hidd.pci.driver"
286 #define IID_Hidd_PCIDriver "hidd.pci.driver"
288 #define HiddPCIDriverAttrBase __IHidd_PCIDrv
290 enum
292 moHidd_PCIDriver_ReadConfigByte,
293 moHidd_PCIDriver_ReadConfigWord,
294 moHidd_PCIDriver_ReadConfigLong,
295 moHidd_PCIDriver_WriteConfigByte,
296 moHidd_PCIDriver_WriteConfigWord,
297 moHidd_PCIDriver_WriteConfigLong,
298 moHidd_PCIDriver_CPUtoPCI,
299 moHidd_PCIDriver_PCItoCPU,
300 moHidd_PCIDriver_MapPCI,
301 moHidd_PCIDriver_UnmapPCI,
302 moHidd_PCIDriver_AllocPCIMem,
303 moHidd_PCIDriver_FreePCIMem,
305 NUM_PCIDRIVER_METHODS
308 enum
310 aoHidd_PCIDriver_DirectBus, /* [..G] DirectBus shows whether CPUtoPCI and PCItoCPU methods are usable */
312 num_Hidd_PCIDriver_Attrs
315 #define aHidd_PCIDriver_DirectBus (aoHidd_PCIDriver_DirectBus + HiddPCIDriverAttrBase)
317 #define IS_PCIDRV_ATTR(attr, idx) \
318 (((idx) = (attr) - HiddPCIDriverAttrBase) < num_Hidd_PCIDriver_Attrs)
321 struct pHidd_PCIDriver_ReadConfigByte
323 OOP_MethodID mID;
324 UBYTE bus; /* Bus number */
325 UBYTE dev; /* Device number */
326 UBYTE sub; /* Function number */
327 UBYTE reg; /* Register number */
330 struct pHidd_PCIDriver_ReadConfigWord
332 OOP_MethodID mID;
333 UBYTE bus; /* Bus number */
334 UBYTE dev; /* Device number */
335 UBYTE sub; /* Function number */
336 UBYTE reg; /* Register number */
339 struct pHidd_PCIDriver_ReadConfigLong
341 OOP_MethodID mID;
342 UBYTE bus; /* Bus number */
343 UBYTE dev; /* Device number */
344 UBYTE sub; /* Function number */
345 UBYTE reg; /* Register number */
348 struct pHidd_PCIDriver_WriteConfigByte
350 OOP_MethodID mID;
351 UBYTE bus; /* Bus number */
352 UBYTE dev; /* Device number */
353 UBYTE sub; /* Function number */
354 UBYTE reg; /* Register number */
355 UBYTE val; /* Value to be written */
358 struct pHidd_PCIDriver_WriteConfigWord
360 OOP_MethodID mID;
361 UBYTE bus; /* Bus number */
362 UBYTE dev; /* Device number */
363 UBYTE sub; /* Function number */
364 UBYTE reg; /* Register number */
365 UWORD val; /* Value to be written */
369 struct pHidd_PCIDriver_WriteConfigLong
371 OOP_MethodID mID;
372 UBYTE bus; /* Bus number */
373 UBYTE dev; /* Device number */
374 UBYTE sub; /* Function number */
375 UBYTE reg; /* Register number */
376 ULONG val; /* Value to be written */
379 struct pHidd_PCIDriver_CPUtoPCI
381 OOP_MethodID mID;
382 APTR address; /* CPU address to be translated */
385 struct pHidd_PCIDriver_PCItoCPU
387 OOP_MethodID mID;
388 APTR address; /* PCI address to be translated */
391 struct pHidd_PCIDriver_MapPCI
393 OOP_MethodID mID;
394 APTR PCIAddress; /* Address on the PCIBus to be mapped to CPU address space */
395 ULONG Length; /* Length of mapped area */
398 struct pHidd_PCIDriver_UnmapPCI
400 OOP_MethodID mID;
401 APTR CPUAddress; /* Address as seen by the CPU of the PCI address space to unmap */
402 ULONG Length; /* Length of unmapped area */
405 struct pHidd_PCIDriver_AllocPCIMem
407 OOP_MethodID mID;
408 ULONG Size;
411 struct pHidd_PCIDriver_FreePCIMem
413 OOP_MethodID mID;
414 APTR Address;
417 /* Prototypes for stubs */
418 VOID HIDD_PCI_EnumDevices(OOP_Object *obj, struct Hook *hook, struct TagItem *requirements);
419 VOID HIDD_PCI_AddHardwareDriver(OOP_Object *obj, OOP_Class *driver);
420 APTR HIDD_PCIDriver_CPUtoPCI(OOP_Object *obj, APTR address);
421 APTR HIDD_PCIDriver_PCItoCPU(OOP_Object *obj, APTR address);
422 APTR HIDD_PCIDriver_MapPCI(OOP_Object *obj, APTR address, ULONG length);
423 VOID HIDD_PCIDriver_UnmapPCI(OOP_Object *obj, APTR address, ULONG length);
424 APTR HIDD_PCIDriver_AllocPCIMem(OOP_Object *obj, ULONG length);
425 VOID HIDD_PCIDriver_FreePCIMem(OOP_Object *obj, APTR address);
427 #endif