Commit 3dcd219f09d6c1817bf9a132899e6b925f7a0914
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 | 150 | } |
151 | 151 | |
152 | 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 | 159 | set_interrupt_cause(E1000State *s, int index, uint32_t val) |
154 | 160 | { |
155 | 161 | if (val) |
156 | 162 | val |= E1000_ICR_INT_ASSERTED; |
157 | 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 | 167 | static void |
... | ... | @@ -970,6 +976,7 @@ nic_load(QEMUFile *f, void *opaque, int version_id) |
970 | 976 | for (j = 0; j < mac_regarraystosave[i].size; j++) |
971 | 977 | qemu_get_be32s(f, |
972 | 978 | s->mac_reg + mac_regarraystosave[i].array0 + j); |
979 | + update_irqs(s); | |
973 | 980 | return 0; |
974 | 981 | } |
975 | 982 | |
... | ... | @@ -1068,6 +1075,7 @@ static void e1000_reset(void *opaque) |
1068 | 1075 | memmove(d->mac_reg, mac_reg_init, sizeof mac_reg_init); |
1069 | 1076 | d->rxbuf_min_shift = 1; |
1070 | 1077 | memset(&d->tx, 0, sizeof d->tx); |
1078 | + update_irqs(d); | |
1071 | 1079 | } |
1072 | 1080 | |
1073 | 1081 | static void pci_e1000_init(PCIDevice *pci_dev) | ... | ... |