pci: Allow PCI bus subtypes to support extended config space accesses
[qemu/ar7.git] / include / hw / ide.h
blob28d8a06439fb64d6f7843a4cdbe924425a39162f
1 #ifndef HW_IDE_H
2 #define HW_IDE_H
4 #include "hw/isa/isa.h"
5 #include "hw/pci/pci.h"
6 #include "exec/memory.h"
8 #define MAX_IDE_DEVS 2
10 /* ide-isa.c */
11 ISADevice *isa_ide_init(ISABus *bus, int iobase, int iobase2, int isairq,
12 DriveInfo *hd0, DriveInfo *hd1);
14 /* ide-pci.c */
15 void pci_cmd646_ide_init(PCIBus *bus, DriveInfo **hd_table,
16 int secondary_ide_enabled);
17 PCIDevice *pci_piix3_xen_ide_init(PCIBus *bus, DriveInfo **hd_table, int devfn);
18 PCIDevice *pci_piix3_ide_init(PCIBus *bus, DriveInfo **hd_table, int devfn);
19 PCIDevice *pci_piix4_ide_init(PCIBus *bus, DriveInfo **hd_table, int devfn);
20 int pci_piix3_xen_ide_unplug(DeviceState *dev, bool aux);
21 void via_ide_init(PCIBus *bus, DriveInfo **hd_table, int devfn);
23 /* ide-mmio.c */
24 void mmio_ide_init_drives(DeviceState *dev, DriveInfo *hd0, DriveInfo *hd1);
26 int ide_get_geometry(BusState *bus, int unit,
27 int16_t *cyls, int8_t *heads, int8_t *secs);
28 int ide_get_bios_chs_trans(BusState *bus, int unit);
30 /* ide/core.c */
31 void ide_drive_get(DriveInfo **hd, int max_bus);
33 #endif /* HW_IDE_H */