提交 fd0bb28c 编写于 作者: A Ansuel Smith 提交者: David S. Miller

net: dsa: qca8k: move port config to dedicated struct

Move ports related config to dedicated struct to keep things organized.
Signed-off-by: NAnsuel Smith <ansuelsmth@gmail.com>
Reviewed-by: NFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 cef08115
...@@ -1019,7 +1019,7 @@ qca8k_parse_port_config(struct qca8k_priv *priv) ...@@ -1019,7 +1019,7 @@ qca8k_parse_port_config(struct qca8k_priv *priv)
delay = 3; delay = 3;
} }
priv->rgmii_tx_delay[cpu_port_index] = delay; priv->ports_config.rgmii_tx_delay[cpu_port_index] = delay;
delay = 0; delay = 0;
...@@ -1035,7 +1035,7 @@ qca8k_parse_port_config(struct qca8k_priv *priv) ...@@ -1035,7 +1035,7 @@ qca8k_parse_port_config(struct qca8k_priv *priv)
delay = 3; delay = 3;
} }
priv->rgmii_rx_delay[cpu_port_index] = delay; priv->ports_config.rgmii_rx_delay[cpu_port_index] = delay;
/* Skip sgmii parsing for rgmii* mode */ /* Skip sgmii parsing for rgmii* mode */
if (mode == PHY_INTERFACE_MODE_RGMII || if (mode == PHY_INTERFACE_MODE_RGMII ||
...@@ -1045,17 +1045,17 @@ qca8k_parse_port_config(struct qca8k_priv *priv) ...@@ -1045,17 +1045,17 @@ qca8k_parse_port_config(struct qca8k_priv *priv)
break; break;
if (of_property_read_bool(port_dn, "qca,sgmii-txclk-falling-edge")) if (of_property_read_bool(port_dn, "qca,sgmii-txclk-falling-edge"))
priv->sgmii_tx_clk_falling_edge = true; priv->ports_config.sgmii_tx_clk_falling_edge = true;
if (of_property_read_bool(port_dn, "qca,sgmii-rxclk-falling-edge")) if (of_property_read_bool(port_dn, "qca,sgmii-rxclk-falling-edge"))
priv->sgmii_rx_clk_falling_edge = true; priv->ports_config.sgmii_rx_clk_falling_edge = true;
if (of_property_read_bool(port_dn, "qca,sgmii-enable-pll")) { if (of_property_read_bool(port_dn, "qca,sgmii-enable-pll")) {
priv->sgmii_enable_pll = true; priv->ports_config.sgmii_enable_pll = true;
if (priv->switch_id == QCA8K_ID_QCA8327) { if (priv->switch_id == QCA8K_ID_QCA8327) {
dev_err(priv->dev, "SGMII PLL should NOT be enabled for qca8327. Aborting enabling"); dev_err(priv->dev, "SGMII PLL should NOT be enabled for qca8327. Aborting enabling");
priv->sgmii_enable_pll = false; priv->ports_config.sgmii_enable_pll = false;
} }
if (priv->switch_revision < 2) if (priv->switch_revision < 2)
...@@ -1281,15 +1281,15 @@ qca8k_mac_config_setup_internal_delay(struct qca8k_priv *priv, int cpu_port_inde ...@@ -1281,15 +1281,15 @@ qca8k_mac_config_setup_internal_delay(struct qca8k_priv *priv, int cpu_port_inde
* not enabled. With ID or TX/RXID delay is enabled and set * not enabled. With ID or TX/RXID delay is enabled and set
* to the default and recommended value. * to the default and recommended value.
*/ */
if (priv->rgmii_tx_delay[cpu_port_index]) { if (priv->ports_config.rgmii_tx_delay[cpu_port_index]) {
delay = priv->rgmii_tx_delay[cpu_port_index]; delay = priv->ports_config.rgmii_tx_delay[cpu_port_index];
val |= QCA8K_PORT_PAD_RGMII_TX_DELAY(delay) | val |= QCA8K_PORT_PAD_RGMII_TX_DELAY(delay) |
QCA8K_PORT_PAD_RGMII_TX_DELAY_EN; QCA8K_PORT_PAD_RGMII_TX_DELAY_EN;
} }
if (priv->rgmii_rx_delay[cpu_port_index]) { if (priv->ports_config.rgmii_rx_delay[cpu_port_index]) {
delay = priv->rgmii_rx_delay[cpu_port_index]; delay = priv->ports_config.rgmii_rx_delay[cpu_port_index];
val |= QCA8K_PORT_PAD_RGMII_RX_DELAY(delay) | val |= QCA8K_PORT_PAD_RGMII_RX_DELAY(delay) |
QCA8K_PORT_PAD_RGMII_RX_DELAY_EN; QCA8K_PORT_PAD_RGMII_RX_DELAY_EN;
...@@ -1397,7 +1397,7 @@ qca8k_phylink_mac_config(struct dsa_switch *ds, int port, unsigned int mode, ...@@ -1397,7 +1397,7 @@ qca8k_phylink_mac_config(struct dsa_switch *ds, int port, unsigned int mode,
val |= QCA8K_SGMII_EN_SD; val |= QCA8K_SGMII_EN_SD;
if (priv->sgmii_enable_pll) if (priv->ports_config.sgmii_enable_pll)
val |= QCA8K_SGMII_EN_PLL | QCA8K_SGMII_EN_RX | val |= QCA8K_SGMII_EN_PLL | QCA8K_SGMII_EN_RX |
QCA8K_SGMII_EN_TX; QCA8K_SGMII_EN_TX;
...@@ -1425,10 +1425,10 @@ qca8k_phylink_mac_config(struct dsa_switch *ds, int port, unsigned int mode, ...@@ -1425,10 +1425,10 @@ qca8k_phylink_mac_config(struct dsa_switch *ds, int port, unsigned int mode,
val = 0; val = 0;
/* SGMII Clock phase configuration */ /* SGMII Clock phase configuration */
if (priv->sgmii_rx_clk_falling_edge) if (priv->ports_config.sgmii_rx_clk_falling_edge)
val |= QCA8K_PORT0_PAD_SGMII_RXCLK_FALLING_EDGE; val |= QCA8K_PORT0_PAD_SGMII_RXCLK_FALLING_EDGE;
if (priv->sgmii_tx_clk_falling_edge) if (priv->ports_config.sgmii_tx_clk_falling_edge)
val |= QCA8K_PORT0_PAD_SGMII_TXCLK_FALLING_EDGE; val |= QCA8K_PORT0_PAD_SGMII_TXCLK_FALLING_EDGE;
if (val) if (val)
......
...@@ -270,15 +270,19 @@ enum { ...@@ -270,15 +270,19 @@ enum {
QCA8K_CPU_PORT6, QCA8K_CPU_PORT6,
}; };
struct qca8k_priv { struct qca8k_ports_config {
u8 switch_id;
u8 switch_revision;
bool sgmii_rx_clk_falling_edge; bool sgmii_rx_clk_falling_edge;
bool sgmii_tx_clk_falling_edge; bool sgmii_tx_clk_falling_edge;
bool sgmii_enable_pll; bool sgmii_enable_pll;
u8 rgmii_rx_delay[QCA8K_NUM_CPU_PORTS]; /* 0: CPU port0, 1: CPU port6 */ u8 rgmii_rx_delay[QCA8K_NUM_CPU_PORTS]; /* 0: CPU port0, 1: CPU port6 */
u8 rgmii_tx_delay[QCA8K_NUM_CPU_PORTS]; /* 0: CPU port0, 1: CPU port6 */ u8 rgmii_tx_delay[QCA8K_NUM_CPU_PORTS]; /* 0: CPU port0, 1: CPU port6 */
};
struct qca8k_priv {
u8 switch_id;
u8 switch_revision;
bool legacy_phy_port_mapping; bool legacy_phy_port_mapping;
struct qca8k_ports_config ports_config;
struct regmap *regmap; struct regmap *regmap;
struct mii_bus *bus; struct mii_bus *bus;
struct ar8xxx_port_status port_sts[QCA8K_NUM_PORTS]; struct ar8xxx_port_status port_sts[QCA8K_NUM_PORTS];
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册