Message ID | 20140619194051.GI1695@ERROL.INI.CMU.EDU |
---|---|
State | New |
Headers | show |
On Thu, Jun 19, 2014 at 03:40:51PM -0400, Gabriel L. Somlo wrote: > Also fix minor indentation issues in the surrounding code. > > Suggested-by: Michael S. Tsirkin <mst@redhat.com> > Signed-off-by: Gabriel Somlo <somlo@cmu.edu> Applied, thanks! > --- > hw/net/e1000.c | 26 ++++++++++++++------------ > 1 file changed, 14 insertions(+), 12 deletions(-) > > diff --git a/hw/net/e1000.c b/hw/net/e1000.c > index 8ee5225..0fc29a0 100644 > --- a/hw/net/e1000.c > +++ b/hw/net/e1000.c > @@ -848,6 +848,14 @@ receive_filter(E1000State *s, const uint8_t *buf, int size) > return 0; > } > > +static bool > +have_autoneg(E1000State *s) > +{ > + return (s->compat_flags & E1000_FLAG_AUTONEG) && > + (s->phy_reg[PHY_CTRL] & MII_CR_AUTO_NEG_EN) && > + (s->phy_reg[PHY_CTRL] & MII_CR_RESTART_AUTO_NEG); > +} > + > static void > e1000_set_link_status(NetClientState *nc) > { > @@ -857,9 +865,7 @@ e1000_set_link_status(NetClientState *nc) > if (nc->link_down) { > e1000_link_down(s); > } else { > - if (s->compat_flags & E1000_FLAG_AUTONEG && > - s->phy_reg[PHY_CTRL] & MII_CR_AUTO_NEG_EN && > - s->phy_reg[PHY_CTRL] & MII_CR_RESTART_AUTO_NEG && > + if (have_autoneg(s) && > !(s->phy_reg[PHY_STATUS] & MII_SR_AUTONEG_COMPLETE)) { > /* emulate auto-negotiation if supported */ > timer_mod(s->autoneg_timer, > @@ -1297,11 +1303,8 @@ static void e1000_pre_save(void *opaque) > * complete auto-negotiation immediately. This allows us to look > * at MII_SR_AUTONEG_COMPLETE to infer link status on load. > */ > - if (nc->link_down && > - s->compat_flags & E1000_FLAG_AUTONEG && > - s->phy_reg[PHY_CTRL] & MII_CR_AUTO_NEG_EN && > - s->phy_reg[PHY_CTRL] & MII_CR_RESTART_AUTO_NEG) { > - s->phy_reg[PHY_STATUS] |= MII_SR_AUTONEG_COMPLETE; > + if (nc->link_down && have_autoneg(s)) { > + s->phy_reg[PHY_STATUS] |= MII_SR_AUTONEG_COMPLETE; > } > } > > @@ -1323,12 +1326,11 @@ static int e1000_post_load(void *opaque, int version_id) > * Alternatively, restart link negotiation if it was in progress. */ > nc->link_down = (s->mac_reg[STATUS] & E1000_STATUS_LU) == 0; > > - if (s->compat_flags & E1000_FLAG_AUTONEG && > - s->phy_reg[PHY_CTRL] & MII_CR_AUTO_NEG_EN && > - s->phy_reg[PHY_CTRL] & MII_CR_RESTART_AUTO_NEG && > + if (have_autoneg(s) && > !(s->phy_reg[PHY_STATUS] & MII_SR_AUTONEG_COMPLETE)) { > nc->link_down = false; > - timer_mod(s->autoneg_timer, qemu_clock_get_ms(QEMU_CLOCK_VIRTUAL) + 500); > + timer_mod(s->autoneg_timer, > + qemu_clock_get_ms(QEMU_CLOCK_VIRTUAL) + 500); > } > > return 0; > -- > 1.9.3
diff --git a/hw/net/e1000.c b/hw/net/e1000.c index 8ee5225..0fc29a0 100644 --- a/hw/net/e1000.c +++ b/hw/net/e1000.c @@ -848,6 +848,14 @@ receive_filter(E1000State *s, const uint8_t *buf, int size) return 0; } +static bool +have_autoneg(E1000State *s) +{ + return (s->compat_flags & E1000_FLAG_AUTONEG) && + (s->phy_reg[PHY_CTRL] & MII_CR_AUTO_NEG_EN) && + (s->phy_reg[PHY_CTRL] & MII_CR_RESTART_AUTO_NEG); +} + static void e1000_set_link_status(NetClientState *nc) { @@ -857,9 +865,7 @@ e1000_set_link_status(NetClientState *nc) if (nc->link_down) { e1000_link_down(s); } else { - if (s->compat_flags & E1000_FLAG_AUTONEG && - s->phy_reg[PHY_CTRL] & MII_CR_AUTO_NEG_EN && - s->phy_reg[PHY_CTRL] & MII_CR_RESTART_AUTO_NEG && + if (have_autoneg(s) && !(s->phy_reg[PHY_STATUS] & MII_SR_AUTONEG_COMPLETE)) { /* emulate auto-negotiation if supported */ timer_mod(s->autoneg_timer, @@ -1297,11 +1303,8 @@ static void e1000_pre_save(void *opaque) * complete auto-negotiation immediately. This allows us to look * at MII_SR_AUTONEG_COMPLETE to infer link status on load. */ - if (nc->link_down && - s->compat_flags & E1000_FLAG_AUTONEG && - s->phy_reg[PHY_CTRL] & MII_CR_AUTO_NEG_EN && - s->phy_reg[PHY_CTRL] & MII_CR_RESTART_AUTO_NEG) { - s->phy_reg[PHY_STATUS] |= MII_SR_AUTONEG_COMPLETE; + if (nc->link_down && have_autoneg(s)) { + s->phy_reg[PHY_STATUS] |= MII_SR_AUTONEG_COMPLETE; } } @@ -1323,12 +1326,11 @@ static int e1000_post_load(void *opaque, int version_id) * Alternatively, restart link negotiation if it was in progress. */ nc->link_down = (s->mac_reg[STATUS] & E1000_STATUS_LU) == 0; - if (s->compat_flags & E1000_FLAG_AUTONEG && - s->phy_reg[PHY_CTRL] & MII_CR_AUTO_NEG_EN && - s->phy_reg[PHY_CTRL] & MII_CR_RESTART_AUTO_NEG && + if (have_autoneg(s) && !(s->phy_reg[PHY_STATUS] & MII_SR_AUTONEG_COMPLETE)) { nc->link_down = false; - timer_mod(s->autoneg_timer, qemu_clock_get_ms(QEMU_CLOCK_VIRTUAL) + 500); + timer_mod(s->autoneg_timer, + qemu_clock_get_ms(QEMU_CLOCK_VIRTUAL) + 500); } return 0;
Also fix minor indentation issues in the surrounding code. Suggested-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Gabriel Somlo <somlo@cmu.edu> --- hw/net/e1000.c | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-)