Commit bc26e55a6615dc594be425d293db40d5cdcdb84b
1 parent
727170b6
Revert "Update irqs on reset and device load"
This reverts commit 3dcd219f. 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>
Showing
2 changed files
with
1 additions
and
11 deletions
hw/e1000.c
| @@ -150,18 +150,12 @@ ioport_map(PCIDevice *pci_dev, int region_num, uint32_t addr, | @@ -150,18 +150,12 @@ ioport_map(PCIDevice *pci_dev, int region_num, uint32_t addr, | ||
| 150 | } | 150 | } |
| 151 | 151 | ||
| 152 | static void | 152 | static void |
| 153 | -update_irqs(E1000State *s) | ||
| 154 | -{ | ||
| 155 | - qemu_set_irq(s->dev.irq[0], (s->mac_reg[IMS] & s->mac_reg[ICR]) != 0); | ||
| 156 | -} | ||
| 157 | - | ||
| 158 | -static void | ||
| 159 | set_interrupt_cause(E1000State *s, int index, uint32_t val) | 153 | set_interrupt_cause(E1000State *s, int index, uint32_t val) |
| 160 | { | 154 | { |
| 161 | if (val) | 155 | if (val) |
| 162 | val |= E1000_ICR_INT_ASSERTED; | 156 | val |= E1000_ICR_INT_ASSERTED; |
| 163 | s->mac_reg[ICR] = val; | 157 | s->mac_reg[ICR] = val; |
| 164 | - update_irqs(s); | 158 | + qemu_set_irq(s->dev.irq[0], (s->mac_reg[IMS] & s->mac_reg[ICR]) != 0); |
| 165 | } | 159 | } |
| 166 | 160 | ||
| 167 | static void | 161 | static void |
| @@ -978,7 +972,6 @@ nic_load(QEMUFile *f, void *opaque, int version_id) | @@ -978,7 +972,6 @@ nic_load(QEMUFile *f, void *opaque, int version_id) | ||
| 978 | for (j = 0; j < mac_regarraystosave[i].size; j++) | 972 | for (j = 0; j < mac_regarraystosave[i].size; j++) |
| 979 | qemu_get_be32s(f, | 973 | qemu_get_be32s(f, |
| 980 | s->mac_reg + mac_regarraystosave[i].array0 + j); | 974 | s->mac_reg + mac_regarraystosave[i].array0 + j); |
| 981 | - update_irqs(s); | ||
| 982 | return 0; | 975 | return 0; |
| 983 | } | 976 | } |
| 984 | 977 | ||
| @@ -1077,7 +1070,6 @@ static void e1000_reset(void *opaque) | @@ -1077,7 +1070,6 @@ static void e1000_reset(void *opaque) | ||
| 1077 | memmove(d->mac_reg, mac_reg_init, sizeof mac_reg_init); | 1070 | memmove(d->mac_reg, mac_reg_init, sizeof mac_reg_init); |
| 1078 | d->rxbuf_min_shift = 1; | 1071 | d->rxbuf_min_shift = 1; |
| 1079 | memset(&d->tx, 0, sizeof d->tx); | 1072 | memset(&d->tx, 0, sizeof d->tx); |
| 1080 | - update_irqs(d); | ||
| 1081 | } | 1073 | } |
| 1082 | 1074 | ||
| 1083 | static void pci_e1000_init(PCIDevice *pci_dev) | 1075 | static void pci_e1000_init(PCIDevice *pci_dev) |
hw/rtl8139.c
| @@ -3317,8 +3317,6 @@ static int rtl8139_load(QEMUFile* f,void* opaque,int version_id) | @@ -3317,8 +3317,6 @@ static int rtl8139_load(QEMUFile* f,void* opaque,int version_id) | ||
| 3317 | s->cplus_enabled = s->CpCmd != 0; | 3317 | s->cplus_enabled = s->CpCmd != 0; |
| 3318 | } | 3318 | } |
| 3319 | 3319 | ||
| 3320 | - rtl8139_update_irq(s); | ||
| 3321 | - | ||
| 3322 | return 0; | 3320 | return 0; |
| 3323 | } | 3321 | } |
| 3324 | 3322 |