#ifndef HW_IDE_PCI_H #define HW_IDE_PCI_H #include <hw/ide/internal.h> typedef struct BMDMAState { IDEDMA dma; uint8_t cmd; uint8_t status; uint32_t addr; IDEBus *bus; /* current transfer state */ uint32_t cur_addr; uint32_t cur_prd_last; uint32_t cur_prd_addr; uint32_t cur_prd_len; uint8_t unit; BlockDriverCompletionFunc *dma_cb; int64_t sector_num; uint32_t nsector; IORange addr_ioport; QEMUBH *bh; qemu_irq irq; } BMDMAState; typedef struct PCIIDEState { PCIDevice dev; IDEBus bus[2]; BMDMAState bmdma[2]; uint32_t secondary; /* used only for cmd646 */ } PCIIDEState; 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); void bmdma_cmd_writeb(void *opaque, uint32_t addr, uint32_t val); extern const IORangeOps bmdma_addr_ioport_ops; void pci_ide_create_devs(PCIDevice *dev, DriveInfo **hd_table); extern const VMStateDescription vmstate_ide_pci; #endif