Re: [PATCH] net: fix rc7's __skb_datagram_iter()

From: Sagi Grimberg
Date: Mon Jul 08 2024 - 02:22:12 EST




On 08/07/2024 6:00, Hugh Dickins wrote:
X would not start in my old 32-bit partition (and the "n"-handling looks
just as wrong on 64-bit, but for whatever reason did not show up there):
"n" must be accumulated over all pages before it's added to "offset" and
compared with "copy", immediately after the skb_frag_foreach_page() loop.

That is indeed strange. I see the issue. It didn't happen in my local testing either.


Fixes: d2d30a376d9c ("net: allow skb_datagram_iter to be called from any context")
Signed-off-by: Hugh Dickins <hughd@xxxxxxxxxx>
---
net/core/datagram.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/net/core/datagram.c b/net/core/datagram.c
index e9ba4c7b449d..ea69d01156e6 100644
--- a/net/core/datagram.c
+++ b/net/core/datagram.c
@@ -420,6 +420,7 @@ static int __skb_datagram_iter(const struct sk_buff *skb, int offset,
struct page *p;
u8 *vaddr;
+ n = 0;

I think its better to reset n right before the skb_frag_foreach_page() iteration.

Thanks Hugh for addressing this!