Commit 1ec619ee authored by Russell King (Oracle)'s avatar Russell King (Oracle) Committed by Jakub Kicinski

net: mtk_eth_soc: provide mtk_sgmii_config()

Provide mtk_sgmii_config() to wrap up the decisions about which SGMII
configuration will be called.
Signed-off-by: default avatarRussell King (Oracle) <rmk+kernel@armlinux.org.uk>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 4ce5a0bd
...@@ -388,12 +388,7 @@ static void mtk_mac_config(struct phylink_config *config, unsigned int mode, ...@@ -388,12 +388,7 @@ static void mtk_mac_config(struct phylink_config *config, unsigned int mode,
0 : mac->id; 0 : mac->id;
/* Setup SGMIISYS with the determined property */ /* Setup SGMIISYS with the determined property */
if (state->interface != PHY_INTERFACE_MODE_SGMII) err = mtk_sgmii_config(eth->sgmii, sid, mode, state->interface);
err = mtk_sgmii_setup_mode_force(eth->sgmii, sid,
state->interface);
else if (phylink_autoneg_inband(mode))
err = mtk_sgmii_setup_mode_an(eth->sgmii, sid);
if (err) if (err)
goto init_err; goto init_err;
......
...@@ -1014,9 +1014,8 @@ u32 mtk_r32(struct mtk_eth *eth, unsigned reg); ...@@ -1014,9 +1014,8 @@ u32 mtk_r32(struct mtk_eth *eth, unsigned reg);
int mtk_sgmii_init(struct mtk_sgmii *ss, struct device_node *np, int mtk_sgmii_init(struct mtk_sgmii *ss, struct device_node *np,
u32 ana_rgc3); u32 ana_rgc3);
int mtk_sgmii_setup_mode_an(struct mtk_sgmii *ss, int id); int mtk_sgmii_config(struct mtk_sgmii *ss, int id, unsigned int mode,
int mtk_sgmii_setup_mode_force(struct mtk_sgmii *ss, int id, phy_interface_t interface);
phy_interface_t interface);
void mtk_sgmii_link_up(struct mtk_sgmii *ss, int id, int speed, int duplex); void mtk_sgmii_link_up(struct mtk_sgmii *ss, int id, int speed, int duplex);
void mtk_sgmii_restart_an(struct mtk_eth *eth, int mac_id); void mtk_sgmii_restart_an(struct mtk_eth *eth, int mac_id);
......
...@@ -35,7 +35,7 @@ int mtk_sgmii_init(struct mtk_sgmii *ss, struct device_node *r, u32 ana_rgc3) ...@@ -35,7 +35,7 @@ int mtk_sgmii_init(struct mtk_sgmii *ss, struct device_node *r, u32 ana_rgc3)
} }
/* For SGMII interface mode */ /* For SGMII interface mode */
int mtk_sgmii_setup_mode_an(struct mtk_sgmii *ss, int id) static int mtk_sgmii_setup_mode_an(struct mtk_sgmii *ss, int id)
{ {
unsigned int val; unsigned int val;
...@@ -64,8 +64,8 @@ int mtk_sgmii_setup_mode_an(struct mtk_sgmii *ss, int id) ...@@ -64,8 +64,8 @@ int mtk_sgmii_setup_mode_an(struct mtk_sgmii *ss, int id)
/* For 1000BASE-X and 2500BASE-X interface modes, which operate at a /* For 1000BASE-X and 2500BASE-X interface modes, which operate at a
* fixed speed. * fixed speed.
*/ */
int mtk_sgmii_setup_mode_force(struct mtk_sgmii *ss, int id, static int mtk_sgmii_setup_mode_force(struct mtk_sgmii *ss, int id,
phy_interface_t interface) phy_interface_t interface)
{ {
unsigned int val; unsigned int val;
...@@ -97,6 +97,20 @@ int mtk_sgmii_setup_mode_force(struct mtk_sgmii *ss, int id, ...@@ -97,6 +97,20 @@ int mtk_sgmii_setup_mode_force(struct mtk_sgmii *ss, int id,
return 0; return 0;
} }
int mtk_sgmii_config(struct mtk_sgmii *ss, int id, unsigned int mode,
phy_interface_t interface)
{
int err = 0;
/* Setup SGMIISYS with the determined property */
if (interface != PHY_INTERFACE_MODE_SGMII)
err = mtk_sgmii_setup_mode_force(ss, id, interface);
else if (phylink_autoneg_inband(mode))
err = mtk_sgmii_setup_mode_an(ss, id);
return err;
}
/* For 1000BASE-X and 2500BASE-X interface modes */ /* For 1000BASE-X and 2500BASE-X interface modes */
void mtk_sgmii_link_up(struct mtk_sgmii *ss, int id, int speed, int duplex) void mtk_sgmii_link_up(struct mtk_sgmii *ss, int id, int speed, int duplex)
{ {
......
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