Am 28.10.2013 um 17:43 hat Paolo Bonzini geschrieben: > Signed-off-by: Paolo Bonzini <pbonz...@redhat.com> > --- > hw/ide/cmd646.c | 3 +-- > hw/ide/core.c | 5 +++++ > hw/ide/internal.h | 1 + > hw/ide/piix.c | 3 +-- > hw/ide/via.c | 3 +-- > 5 files changed, 9 insertions(+), 6 deletions(-) > > diff --git a/hw/ide/cmd646.c b/hw/ide/cmd646.c > index 0500a7a..4753543 100644 > --- a/hw/ide/cmd646.c > +++ b/hw/ide/cmd646.c > @@ -294,8 +294,7 @@ static int pci_cmd646_ide_initfn(PCIDevice *dev) > > bmdma_init(&d->bus[i], &d->bmdma[i], d); > d->bmdma[i].bus = &d->bus[i]; > - qemu_add_vm_change_state_handler(d->bus[i].dma->ops->restart_cb, > - &d->bmdma[i].dma); > + ide_register_restart_cb(&d->bus[i]); > } > > vmstate_register(DEVICE(dev), 0, &vmstate_ide_pci, d); > diff --git a/hw/ide/core.c b/hw/ide/core.c > index 1e3108c..93cfd46 100644 > --- a/hw/ide/core.c > +++ b/hw/ide/core.c > @@ -2193,6 +2193,11 @@ static const IDEDMAOps ide_dma_nop_ops = { > .restart_cb = ide_nop_restart, > }; > > +void ide_register_restart_cb(IDEBus *bus) > +{ > + qemu_add_vm_change_state_handler(bus->dma->ops->restart_cb, bus->dma); > +} > + > static IDEDMA ide_dma_nop = { > .ops = &ide_dma_nop_ops, > .aiocb = NULL, > diff --git a/hw/ide/internal.h b/hw/ide/internal.h > index 96969d9..678b33c 100644 > --- a/hw/ide/internal.h > +++ b/hw/ide/internal.h > @@ -548,6 +548,7 @@ void ide_init2(IDEBus *bus, qemu_irq irq); > void ide_init2_with_non_qdev_drives(IDEBus *bus, DriveInfo *hd0, > DriveInfo *hd1, qemu_irq irq); > void ide_init_ioport(IDEBus *bus, ISADevice *isa, int iobase, int iobase2); > +void ide_register_restart_cb(IDEBus *bus); > > void ide_exec_cmd(IDEBus *bus, uint32_t val); > void ide_dma_cb(void *opaque, int ret); > diff --git a/hw/ide/piix.c b/hw/ide/piix.c > index ab36749..d7f5118 100644 > --- a/hw/ide/piix.c > +++ b/hw/ide/piix.c > @@ -143,8 +143,7 @@ static void pci_piix_init_ports(PCIIDEState *d) { > > bmdma_init(&d->bus[i], &d->bmdma[i], d); > d->bmdma[i].bus = &d->bus[i]; > - qemu_add_vm_change_state_handler(d->bus[i].dma->ops->restart_cb, > - &d->bmdma[i].dma); > + ide_register_restart_cb(&d->bus[i]); > } > } > > diff --git a/hw/ide/via.c b/hw/ide/via.c > index 99468c7..ae52164 100644 > --- a/hw/ide/via.c > +++ b/hw/ide/via.c > @@ -166,8 +166,7 @@ static void vt82c686b_init_ports(PCIIDEState *d) { > > bmdma_init(&d->bus[i], &d->bmdma[i], d); > d->bmdma[i].bus = &d->bus[i]; > - qemu_add_vm_change_state_handler(d->bus[i].dma->ops->restart_cb, > - &d->bmdma[i].dma); > + ide_register_restart_cb(&d->bus[i]); > } > }
Can't we instead register a callback somewhere in core.c? Kevin