aboutsummaryrefslogtreecommitdiff
path: root/hw
diff options
context:
space:
mode:
Diffstat (limited to 'hw')
-rw-r--r--hw/e1000.c30
1 files changed, 14 insertions, 16 deletions
diff --git a/hw/e1000.c b/hw/e1000.c
index da37f82951..71ffc0e715 100644
--- a/hw/e1000.c
+++ b/hw/e1000.c
@@ -881,17 +881,11 @@ e1000_mmio_readw(void *opaque, target_phys_addr_t addr)
(8 * (addr & 3))) & 0xffff;
}
-static const struct {
- int size;
- int array0;
-} mac_regarraystosave[] = { {32, RA}, {128, MTA}, {128, VFTA} };
-enum { MAC_NARRAYS = ARRAY_SIZE(mac_regarraystosave) };
-
static void
nic_save(QEMUFile *f, void *opaque)
{
E1000State *s = opaque;
- int i, j;
+ int i;
pci_device_save(&s->dev, f);
qemu_put_be32(f, 0);
@@ -959,17 +953,19 @@ nic_save(QEMUFile *f, void *opaque)
qemu_put_be32s(f, &s->mac_reg[TXDCTL]);
qemu_put_be32s(f, &s->mac_reg[WUFC]);
qemu_put_be32s(f, &s->mac_reg[VET]);
- for (i = 0; i < MAC_NARRAYS; i++)
- for (j = 0; j < mac_regarraystosave[i].size; j++)
- qemu_put_be32s(f,
- s->mac_reg + mac_regarraystosave[i].array0 + j);
+ for (i = RA; i < RA + 32; i++)
+ qemu_put_be32s(f, &s->mac_reg[i]);
+ for (i = MTA; i < MTA + 128; i++)
+ qemu_put_be32s(f, &s->mac_reg[i]);
+ for (i = VFTA; i < VFTA + 128; i++)
+ qemu_put_be32s(f, &s->mac_reg[i]);
}
static int
nic_load(QEMUFile *f, void *opaque, int version_id)
{
E1000State *s = opaque;
- int i, j, ret;
+ int i, ret;
if ((ret = pci_device_load(&s->dev, f)) < 0)
return ret;
@@ -1040,10 +1036,12 @@ nic_load(QEMUFile *f, void *opaque, int version_id)
qemu_get_be32s(f, &s->mac_reg[TXDCTL]);
qemu_get_be32s(f, &s->mac_reg[WUFC]);
qemu_get_be32s(f, &s->mac_reg[VET]);
- for (i = 0; i < MAC_NARRAYS; i++)
- for (j = 0; j < mac_regarraystosave[i].size; j++)
- qemu_get_be32s(f,
- s->mac_reg + mac_regarraystosave[i].array0 + j);
+ for (i = RA; i < RA + 32; i++)
+ qemu_get_be32s(f, &s->mac_reg[i]);
+ for (i = MTA; i < MTA + 128; i++)
+ qemu_get_be32s(f, &s->mac_reg[i]);
+ for (i = VFTA; i < VFTA + 128; i++)
+ qemu_get_be32s(f, &s->mac_reg[i]);
return 0;
}