net/cadence_gem: Set PHY autonegotiation restart status
The Linux kernel PHY driver sets AN_RESTART in the BMCR of the PHY when autonegotiation is started. Recently the kernel started to read back the PHY's AN_RESTART bit and now checks whether the autonegotiation is complete and the bit was cleared [1]. Otherwise the link status is down. The emulated PHY needs to clear AN_RESTART immediately to inform the kernel driver about the completion of autonegotiation phase. [1] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=c36757eb9dee Signed-off-by: Linus Ziegert <linus.ziegert+qemu@holoplot.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Message-id: 20191104181604.21943-1-linus.ziegert+qemu@holoplot.com Cc: qemu-stable@nongnu.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
3a6606c7aa
commit
6623d21445
@ -274,6 +274,7 @@
|
||||
#define PHY_REG_CONTROL_RST 0x8000
|
||||
#define PHY_REG_CONTROL_LOOP 0x4000
|
||||
#define PHY_REG_CONTROL_ANEG 0x1000
|
||||
#define PHY_REG_CONTROL_ANRESTART 0x0200
|
||||
|
||||
#define PHY_REG_STATUS_LINK 0x0004
|
||||
#define PHY_REG_STATUS_ANEGCMPL 0x0020
|
||||
@ -1345,7 +1346,7 @@ static void gem_phy_write(CadenceGEMState *s, unsigned reg_num, uint16_t val)
|
||||
}
|
||||
if (val & PHY_REG_CONTROL_ANEG) {
|
||||
/* Complete autonegotiation immediately */
|
||||
val &= ~PHY_REG_CONTROL_ANEG;
|
||||
val &= ~(PHY_REG_CONTROL_ANEG | PHY_REG_CONTROL_ANRESTART);
|
||||
s->phy_regs[PHY_REG_STATUS] |= PHY_REG_STATUS_ANEGCMPL;
|
||||
}
|
||||
if (val & PHY_REG_CONTROL_LOOP) {
|
||||
|
Loading…
Reference in New Issue
Block a user