提交 727fb249 编写于 作者: G Grant Grundler 提交者: Zheng Zengkai

net: atlantic: reduce scope of is_rsc_complete

stable inclusion
from stable-v5.10.118
commit 9bee8b4275ece3472b2492892708ac6c1efe4fbf
category: bugfix
bugzilla: https://gitee.com/openeuler/kernel/issues/I5L686

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?id=9bee8b4275ece3472b2492892708ac6c1efe4fbf

--------------------------------

[ Upstream commit 79784d77 ]

Don't defer handling the err case outside the loop. That's pointless.

And since is_rsc_complete is only used inside this loop, declare
it inside the loop to reduce it's scope.
Signed-off-by: NGrant Grundler <grundler@chromium.org>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
Signed-off-by: NSasha Levin <sashal@kernel.org>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
Acked-by: NXie XiuQi <xiexiuqi@huawei.com>
上级 17c852b9
...@@ -345,7 +345,6 @@ int aq_ring_rx_clean(struct aq_ring_s *self, ...@@ -345,7 +345,6 @@ int aq_ring_rx_clean(struct aq_ring_s *self,
int budget) int budget)
{ {
struct net_device *ndev = aq_nic_get_ndev(self->aq_nic); struct net_device *ndev = aq_nic_get_ndev(self->aq_nic);
bool is_rsc_completed = true;
int err = 0; int err = 0;
for (; (self->sw_head != self->hw_head) && budget; for (; (self->sw_head != self->hw_head) && budget;
...@@ -365,6 +364,8 @@ int aq_ring_rx_clean(struct aq_ring_s *self, ...@@ -365,6 +364,8 @@ int aq_ring_rx_clean(struct aq_ring_s *self,
if (!buff->is_eop) { if (!buff->is_eop) {
buff_ = buff; buff_ = buff;
do { do {
bool is_rsc_completed = true;
if (buff_->next >= self->size) { if (buff_->next >= self->size) {
err = -EIO; err = -EIO;
goto err_exit; goto err_exit;
...@@ -376,18 +377,16 @@ int aq_ring_rx_clean(struct aq_ring_s *self, ...@@ -376,18 +377,16 @@ int aq_ring_rx_clean(struct aq_ring_s *self,
next_, next_,
self->hw_head); self->hw_head);
if (unlikely(!is_rsc_completed)) if (unlikely(!is_rsc_completed)) {
break; err = 0;
goto err_exit;
}
buff->is_error |= buff_->is_error; buff->is_error |= buff_->is_error;
buff->is_cso_err |= buff_->is_cso_err; buff->is_cso_err |= buff_->is_cso_err;
} while (!buff_->is_eop); } while (!buff_->is_eop);
if (!is_rsc_completed) {
err = 0;
goto err_exit;
}
if (buff->is_error || if (buff->is_error ||
(buff->is_lro && buff->is_cso_err)) { (buff->is_lro && buff->is_cso_err)) {
buff_ = buff; buff_ = buff;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册