Commit 18e1b742 authored by Alexis Lothoré's avatar Alexis Lothoré Committed by Jakub Kicinski

net: dsa: mv88e6xxx: pass mv88e6xxx_chip structure to port_max_speed_mode

Some switches families have minor differences on supported link speed for
ports. Instead of redefining a new port_max_speed_mode for each different
configuration, allow to pass mv88e6xxx_chip structure to allow
differentiating those chips by known chip id
Signed-off-by: default avatarAlexis Lothoré <alexis.lothore@bootlin.com>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 2f934939
...@@ -3334,7 +3334,7 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port) ...@@ -3334,7 +3334,7 @@ static int mv88e6xxx_setup_port(struct mv88e6xxx_chip *chip, int port)
caps = pl_config.mac_capabilities; caps = pl_config.mac_capabilities;
if (chip->info->ops->port_max_speed_mode) if (chip->info->ops->port_max_speed_mode)
mode = chip->info->ops->port_max_speed_mode(port); mode = chip->info->ops->port_max_speed_mode(chip, port);
else else
mode = PHY_INTERFACE_MODE_NA; mode = PHY_INTERFACE_MODE_NA;
......
...@@ -518,7 +518,8 @@ struct mv88e6xxx_ops { ...@@ -518,7 +518,8 @@ struct mv88e6xxx_ops {
int speed, int duplex); int speed, int duplex);
/* What interface mode should be used for maximum speed? */ /* What interface mode should be used for maximum speed? */
phy_interface_t (*port_max_speed_mode)(int port); phy_interface_t (*port_max_speed_mode)(struct mv88e6xxx_chip *chip,
int port);
int (*port_tag_remap)(struct mv88e6xxx_chip *chip, int port); int (*port_tag_remap)(struct mv88e6xxx_chip *chip, int port);
......
...@@ -342,7 +342,8 @@ int mv88e6341_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port, ...@@ -342,7 +342,8 @@ int mv88e6341_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port,
duplex); duplex);
} }
phy_interface_t mv88e6341_port_max_speed_mode(int port) phy_interface_t mv88e6341_port_max_speed_mode(struct mv88e6xxx_chip *chip,
int port)
{ {
if (port == 5) if (port == 5)
return PHY_INTERFACE_MODE_2500BASEX; return PHY_INTERFACE_MODE_2500BASEX;
...@@ -381,7 +382,8 @@ int mv88e6390_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port, ...@@ -381,7 +382,8 @@ int mv88e6390_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port,
duplex); duplex);
} }
phy_interface_t mv88e6390_port_max_speed_mode(int port) phy_interface_t mv88e6390_port_max_speed_mode(struct mv88e6xxx_chip *chip,
int port)
{ {
if (port == 9 || port == 10) if (port == 9 || port == 10)
return PHY_INTERFACE_MODE_2500BASEX; return PHY_INTERFACE_MODE_2500BASEX;
...@@ -403,7 +405,8 @@ int mv88e6390x_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port, ...@@ -403,7 +405,8 @@ int mv88e6390x_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port,
duplex); duplex);
} }
phy_interface_t mv88e6390x_port_max_speed_mode(int port) phy_interface_t mv88e6390x_port_max_speed_mode(struct mv88e6xxx_chip *chip,
int port)
{ {
if (port == 9 || port == 10) if (port == 9 || port == 10)
return PHY_INTERFACE_MODE_XAUI; return PHY_INTERFACE_MODE_XAUI;
...@@ -500,7 +503,8 @@ int mv88e6393x_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port, ...@@ -500,7 +503,8 @@ int mv88e6393x_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port,
return 0; return 0;
} }
phy_interface_t mv88e6393x_port_max_speed_mode(int port) phy_interface_t mv88e6393x_port_max_speed_mode(struct mv88e6xxx_chip *chip,
int port)
{ {
if (port == 0 || port == 9 || port == 10) if (port == 0 || port == 9 || port == 10)
return PHY_INTERFACE_MODE_10GBASER; return PHY_INTERFACE_MODE_10GBASER;
......
...@@ -359,10 +359,14 @@ int mv88e6390x_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port, ...@@ -359,10 +359,14 @@ int mv88e6390x_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port,
int mv88e6393x_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port, int mv88e6393x_port_set_speed_duplex(struct mv88e6xxx_chip *chip, int port,
int speed, int duplex); int speed, int duplex);
phy_interface_t mv88e6341_port_max_speed_mode(int port); phy_interface_t mv88e6341_port_max_speed_mode(struct mv88e6xxx_chip *chip,
phy_interface_t mv88e6390_port_max_speed_mode(int port); int port);
phy_interface_t mv88e6390x_port_max_speed_mode(int port); phy_interface_t mv88e6390_port_max_speed_mode(struct mv88e6xxx_chip *chip,
phy_interface_t mv88e6393x_port_max_speed_mode(int port); int port);
phy_interface_t mv88e6390x_port_max_speed_mode(struct mv88e6xxx_chip *chip,
int port);
phy_interface_t mv88e6393x_port_max_speed_mode(struct mv88e6xxx_chip *chip,
int port);
int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state); int mv88e6xxx_port_set_state(struct mv88e6xxx_chip *chip, int port, u8 state);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment