Commit 048c4543 authored by Eric Dumazet's avatar Eric Dumazet Committed by Willy Tarreau

tcp: fix tcp_md5_hash_skb_data()

[ Upstream commit 54d27fcb ]

TCP md5 communications fail [1] for some devices, because sg/crypto code
assume page offsets are below PAGE_SIZE.

This was discovered using mlx4 driver [2], but I suspect loopback
might trigger the same bug now we use order-3 pages in tcp_sendmsg()

[1] Failure is giving following messages.

huh, entered softirq 3 NET_RX ffffffff806ad230 preempt_count 00000100,
exited with 00000101?

[2] mlx4 driver uses order-2 pages to allocate RX frags
Reported-by: default avatarMatt Schnall <mischnal@google.com>
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Cc: Bernhard Beck <bbeck@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarWilly Tarreau <w@1wt.eu>
parent dc070123
...@@ -2826,7 +2826,11 @@ int tcp_md5_hash_skb_data(struct tcp_md5sig_pool *hp, ...@@ -2826,7 +2826,11 @@ int tcp_md5_hash_skb_data(struct tcp_md5sig_pool *hp,
for (i = 0; i < shi->nr_frags; ++i) { for (i = 0; i < shi->nr_frags; ++i) {
const struct skb_frag_struct *f = &shi->frags[i]; const struct skb_frag_struct *f = &shi->frags[i];
sg_set_page(&sg, f->page, f->size, f->page_offset); unsigned int offset = f->page_offset;
struct page *page = f->page + (offset >> PAGE_SHIFT);
sg_set_page(&sg, page, f->size,
offset_in_page(offset));
if (crypto_hash_update(desc, &sg, f->size)) if (crypto_hash_update(desc, &sg, f->size))
return 1; return 1;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment