OSDN Git Service

net: ipa: fix a bug in ipa_endpoint_stop()
authorAlex Elder <elder@linaro.org>
Mon, 4 May 2020 23:53:41 +0000 (18:53 -0500)
committerDavid S. Miller <davem@davemloft.net>
Thu, 7 May 2020 00:41:11 +0000 (17:41 -0700)
commit97e4692dda26d047899a3f1f3f57c3d861b6b9c9
tree67f005ecd986b25a0bbd6fd0f501c18c25df19d5
parent6a5dc76ac4f5d5050dd50298882b933193ece79d
net: ipa: fix a bug in ipa_endpoint_stop()

In ipa_endpoint_stop(), for TX endpoints we set the number of retries
to 0.  When we break out of the loop, retries being 0 means we return
EIO rather than the value of ret (which should be 0).

Fix this by using a non-zero retry count for both RX and TX
channels, and just break out of the loop after calling
gsi_channel_stop() for TX channels.  This way only RX channels
will retry, and the retry count will be non-zero at the end
for TX channels (so the proper value gets returned).

Signed-off-by: Alex Elder <elder@linaro.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
(cherry picked from commit 713b6ebb4c376b3fb65fdceb3b59e401c93248f9)
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ipa/ipa_endpoint.c