From: Hervé Poussineau Date: Wed, 3 Jun 2015 20:45:49 +0000 (+0200) Subject: net/dp8393x: fix hardware reset X-Git-Tag: v2.4.0-rc0~79^2~7 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=bd8f1ebce430eb6c1dd92e34baf7bc35aa600464;p=thirdparty%2Fqemu.git net/dp8393x: fix hardware reset Documentation is not clear of what happens when doing a hardware reset, but firmware expect all registers to be zero unless specified otherwise. This fixes reboot on MIPS Magnum. Signed-off-by: Hervé Poussineau Reviewed-by: Aurelien Jarno Signed-off-by: Leon Alrae --- diff --git a/hw/net/dp8393x.c b/hw/net/dp8393x.c index ff633f76a03..cd889bce86b 100644 --- a/hw/net/dp8393x.c +++ b/hw/net/dp8393x.c @@ -786,6 +786,7 @@ static void dp8393x_reset(DeviceState *dev) dp8393xState *s = DP8393X(dev); timer_del(s->watchdog); + memset(s->regs, 0, sizeof(s->regs)); s->regs[SONIC_CR] = SONIC_CR_RST | SONIC_CR_STP | SONIC_CR_RXDIS; s->regs[SONIC_DCR] &= ~(SONIC_DCR_EXBUS | SONIC_DCR_LBR); s->regs[SONIC_RCR] &= ~(SONIC_RCR_LB0 | SONIC_RCR_LB1 | SONIC_RCR_BRD | SONIC_RCR_RNT);