mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-06 18:09:56 +00:00
net: stmmac: dwmac4: fix flow control issue
[ Upstream commitee326fd01e] Current dwmac4_flow_ctrl will not clear GMAC_RX_FLOW_CTRL_RFE/GMAC_RX_FLOW_CTRL_RFE bits, so MAC hw will keep flow control on although expecting flow control off by ethtool. Add codes to fix it. Fixes:477286b53f("stmmac: add GMAC4 core support") Signed-off-by: Biao Huang <biao.huang@mediatek.com> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
f5d06ac24d
commit
037f641e40
@@ -474,8 +474,9 @@ static void dwmac4_flow_ctrl(struct mac_device_info *hw, unsigned int duplex,
|
|||||||
if (fc & FLOW_RX) {
|
if (fc & FLOW_RX) {
|
||||||
pr_debug("\tReceive Flow-Control ON\n");
|
pr_debug("\tReceive Flow-Control ON\n");
|
||||||
flow |= GMAC_RX_FLOW_CTRL_RFE;
|
flow |= GMAC_RX_FLOW_CTRL_RFE;
|
||||||
writel(flow, ioaddr + GMAC_RX_FLOW_CTRL);
|
|
||||||
}
|
}
|
||||||
|
writel(flow, ioaddr + GMAC_RX_FLOW_CTRL);
|
||||||
|
|
||||||
if (fc & FLOW_TX) {
|
if (fc & FLOW_TX) {
|
||||||
pr_debug("\tTransmit Flow-Control ON\n");
|
pr_debug("\tTransmit Flow-Control ON\n");
|
||||||
|
|
||||||
@@ -483,7 +484,7 @@ static void dwmac4_flow_ctrl(struct mac_device_info *hw, unsigned int duplex,
|
|||||||
pr_debug("\tduplex mode: PAUSE %d\n", pause_time);
|
pr_debug("\tduplex mode: PAUSE %d\n", pause_time);
|
||||||
|
|
||||||
for (queue = 0; queue < tx_cnt; queue++) {
|
for (queue = 0; queue < tx_cnt; queue++) {
|
||||||
flow |= GMAC_TX_FLOW_CTRL_TFE;
|
flow = GMAC_TX_FLOW_CTRL_TFE;
|
||||||
|
|
||||||
if (duplex)
|
if (duplex)
|
||||||
flow |=
|
flow |=
|
||||||
@@ -491,6 +492,9 @@ static void dwmac4_flow_ctrl(struct mac_device_info *hw, unsigned int duplex,
|
|||||||
|
|
||||||
writel(flow, ioaddr + GMAC_QX_TX_FLOW_CTRL(queue));
|
writel(flow, ioaddr + GMAC_QX_TX_FLOW_CTRL(queue));
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
for (queue = 0; queue < tx_cnt; queue++)
|
||||||
|
writel(0, ioaddr + GMAC_QX_TX_FLOW_CTRL(queue));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user