Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 7a8c4dd9 authored by Dave Watson's avatar Dave Watson Committed by David S. Miller
Browse files

tls: Correct length of scatterlist in tls_sw_sendpage



The scatterlist is reused by both sendmsg and sendfile.
If a sendmsg of smaller number of pages is followed by a sendfile
of larger number of pages, the scatterlist may be too short, resulting
in a crash in gcm_encrypt.

Add sg_unmark_end to make the list the correct length.

tls_sw_sendmsg already calls sg_unmark_end correctly when it allocates
memory in alloc_sg, or in zerocopy_from_iter.

Signed-off-by: default avatarDave Watson <davejwatson@fb.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 52acf064
Loading
Loading
Loading
Loading
+2 −0
Original line number Original line Diff line number Diff line
@@ -577,6 +577,8 @@ int tls_sw_sendpage(struct sock *sk, struct page *page,
		get_page(page);
		get_page(page);
		sg = ctx->sg_plaintext_data + ctx->sg_plaintext_num_elem;
		sg = ctx->sg_plaintext_data + ctx->sg_plaintext_num_elem;
		sg_set_page(sg, page, copy, offset);
		sg_set_page(sg, page, copy, offset);
		sg_unmark_end(sg);

		ctx->sg_plaintext_num_elem++;
		ctx->sg_plaintext_num_elem++;


		sk_mem_charge(sk, copy);
		sk_mem_charge(sk, copy);