Revert "Update irqs on reset and device load"
authorBlue Swirl <blauwirbel@gmail.com>
Wed, 17 Jun 2009 17:01:03 +0000 (17:01 +0000)
committerBlue Swirl <blauwirbel@gmail.com>
Wed, 17 Jun 2009 17:01:03 +0000 (17:01 +0000)
This reverts commit 3dcd219f09d6c1817bf9a132899e6b925f7a0914.

It is incorrect to call qemu_irq functions (or any other functions that
access other device state) during savevm/loadvm.

Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
hw/e1000.c
hw/rtl8139.c

index cffcbde..5f4b123 100644 (file)
@@ -150,18 +150,12 @@ ioport_map(PCIDevice *pci_dev, int region_num, uint32_t addr,
 }
 
 static void
-update_irqs(E1000State *s)
-{
-    qemu_set_irq(s->dev.irq[0], (s->mac_reg[IMS] & s->mac_reg[ICR]) != 0);
-}
-
-static void
 set_interrupt_cause(E1000State *s, int index, uint32_t val)
 {
     if (val)
         val |= E1000_ICR_INT_ASSERTED;
     s->mac_reg[ICR] = val;
-    update_irqs(s);
+    qemu_set_irq(s->dev.irq[0], (s->mac_reg[IMS] & s->mac_reg[ICR]) != 0);
 }
 
 static void
@@ -978,7 +972,6 @@ nic_load(QEMUFile *f, void *opaque, int version_id)
         for (j = 0; j < mac_regarraystosave[i].size; j++)
             qemu_get_be32s(f,
                            s->mac_reg + mac_regarraystosave[i].array0 + j);
-    update_irqs(s);
     return 0;
 }
 
@@ -1077,7 +1070,6 @@ static void e1000_reset(void *opaque)
     memmove(d->mac_reg, mac_reg_init, sizeof mac_reg_init);
     d->rxbuf_min_shift = 1;
     memset(&d->tx, 0, sizeof d->tx);
-    update_irqs(d);
 }
 
 static void pci_e1000_init(PCIDevice *pci_dev)
index 1364606..0a66026 100644 (file)
@@ -3317,8 +3317,6 @@ static int rtl8139_load(QEMUFile* f,void* opaque,int version_id)
         s->cplus_enabled = s->CpCmd != 0;
     }
 
-    rtl8139_update_irq(s);
-
     return 0;
 }