Skip to content

Commit 364e9d7

Browse files
lunndavem330
authored andcommitted
net: dsa: mv88e6xxx: Power on/off SERDES on cmode change
The 6390 family has a number of SERDES interfaces per port. When the cmode changes, eg 1000Base-X to XAUI, the SERDES interface in use will also change. Power down the old SERDES interface and power up the new SERDES interface. Signed-off-by: Andrew Lunn <andrew@lunn.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent 2d2e1dd commit 364e9d7

File tree

1 file changed

+9
-0
lines changed
  • drivers/net/dsa/mv88e6xxx

1 file changed

+9
-0
lines changed

drivers/net/dsa/mv88e6xxx/port.c

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@
1919

2020
#include "chip.h"
2121
#include "port.h"
22+
#include "serdes.h"
2223

2324
int mv88e6xxx_port_read(struct mv88e6xxx_chip *chip, int port, int reg,
2425
u16 *val)
@@ -372,6 +373,10 @@ int mv88e6390x_port_set_cmode(struct mv88e6xxx_chip *chip, int port,
372373
cmode = 0;
373374
}
374375

376+
err = mv88e6390_serdes_power(chip, port, false);
377+
if (err)
378+
return err;
379+
375380
if (cmode) {
376381
err = mv88e6xxx_port_read(chip, port, MV88E6XXX_PORT_STS, &reg);
377382
if (err)
@@ -383,6 +388,10 @@ int mv88e6390x_port_set_cmode(struct mv88e6xxx_chip *chip, int port,
383388
err = mv88e6xxx_port_write(chip, port, MV88E6XXX_PORT_STS, reg);
384389
if (err)
385390
return err;
391+
392+
err = mv88e6390_serdes_power(chip, port, true);
393+
if (err)
394+
return err;
386395
}
387396

388397
chip->ports[port].cmode = cmode;

0 commit comments

Comments
 (0)