diff options
author | Blue Swirl <blauwirbel@gmail.com> | 2009-06-09 15:02:00 +0000 |
---|---|---|
committer | Blue Swirl <blauwirbel@gmail.com> | 2009-06-09 15:02:00 +0000 |
commit | 32c86e95b258515099d04f9eff48efc57a469bf7 (patch) | |
tree | f9733ba1364a0aaa3c9a640a8f6531dfc42e44dc /hw/e1000.c | |
parent | 98ba2632fc2695838657a972fce69270cb79dc77 (diff) |
Register reset functions for e1000 and rtl8139
Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
Diffstat (limited to 'hw/e1000.c')
-rw-r--r-- | hw/e1000.c | 21 |
1 files changed, 14 insertions, 7 deletions
diff --git a/hw/e1000.c b/hw/e1000.c index 26657922c5..a04d7b1fe4 100644 --- a/hw/e1000.c +++ b/hw/e1000.c @@ -1058,6 +1058,18 @@ pci_e1000_uninit(PCIDevice *dev) return 0; } +static void e1000_reset(void *opaque) +{ + E1000State *d = opaque; + + memset(d->phy_reg, 0, sizeof d->phy_reg); + memmove(d->phy_reg, phy_reg_init, sizeof phy_reg_init); + memset(d->mac_reg, 0, sizeof d->mac_reg); + memmove(d->mac_reg, mac_reg_init, sizeof mac_reg_init); + d->rxbuf_min_shift = 1; + memset(&d->tx, 0, sizeof d->tx); +} + static void pci_e1000_init(PCIDevice *pci_dev) { E1000State *d = (E1000State *)pci_dev; @@ -1098,13 +1110,6 @@ static void pci_e1000_init(PCIDevice *pci_dev) checksum = (uint16_t) EEPROM_SUM - checksum; d->eeprom_data[EEPROM_CHECKSUM_REG] = checksum; - memset(d->phy_reg, 0, sizeof d->phy_reg); - memmove(d->phy_reg, phy_reg_init, sizeof phy_reg_init); - memset(d->mac_reg, 0, sizeof d->mac_reg); - memmove(d->mac_reg, mac_reg_init, sizeof mac_reg_init); - d->rxbuf_min_shift = 1; - memset(&d->tx, 0, sizeof d->tx); - d->vc = qdev_get_vlan_client(&d->dev.qdev, e1000_receive, e1000_can_receive, e1000_cleanup, d); @@ -1114,6 +1119,8 @@ static void pci_e1000_init(PCIDevice *pci_dev) register_savevm(info_str, -1, 2, nic_save, nic_load, d); d->dev.unregister = pci_e1000_uninit; + qemu_register_reset(e1000_reset, 0, d); + e1000_reset(d); } static void e1000_register_devices(void) |