r8152: fix flow control issue of RTL8156A
authorHayes Wang <hayeswang@realtek.com>
Fri, 28 Apr 2023 08:53:29 +0000 (16:53 +0800)
committerDavid S. Miller <davem@davemloft.net>
Mon, 1 May 2023 06:32:04 +0000 (07:32 +0100)
commit8ceda6d5a1e5402fd852e6cc59a286ce3dc545ee
tree0ffdae381e2dd5348802b6389321123f1bcb8a9e
parent526f28bd0fbdc699cda31426928802650c1528e5
r8152: fix flow control issue of RTL8156A

The feature of flow control becomes abnormal, if the device sends a
pause frame and the tx/rx is disabled before sending a release frame. It
causes the lost of packets.

Set PLA_RX_FIFO_FULL and PLA_RX_FIFO_EMPTY to zeros before disabling the
tx/rx. And, toggle FC_PATCH_TASK before enabling tx/rx to reset the flow
control patch and timer. Then, the hardware could clear the state and
the flow control becomes normal after enabling tx/rx.

Besides, remove inline for fc_pause_on_auto() and fc_pause_off_auto().

Fixes: 195aae321c82 ("r8152: support new chips")
Signed-off-by: Hayes Wang <hayeswang@realtek.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/usb/r8152.c