net: dsa: mv88e6xxx: Default CMODE to 1000BaseX only on 6390X
authorMarek Behún <marek.behun@nic.cz>
Mon, 25 Feb 2019 11:39:54 +0000 (12:39 +0100)
committerDavid S. Miller <davem@davemloft.net>
Mon, 25 Feb 2019 17:47:09 +0000 (09:47 -0800)
Commit 787799a9d555 sets the SERDES interfaces of 6390 and 6390X to
1000BaseX, but this is only needed on 6390X, since there are SERDES
interfaces which can be used on lower ports on 6390.

This commit fixes this by returning to previous behaviour on 6390.
(Previous behaviour means that CMODE is not set at all if requested mode
is NA).

This is needed on Turris MOX, where the 88e6190 is connected to CPU in
2500BaseX mode.

Fixes: 787799a9d555 ("net: dsa: mv88e6xxx: Default ports 9/10 6390X CMODE to 1000BaseX")
Signed-off-by: Marek Behún <marek.behun@nic.cz>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/mv88e6xxx/port.c

index ebd26b6a93e6b6084545e2649daa40c9621da47d..ee7029f4ee2241e42edfd121376e7a86ab4b13ed 100644 (file)
@@ -444,6 +444,8 @@ int mv88e6390_port_set_cmode(struct mv88e6xxx_chip *chip, int port,
                             phy_interface_t mode)
 {
        switch (mode) {
+       case PHY_INTERFACE_MODE_NA:
+               return 0;
        case PHY_INTERFACE_MODE_XGMII:
        case PHY_INTERFACE_MODE_XAUI:
        case PHY_INTERFACE_MODE_RXAUI: