提交 850bfa3b 编写于 作者: Y Yisen.Zhuang\(Zhuangyuzeng\) 提交者: David S. Miller

net: hns: add attribute port-rst-offset for dsaf port node

The reset offset for each port in a dsaf is different. The current code is
not so readability. This patch adds configuration named port-rst-offset to
make the code simple and more readability. If this attribute doesn't exist,
default value of this attribute is equal to its port index.
Signed-off-by: NYisen Zhuang <yisen.zhuang@huawei.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 31d4446d
...@@ -664,6 +664,7 @@ static int hns_mac_get_info(struct hns_mac_cb *mac_cb) ...@@ -664,6 +664,7 @@ static int hns_mac_get_info(struct hns_mac_cb *mac_cb)
mac_cb->max_frm = MAC_DEFAULT_MTU; mac_cb->max_frm = MAC_DEFAULT_MTU;
mac_cb->tx_pause_frm_time = MAC_DEFAULT_PAUSE_TIME; mac_cb->tx_pause_frm_time = MAC_DEFAULT_PAUSE_TIME;
mac_cb->port_rst_off = mac_cb->mac_id;
/* if the dsaf node doesn't contain a port subnode, get phy-handle /* if the dsaf node doesn't contain a port subnode, get phy-handle
* from dsaf node * from dsaf node
...@@ -693,6 +694,15 @@ static int hns_mac_get_info(struct hns_mac_cb *mac_cb) ...@@ -693,6 +694,15 @@ static int hns_mac_get_info(struct hns_mac_cb *mac_cb)
} }
mac_cb->serdes_ctrl = syscon; mac_cb->serdes_ctrl = syscon;
ret = fwnode_property_read_u32(mac_cb->fw_port,
"port-rst-offset",
&mac_cb->port_rst_off);
if (ret) {
dev_dbg(mac_cb->dev,
"mac%d port-rst-offset not found, use default value.\n",
mac_cb->mac_id);
}
syscon = syscon_node_to_regmap( syscon = syscon_node_to_regmap(
of_parse_phandle(to_of_node(mac_cb->fw_port), of_parse_phandle(to_of_node(mac_cb->fw_port),
"cpld-syscon", 0)); "cpld-syscon", 0));
......
...@@ -318,6 +318,7 @@ struct hns_mac_cb { ...@@ -318,6 +318,7 @@ struct hns_mac_cb {
struct regmap *serdes_ctrl; struct regmap *serdes_ctrl;
struct regmap *cpld_ctrl; struct regmap *cpld_ctrl;
u32 cpld_ctrl_reg; u32 cpld_ctrl_reg;
u32 port_rst_off;
struct mac_entry_idx addr_entry_idx[DSAF_MAX_VM_NUM]; struct mac_entry_idx addr_entry_idx[DSAF_MAX_VM_NUM];
u8 sfp_prsnt; u8 sfp_prsnt;
u8 cpld_led_value; u8 cpld_led_value;
......
...@@ -135,11 +135,7 @@ void hns_dsaf_xge_srst_by_port(struct dsaf_device *dsaf_dev, u32 port, u32 val) ...@@ -135,11 +135,7 @@ void hns_dsaf_xge_srst_by_port(struct dsaf_device *dsaf_dev, u32 port, u32 val)
return; return;
reg_val |= RESET_REQ_OR_DREQ; reg_val |= RESET_REQ_OR_DREQ;
reg_val |= 0x2082082 << dsaf_dev->mac_cb[port]->port_rst_off;
if (!HNS_DSAF_IS_DEBUG(dsaf_dev))
reg_val |= 0x2082082 << port;
else
reg_val |= 0x2082082 << (dsaf_dev->reset_offset + 6);
if (val == 0) if (val == 0)
reg_addr = DSAF_SUB_SC_XGE_RESET_REQ_REG; reg_addr = DSAF_SUB_SC_XGE_RESET_REQ_REG;
...@@ -158,11 +154,8 @@ void hns_dsaf_xge_core_srst_by_port(struct dsaf_device *dsaf_dev, ...@@ -158,11 +154,8 @@ void hns_dsaf_xge_core_srst_by_port(struct dsaf_device *dsaf_dev,
if (port >= DSAF_XGE_NUM) if (port >= DSAF_XGE_NUM)
return; return;
if (!HNS_DSAF_IS_DEBUG(dsaf_dev)) reg_val |= XGMAC_TRX_CORE_SRST_M
reg_val |= XGMAC_TRX_CORE_SRST_M << port; << dsaf_dev->mac_cb[port]->port_rst_off;
else
reg_val |= XGMAC_TRX_CORE_SRST_M <<
(dsaf_dev->reset_offset + 6);
if (val == 0) if (val == 0)
reg_addr = DSAF_SUB_SC_XGE_RESET_REQ_REG; reg_addr = DSAF_SUB_SC_XGE_RESET_REQ_REG;
...@@ -176,17 +169,19 @@ void hns_dsaf_ge_srst_by_port(struct dsaf_device *dsaf_dev, u32 port, u32 val) ...@@ -176,17 +169,19 @@ void hns_dsaf_ge_srst_by_port(struct dsaf_device *dsaf_dev, u32 port, u32 val)
{ {
u32 reg_val_1; u32 reg_val_1;
u32 reg_val_2; u32 reg_val_2;
u32 port_rst_off;
if (port >= DSAF_GE_NUM) if (port >= DSAF_GE_NUM)
return; return;
if (!HNS_DSAF_IS_DEBUG(dsaf_dev)) { if (!HNS_DSAF_IS_DEBUG(dsaf_dev)) {
reg_val_1 = 0x1 << port; reg_val_1 = 0x1 << port;
port_rst_off = dsaf_dev->mac_cb[port]->port_rst_off;
/* there is difference between V1 and V2 in register.*/ /* there is difference between V1 and V2 in register.*/
if (AE_IS_VER1(dsaf_dev->dsaf_ver)) if (AE_IS_VER1(dsaf_dev->dsaf_ver))
reg_val_2 = 0x1041041 << port; reg_val_2 = 0x1041041 << port_rst_off;
else else
reg_val_2 = 0x2082082 << port; reg_val_2 = 0x2082082 << port_rst_off;
if (val == 0) { if (val == 0) {
dsaf_write_sub(dsaf_dev, DSAF_SUB_SC_GE_RESET_REQ1_REG, dsaf_write_sub(dsaf_dev, DSAF_SUB_SC_GE_RESET_REQ1_REG,
...@@ -226,11 +221,7 @@ void hns_ppe_srst_by_port(struct dsaf_device *dsaf_dev, u32 port, u32 val) ...@@ -226,11 +221,7 @@ void hns_ppe_srst_by_port(struct dsaf_device *dsaf_dev, u32 port, u32 val)
u32 reg_val = 0; u32 reg_val = 0;
u32 reg_addr; u32 reg_addr;
if (!HNS_DSAF_IS_DEBUG(dsaf_dev)) reg_val |= RESET_REQ_OR_DREQ << dsaf_dev->mac_cb[port]->port_rst_off;
reg_val |= RESET_REQ_OR_DREQ << port;
else
reg_val |= RESET_REQ_OR_DREQ <<
(dsaf_dev->reset_offset + 6);
if (val == 0) if (val == 0)
reg_addr = DSAF_SUB_SC_PPE_RESET_REQ_REG; reg_addr = DSAF_SUB_SC_PPE_RESET_REQ_REG;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册