| #include <hw/ide/internal.h> |
| typedef struct BMDMAState { |
| /* current transfer state */ |
| BlockDriverCompletionFunc *dma_cb; |
| MemoryRegion addr_ioport; |
| /* Bit 0-2 and 7: BM status register |
| * Bit 3-6: bus->error_status */ |
| uint8_t migration_compat_status; |
| struct PCIIDEState *pci_dev; |
| typedef struct CMD646BAR { |
| struct PCIIDEState *pci_dev; |
| typedef struct PCIIDEState { |
| uint32_t secondary; /* used only for cmd646 */ |
| CMD646BAR cmd646_bar[2]; /* used only for cmd646 */ |
| static inline IDEState *bmdma_active_if(BMDMAState *bmdma) |
| assert(bmdma->unit != (uint8_t)-1); |
| return bmdma->bus->ifs + bmdma->unit; |
| void bmdma_init(IDEBus *bus, BMDMAState *bm, PCIIDEState *d); |
| void bmdma_cmd_writeb(BMDMAState *bm, uint32_t val); |
| extern MemoryRegionOps bmdma_addr_ioport_ops; |
| void pci_ide_create_devs(PCIDevice *dev, DriveInfo **hd_table); |
| extern const VMStateDescription vmstate_ide_pci; |