Commit 3dcd219f09d6c1817bf9a132899e6b925f7a0914

Authored by Blue Swirl
1 parent 32c86e95

Update irqs on reset and device load

Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
Showing 2 changed files with 11 additions and 1 deletions
hw/e1000.c
@@ -150,12 +150,18 @@ ioport_map(PCIDevice *pci_dev, int region_num, uint32_t addr, @@ -150,12 +150,18 @@ 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
153 set_interrupt_cause(E1000State *s, int index, uint32_t val) 159 set_interrupt_cause(E1000State *s, int index, uint32_t val)
154 { 160 {
155 if (val) 161 if (val)
156 val |= E1000_ICR_INT_ASSERTED; 162 val |= E1000_ICR_INT_ASSERTED;
157 s->mac_reg[ICR] = val; 163 s->mac_reg[ICR] = val;
158 - qemu_set_irq(s->dev.irq[0], (s->mac_reg[IMS] & s->mac_reg[ICR]) != 0); 164 + update_irqs(s);
159 } 165 }
160 166
161 static void 167 static void
@@ -970,6 +976,7 @@ nic_load(QEMUFile *f, void *opaque, int version_id) @@ -970,6 +976,7 @@ nic_load(QEMUFile *f, void *opaque, int version_id)
970 for (j = 0; j < mac_regarraystosave[i].size; j++) 976 for (j = 0; j < mac_regarraystosave[i].size; j++)
971 qemu_get_be32s(f, 977 qemu_get_be32s(f,
972 s->mac_reg + mac_regarraystosave[i].array0 + j); 978 s->mac_reg + mac_regarraystosave[i].array0 + j);
  979 + update_irqs(s);
973 return 0; 980 return 0;
974 } 981 }
975 982
@@ -1068,6 +1075,7 @@ static void e1000_reset(void *opaque) @@ -1068,6 +1075,7 @@ static void e1000_reset(void *opaque)
1068 memmove(d->mac_reg, mac_reg_init, sizeof mac_reg_init); 1075 memmove(d->mac_reg, mac_reg_init, sizeof mac_reg_init);
1069 d->rxbuf_min_shift = 1; 1076 d->rxbuf_min_shift = 1;
1070 memset(&d->tx, 0, sizeof d->tx); 1077 memset(&d->tx, 0, sizeof d->tx);
  1078 + update_irqs(d);
1071 } 1079 }
1072 1080
1073 static void pci_e1000_init(PCIDevice *pci_dev) 1081 static void pci_e1000_init(PCIDevice *pci_dev)
hw/rtl8139.c
@@ -3314,6 +3314,8 @@ static int rtl8139_load(QEMUFile* f,void* opaque,int version_id) @@ -3314,6 +3314,8 @@ static int rtl8139_load(QEMUFile* f,void* opaque,int version_id)
3314 s->cplus_enabled = s->CpCmd != 0; 3314 s->cplus_enabled = s->CpCmd != 0;
3315 } 3315 }
3316 3316
  3317 + rtl8139_update_irq(s);
  3318 +
3317 return 0; 3319 return 0;
3318 } 3320 }
3319 3321