mirror of
https://git.proxmox.com/git/qemu
synced 2025-06-15 09:46:54 +00:00
ide: Introduce abstract QOM type for PCIIDEState
Needed for QOM casts. Signed-off-by: Andreas Färber <afaerber@suse.de>
This commit is contained in:
parent
02a9594b4f
commit
f6c11d5644
@ -127,7 +127,7 @@ static uint64_t bmdma_read(void *opaque, hwaddr addr,
|
|||||||
unsigned size)
|
unsigned size)
|
||||||
{
|
{
|
||||||
BMDMAState *bm = opaque;
|
BMDMAState *bm = opaque;
|
||||||
PCIIDEState *pci_dev = bm->pci_dev;
|
PCIDevice *pci_dev = PCI_DEVICE(bm->pci_dev);
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
|
|
||||||
if (size != 1) {
|
if (size != 1) {
|
||||||
@ -139,16 +139,16 @@ static uint64_t bmdma_read(void *opaque, hwaddr addr,
|
|||||||
val = bm->cmd;
|
val = bm->cmd;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
val = pci_dev->dev.config[MRDMODE];
|
val = pci_dev->config[MRDMODE];
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
val = bm->status;
|
val = bm->status;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
if (bm == &pci_dev->bmdma[0]) {
|
if (bm == &bm->pci_dev->bmdma[0]) {
|
||||||
val = pci_dev->dev.config[UDIDETCR0];
|
val = pci_dev->config[UDIDETCR0];
|
||||||
} else {
|
} else {
|
||||||
val = pci_dev->dev.config[UDIDETCR1];
|
val = pci_dev->config[UDIDETCR1];
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -165,7 +165,7 @@ static void bmdma_write(void *opaque, hwaddr addr,
|
|||||||
uint64_t val, unsigned size)
|
uint64_t val, unsigned size)
|
||||||
{
|
{
|
||||||
BMDMAState *bm = opaque;
|
BMDMAState *bm = opaque;
|
||||||
PCIIDEState *pci_dev = bm->pci_dev;
|
PCIDevice *pci_dev = PCI_DEVICE(bm->pci_dev);
|
||||||
|
|
||||||
if (size != 1) {
|
if (size != 1) {
|
||||||
return;
|
return;
|
||||||
@ -179,18 +179,19 @@ static void bmdma_write(void *opaque, hwaddr addr,
|
|||||||
bmdma_cmd_writeb(bm, val);
|
bmdma_cmd_writeb(bm, val);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
pci_dev->dev.config[MRDMODE] =
|
pci_dev->config[MRDMODE] =
|
||||||
(pci_dev->dev.config[MRDMODE] & ~0x30) | (val & 0x30);
|
(pci_dev->config[MRDMODE] & ~0x30) | (val & 0x30);
|
||||||
cmd646_update_irq(pci_dev);
|
cmd646_update_irq(bm->pci_dev);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
bm->status = (val & 0x60) | (bm->status & 1) | (bm->status & ~val & 0x06);
|
bm->status = (val & 0x60) | (bm->status & 1) | (bm->status & ~val & 0x06);
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
if (bm == &pci_dev->bmdma[0])
|
if (bm == &bm->pci_dev->bmdma[0]) {
|
||||||
pci_dev->dev.config[UDIDETCR0] = val;
|
pci_dev->config[UDIDETCR0] = val;
|
||||||
else
|
} else {
|
||||||
pci_dev->dev.config[UDIDETCR1] = val;
|
pci_dev->config[UDIDETCR1] = val;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -222,25 +223,29 @@ static void bmdma_setup_bar(PCIIDEState *d)
|
|||||||
registers */
|
registers */
|
||||||
static void cmd646_update_irq(PCIIDEState *d)
|
static void cmd646_update_irq(PCIIDEState *d)
|
||||||
{
|
{
|
||||||
|
PCIDevice *pd = PCI_DEVICE(d);
|
||||||
int pci_level;
|
int pci_level;
|
||||||
pci_level = ((d->dev.config[MRDMODE] & MRDMODE_INTR_CH0) &&
|
|
||||||
!(d->dev.config[MRDMODE] & MRDMODE_BLK_CH0)) ||
|
pci_level = ((pd->config[MRDMODE] & MRDMODE_INTR_CH0) &&
|
||||||
((d->dev.config[MRDMODE] & MRDMODE_INTR_CH1) &&
|
!(pd->config[MRDMODE] & MRDMODE_BLK_CH0)) ||
|
||||||
!(d->dev.config[MRDMODE] & MRDMODE_BLK_CH1));
|
((pd->config[MRDMODE] & MRDMODE_INTR_CH1) &&
|
||||||
qemu_set_irq(d->dev.irq[0], pci_level);
|
!(pd->config[MRDMODE] & MRDMODE_BLK_CH1));
|
||||||
|
qemu_set_irq(pd->irq[0], pci_level);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* the PCI irq level is the logical OR of the two channels */
|
/* the PCI irq level is the logical OR of the two channels */
|
||||||
static void cmd646_set_irq(void *opaque, int channel, int level)
|
static void cmd646_set_irq(void *opaque, int channel, int level)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = opaque;
|
PCIIDEState *d = opaque;
|
||||||
|
PCIDevice *pd = PCI_DEVICE(d);
|
||||||
int irq_mask;
|
int irq_mask;
|
||||||
|
|
||||||
irq_mask = MRDMODE_INTR_CH0 << channel;
|
irq_mask = MRDMODE_INTR_CH0 << channel;
|
||||||
if (level)
|
if (level) {
|
||||||
d->dev.config[MRDMODE] |= irq_mask;
|
pd->config[MRDMODE] |= irq_mask;
|
||||||
else
|
} else {
|
||||||
d->dev.config[MRDMODE] &= ~irq_mask;
|
pd->config[MRDMODE] &= ~irq_mask;
|
||||||
|
}
|
||||||
cmd646_update_irq(d);
|
cmd646_update_irq(d);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -257,8 +262,8 @@ static void cmd646_reset(void *opaque)
|
|||||||
/* CMD646 PCI IDE controller */
|
/* CMD646 PCI IDE controller */
|
||||||
static int pci_cmd646_ide_initfn(PCIDevice *dev)
|
static int pci_cmd646_ide_initfn(PCIDevice *dev)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = DO_UPCAST(PCIIDEState, dev, dev);
|
PCIIDEState *d = PCI_IDE(dev);
|
||||||
uint8_t *pci_conf = d->dev.config;
|
uint8_t *pci_conf = dev->config;
|
||||||
qemu_irq *irq;
|
qemu_irq *irq;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -284,7 +289,7 @@ static int pci_cmd646_ide_initfn(PCIDevice *dev)
|
|||||||
|
|
||||||
irq = qemu_allocate_irqs(cmd646_set_irq, d, 2);
|
irq = qemu_allocate_irqs(cmd646_set_irq, d, 2);
|
||||||
for (i = 0; i < 2; i++) {
|
for (i = 0; i < 2; i++) {
|
||||||
ide_bus_new(&d->bus[i], &d->dev.qdev, i, 2);
|
ide_bus_new(&d->bus[i], DEVICE(dev), i, 2);
|
||||||
ide_init2(&d->bus[i], irq[i]);
|
ide_init2(&d->bus[i], irq[i]);
|
||||||
|
|
||||||
bmdma_init(&d->bus[i], &d->bmdma[i], d);
|
bmdma_init(&d->bus[i], &d->bmdma[i], d);
|
||||||
@ -293,14 +298,14 @@ static int pci_cmd646_ide_initfn(PCIDevice *dev)
|
|||||||
&d->bmdma[i].dma);
|
&d->bmdma[i].dma);
|
||||||
}
|
}
|
||||||
|
|
||||||
vmstate_register(&dev->qdev, 0, &vmstate_ide_pci, d);
|
vmstate_register(DEVICE(dev), 0, &vmstate_ide_pci, d);
|
||||||
qemu_register_reset(cmd646_reset, d);
|
qemu_register_reset(cmd646_reset, d);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void pci_cmd646_ide_exitfn(PCIDevice *dev)
|
static void pci_cmd646_ide_exitfn(PCIDevice *dev)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = DO_UPCAST(PCIIDEState, dev, dev);
|
PCIIDEState *d = PCI_IDE(dev);
|
||||||
unsigned i;
|
unsigned i;
|
||||||
|
|
||||||
for (i = 0; i < 2; ++i) {
|
for (i = 0; i < 2; ++i) {
|
||||||
@ -347,8 +352,7 @@ static void cmd646_ide_class_init(ObjectClass *klass, void *data)
|
|||||||
|
|
||||||
static const TypeInfo cmd646_ide_info = {
|
static const TypeInfo cmd646_ide_info = {
|
||||||
.name = "cmd646-ide",
|
.name = "cmd646-ide",
|
||||||
.parent = TYPE_PCI_DEVICE,
|
.parent = TYPE_PCI_IDE,
|
||||||
.instance_size = sizeof(PCIIDEState),
|
|
||||||
.class_init = cmd646_ide_class_init,
|
.class_init = cmd646_ide_class_init,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
30
hw/ide/pci.c
30
hw/ide/pci.c
@ -56,13 +56,14 @@ static int bmdma_prepare_buf(IDEDMA *dma, int is_write)
|
|||||||
{
|
{
|
||||||
BMDMAState *bm = DO_UPCAST(BMDMAState, dma, dma);
|
BMDMAState *bm = DO_UPCAST(BMDMAState, dma, dma);
|
||||||
IDEState *s = bmdma_active_if(bm);
|
IDEState *s = bmdma_active_if(bm);
|
||||||
|
PCIDevice *pci_dev = PCI_DEVICE(bm->pci_dev);
|
||||||
struct {
|
struct {
|
||||||
uint32_t addr;
|
uint32_t addr;
|
||||||
uint32_t size;
|
uint32_t size;
|
||||||
} prd;
|
} prd;
|
||||||
int l, len;
|
int l, len;
|
||||||
|
|
||||||
pci_dma_sglist_init(&s->sg, &bm->pci_dev->dev,
|
pci_dma_sglist_init(&s->sg, pci_dev,
|
||||||
s->nsector / (BMDMA_PAGE_SIZE / 512) + 1);
|
s->nsector / (BMDMA_PAGE_SIZE / 512) + 1);
|
||||||
s->io_buffer_size = 0;
|
s->io_buffer_size = 0;
|
||||||
for(;;) {
|
for(;;) {
|
||||||
@ -71,7 +72,7 @@ static int bmdma_prepare_buf(IDEDMA *dma, int is_write)
|
|||||||
if (bm->cur_prd_last ||
|
if (bm->cur_prd_last ||
|
||||||
(bm->cur_addr - bm->addr) >= BMDMA_PAGE_SIZE)
|
(bm->cur_addr - bm->addr) >= BMDMA_PAGE_SIZE)
|
||||||
return s->io_buffer_size != 0;
|
return s->io_buffer_size != 0;
|
||||||
pci_dma_read(&bm->pci_dev->dev, bm->cur_addr, &prd, 8);
|
pci_dma_read(pci_dev, bm->cur_addr, &prd, 8);
|
||||||
bm->cur_addr += 8;
|
bm->cur_addr += 8;
|
||||||
prd.addr = le32_to_cpu(prd.addr);
|
prd.addr = le32_to_cpu(prd.addr);
|
||||||
prd.size = le32_to_cpu(prd.size);
|
prd.size = le32_to_cpu(prd.size);
|
||||||
@ -98,6 +99,7 @@ static int bmdma_rw_buf(IDEDMA *dma, int is_write)
|
|||||||
{
|
{
|
||||||
BMDMAState *bm = DO_UPCAST(BMDMAState, dma, dma);
|
BMDMAState *bm = DO_UPCAST(BMDMAState, dma, dma);
|
||||||
IDEState *s = bmdma_active_if(bm);
|
IDEState *s = bmdma_active_if(bm);
|
||||||
|
PCIDevice *pci_dev = PCI_DEVICE(bm->pci_dev);
|
||||||
struct {
|
struct {
|
||||||
uint32_t addr;
|
uint32_t addr;
|
||||||
uint32_t size;
|
uint32_t size;
|
||||||
@ -113,7 +115,7 @@ static int bmdma_rw_buf(IDEDMA *dma, int is_write)
|
|||||||
if (bm->cur_prd_last ||
|
if (bm->cur_prd_last ||
|
||||||
(bm->cur_addr - bm->addr) >= BMDMA_PAGE_SIZE)
|
(bm->cur_addr - bm->addr) >= BMDMA_PAGE_SIZE)
|
||||||
return 0;
|
return 0;
|
||||||
pci_dma_read(&bm->pci_dev->dev, bm->cur_addr, &prd, 8);
|
pci_dma_read(pci_dev, bm->cur_addr, &prd, 8);
|
||||||
bm->cur_addr += 8;
|
bm->cur_addr += 8;
|
||||||
prd.addr = le32_to_cpu(prd.addr);
|
prd.addr = le32_to_cpu(prd.addr);
|
||||||
prd.size = le32_to_cpu(prd.size);
|
prd.size = le32_to_cpu(prd.size);
|
||||||
@ -128,10 +130,10 @@ static int bmdma_rw_buf(IDEDMA *dma, int is_write)
|
|||||||
l = bm->cur_prd_len;
|
l = bm->cur_prd_len;
|
||||||
if (l > 0) {
|
if (l > 0) {
|
||||||
if (is_write) {
|
if (is_write) {
|
||||||
pci_dma_write(&bm->pci_dev->dev, bm->cur_prd_addr,
|
pci_dma_write(pci_dev, bm->cur_prd_addr,
|
||||||
s->io_buffer + s->io_buffer_index, l);
|
s->io_buffer + s->io_buffer_index, l);
|
||||||
} else {
|
} else {
|
||||||
pci_dma_read(&bm->pci_dev->dev, bm->cur_prd_addr,
|
pci_dma_read(pci_dev, bm->cur_prd_addr,
|
||||||
s->io_buffer + s->io_buffer_index, l);
|
s->io_buffer + s->io_buffer_index, l);
|
||||||
}
|
}
|
||||||
bm->cur_prd_addr += l;
|
bm->cur_prd_addr += l;
|
||||||
@ -480,7 +482,7 @@ const VMStateDescription vmstate_ide_pci = {
|
|||||||
.minimum_version_id_old = 0,
|
.minimum_version_id_old = 0,
|
||||||
.post_load = ide_pci_post_load,
|
.post_load = ide_pci_post_load,
|
||||||
.fields = (VMStateField []) {
|
.fields = (VMStateField []) {
|
||||||
VMSTATE_PCI_DEVICE(dev, PCIIDEState),
|
VMSTATE_PCI_DEVICE(parent_obj, PCIIDEState),
|
||||||
VMSTATE_STRUCT_ARRAY(bmdma, PCIIDEState, 2, 0,
|
VMSTATE_STRUCT_ARRAY(bmdma, PCIIDEState, 2, 0,
|
||||||
vmstate_bmdma, BMDMAState),
|
vmstate_bmdma, BMDMAState),
|
||||||
VMSTATE_IDE_BUS_ARRAY(bus, PCIIDEState, 2),
|
VMSTATE_IDE_BUS_ARRAY(bus, PCIIDEState, 2),
|
||||||
@ -492,7 +494,7 @@ const VMStateDescription vmstate_ide_pci = {
|
|||||||
|
|
||||||
void pci_ide_create_devs(PCIDevice *dev, DriveInfo **hd_table)
|
void pci_ide_create_devs(PCIDevice *dev, DriveInfo **hd_table)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = DO_UPCAST(PCIIDEState, dev, dev);
|
PCIIDEState *d = PCI_IDE(dev);
|
||||||
static const int bus[4] = { 0, 0, 1, 1 };
|
static const int bus[4] = { 0, 0, 1, 1 };
|
||||||
static const int unit[4] = { 0, 1, 0, 1 };
|
static const int unit[4] = { 0, 1, 0, 1 };
|
||||||
int i;
|
int i;
|
||||||
@ -531,3 +533,17 @@ void bmdma_init(IDEBus *bus, BMDMAState *bm, PCIIDEState *d)
|
|||||||
bus->irq = *irq;
|
bus->irq = *irq;
|
||||||
bm->pci_dev = d;
|
bm->pci_dev = d;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const TypeInfo pci_ide_type_info = {
|
||||||
|
.name = TYPE_PCI_IDE,
|
||||||
|
.parent = TYPE_PCI_DEVICE,
|
||||||
|
.instance_size = sizeof(PCIIDEState),
|
||||||
|
.abstract = true,
|
||||||
|
};
|
||||||
|
|
||||||
|
static void pci_ide_register_types(void)
|
||||||
|
{
|
||||||
|
type_register_static(&pci_ide_type_info);
|
||||||
|
}
|
||||||
|
|
||||||
|
type_init(pci_ide_register_types)
|
||||||
|
@ -37,8 +37,14 @@ typedef struct CMD646BAR {
|
|||||||
struct PCIIDEState *pci_dev;
|
struct PCIIDEState *pci_dev;
|
||||||
} CMD646BAR;
|
} CMD646BAR;
|
||||||
|
|
||||||
|
#define TYPE_PCI_IDE "pci-ide"
|
||||||
|
#define PCI_IDE(obj) OBJECT_CHECK(PCIIDEState, (obj), TYPE_PCI_IDE)
|
||||||
|
|
||||||
typedef struct PCIIDEState {
|
typedef struct PCIIDEState {
|
||||||
PCIDevice dev;
|
/*< private >*/
|
||||||
|
PCIDevice parent_obj;
|
||||||
|
/*< public >*/
|
||||||
|
|
||||||
IDEBus bus[2];
|
IDEBus bus[2];
|
||||||
BMDMAState bmdma[2];
|
BMDMAState bmdma[2];
|
||||||
uint32_t secondary; /* used only for cmd646 */
|
uint32_t secondary; /* used only for cmd646 */
|
||||||
|
@ -106,7 +106,8 @@ static void bmdma_setup_bar(PCIIDEState *d)
|
|||||||
static void piix3_reset(void *opaque)
|
static void piix3_reset(void *opaque)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = opaque;
|
PCIIDEState *d = opaque;
|
||||||
uint8_t *pci_conf = d->dev.config;
|
PCIDevice *pd = PCI_DEVICE(d);
|
||||||
|
uint8_t *pci_conf = pd->config;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < 2; i++) {
|
for (i = 0; i < 2; i++) {
|
||||||
@ -149,15 +150,15 @@ static void pci_piix_init_ports(PCIIDEState *d) {
|
|||||||
|
|
||||||
static int pci_piix_ide_initfn(PCIDevice *dev)
|
static int pci_piix_ide_initfn(PCIDevice *dev)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = DO_UPCAST(PCIIDEState, dev, dev);
|
PCIIDEState *d = PCI_IDE(dev);
|
||||||
uint8_t *pci_conf = d->dev.config;
|
uint8_t *pci_conf = dev->config;
|
||||||
|
|
||||||
pci_conf[PCI_CLASS_PROG] = 0x80; // legacy ATA mode
|
pci_conf[PCI_CLASS_PROG] = 0x80; // legacy ATA mode
|
||||||
|
|
||||||
qemu_register_reset(piix3_reset, d);
|
qemu_register_reset(piix3_reset, d);
|
||||||
|
|
||||||
bmdma_setup_bar(d);
|
bmdma_setup_bar(d);
|
||||||
pci_register_bar(&d->dev, 4, PCI_BASE_ADDRESS_SPACE_IO, &d->bmdma_bar);
|
pci_register_bar(dev, 4, PCI_BASE_ADDRESS_SPACE_IO, &d->bmdma_bar);
|
||||||
|
|
||||||
vmstate_register(DEVICE(dev), 0, &vmstate_ide_pci, d);
|
vmstate_register(DEVICE(dev), 0, &vmstate_ide_pci, d);
|
||||||
|
|
||||||
@ -168,13 +169,11 @@ static int pci_piix_ide_initfn(PCIDevice *dev)
|
|||||||
|
|
||||||
static int pci_piix3_xen_ide_unplug(DeviceState *dev)
|
static int pci_piix3_xen_ide_unplug(DeviceState *dev)
|
||||||
{
|
{
|
||||||
PCIDevice *pci_dev;
|
|
||||||
PCIIDEState *pci_ide;
|
PCIIDEState *pci_ide;
|
||||||
DriveInfo *di;
|
DriveInfo *di;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
pci_dev = PCI_DEVICE(dev);
|
pci_ide = PCI_IDE(dev);
|
||||||
pci_ide = DO_UPCAST(PCIIDEState, dev, pci_dev);
|
|
||||||
|
|
||||||
for (; i < 3; i++) {
|
for (; i < 3; i++) {
|
||||||
di = drive_get_by_index(IF_IDE, i);
|
di = drive_get_by_index(IF_IDE, i);
|
||||||
@ -203,7 +202,7 @@ PCIDevice *pci_piix3_xen_ide_init(PCIBus *bus, DriveInfo **hd_table, int devfn)
|
|||||||
|
|
||||||
static void pci_piix_ide_exitfn(PCIDevice *dev)
|
static void pci_piix_ide_exitfn(PCIDevice *dev)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = DO_UPCAST(PCIIDEState, dev, dev);
|
PCIIDEState *d = PCI_IDE(dev);
|
||||||
unsigned i;
|
unsigned i;
|
||||||
|
|
||||||
for (i = 0; i < 2; ++i) {
|
for (i = 0; i < 2; ++i) {
|
||||||
@ -254,8 +253,7 @@ static void piix3_ide_class_init(ObjectClass *klass, void *data)
|
|||||||
|
|
||||||
static const TypeInfo piix3_ide_info = {
|
static const TypeInfo piix3_ide_info = {
|
||||||
.name = "piix3-ide",
|
.name = "piix3-ide",
|
||||||
.parent = TYPE_PCI_DEVICE,
|
.parent = TYPE_PCI_IDE,
|
||||||
.instance_size = sizeof(PCIIDEState),
|
|
||||||
.class_init = piix3_ide_class_init,
|
.class_init = piix3_ide_class_init,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -275,8 +273,7 @@ static void piix3_ide_xen_class_init(ObjectClass *klass, void *data)
|
|||||||
|
|
||||||
static const TypeInfo piix3_ide_xen_info = {
|
static const TypeInfo piix3_ide_xen_info = {
|
||||||
.name = "piix3-ide-xen",
|
.name = "piix3-ide-xen",
|
||||||
.parent = TYPE_PCI_DEVICE,
|
.parent = TYPE_PCI_IDE,
|
||||||
.instance_size = sizeof(PCIIDEState),
|
|
||||||
.class_init = piix3_ide_xen_class_init,
|
.class_init = piix3_ide_xen_class_init,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -297,8 +294,7 @@ static void piix4_ide_class_init(ObjectClass *klass, void *data)
|
|||||||
|
|
||||||
static const TypeInfo piix4_ide_info = {
|
static const TypeInfo piix4_ide_info = {
|
||||||
.name = "piix4-ide",
|
.name = "piix4-ide",
|
||||||
.parent = TYPE_PCI_DEVICE,
|
.parent = TYPE_PCI_IDE,
|
||||||
.instance_size = sizeof(PCIIDEState),
|
|
||||||
.class_init = piix4_ide_class_init,
|
.class_init = piix4_ide_class_init,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
18
hw/ide/via.c
18
hw/ide/via.c
@ -108,7 +108,8 @@ static void bmdma_setup_bar(PCIIDEState *d)
|
|||||||
static void via_reset(void *opaque)
|
static void via_reset(void *opaque)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = opaque;
|
PCIIDEState *d = opaque;
|
||||||
uint8_t *pci_conf = d->dev.config;
|
PCIDevice *pd = PCI_DEVICE(d);
|
||||||
|
uint8_t *pci_conf = pd->config;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < 2; i++) {
|
for (i = 0; i < 2; i++) {
|
||||||
@ -158,7 +159,7 @@ static void vt82c686b_init_ports(PCIIDEState *d) {
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < 2; i++) {
|
for (i = 0; i < 2; i++) {
|
||||||
ide_bus_new(&d->bus[i], &d->dev.qdev, i, 2);
|
ide_bus_new(&d->bus[i], DEVICE(d), i, 2);
|
||||||
ide_init_ioport(&d->bus[i], NULL, port_info[i].iobase,
|
ide_init_ioport(&d->bus[i], NULL, port_info[i].iobase,
|
||||||
port_info[i].iobase2);
|
port_info[i].iobase2);
|
||||||
ide_init2(&d->bus[i], isa_get_irq(NULL, port_info[i].isairq));
|
ide_init2(&d->bus[i], isa_get_irq(NULL, port_info[i].isairq));
|
||||||
@ -173,17 +174,17 @@ static void vt82c686b_init_ports(PCIIDEState *d) {
|
|||||||
/* via ide func */
|
/* via ide func */
|
||||||
static int vt82c686b_ide_initfn(PCIDevice *dev)
|
static int vt82c686b_ide_initfn(PCIDevice *dev)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = DO_UPCAST(PCIIDEState, dev, dev);
|
PCIIDEState *d = PCI_IDE(dev);
|
||||||
uint8_t *pci_conf = d->dev.config;
|
uint8_t *pci_conf = dev->config;
|
||||||
|
|
||||||
pci_config_set_prog_interface(pci_conf, 0x8a); /* legacy ATA mode */
|
pci_config_set_prog_interface(pci_conf, 0x8a); /* legacy ATA mode */
|
||||||
pci_set_long(pci_conf + PCI_CAPABILITY_LIST, 0x000000c0);
|
pci_set_long(pci_conf + PCI_CAPABILITY_LIST, 0x000000c0);
|
||||||
|
|
||||||
qemu_register_reset(via_reset, d);
|
qemu_register_reset(via_reset, d);
|
||||||
bmdma_setup_bar(d);
|
bmdma_setup_bar(d);
|
||||||
pci_register_bar(&d->dev, 4, PCI_BASE_ADDRESS_SPACE_IO, &d->bmdma_bar);
|
pci_register_bar(dev, 4, PCI_BASE_ADDRESS_SPACE_IO, &d->bmdma_bar);
|
||||||
|
|
||||||
vmstate_register(&dev->qdev, 0, &vmstate_ide_pci, d);
|
vmstate_register(DEVICE(dev), 0, &vmstate_ide_pci, d);
|
||||||
|
|
||||||
vt82c686b_init_ports(d);
|
vt82c686b_init_ports(d);
|
||||||
|
|
||||||
@ -192,7 +193,7 @@ static int vt82c686b_ide_initfn(PCIDevice *dev)
|
|||||||
|
|
||||||
static void vt82c686b_ide_exitfn(PCIDevice *dev)
|
static void vt82c686b_ide_exitfn(PCIDevice *dev)
|
||||||
{
|
{
|
||||||
PCIIDEState *d = DO_UPCAST(PCIIDEState, dev, dev);
|
PCIIDEState *d = PCI_IDE(dev);
|
||||||
unsigned i;
|
unsigned i;
|
||||||
|
|
||||||
for (i = 0; i < 2; ++i) {
|
for (i = 0; i < 2; ++i) {
|
||||||
@ -229,8 +230,7 @@ static void via_ide_class_init(ObjectClass *klass, void *data)
|
|||||||
|
|
||||||
static const TypeInfo via_ide_info = {
|
static const TypeInfo via_ide_info = {
|
||||||
.name = "via-ide",
|
.name = "via-ide",
|
||||||
.parent = TYPE_PCI_DEVICE,
|
.parent = TYPE_PCI_IDE,
|
||||||
.instance_size = sizeof(PCIIDEState),
|
|
||||||
.class_init = via_ide_class_init,
|
.class_init = via_ide_class_init,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user