Skip to content

Commit 2b8bbc6

Browse files
dhowellsgregkh
authored andcommitted
crypto: af_alg: Convert af_alg_sendpage() to use MSG_SPLICE_PAGES
[ Upstream commit fb800fa ] Convert af_alg_sendpage() to use sendmsg() with MSG_SPLICE_PAGES rather than directly splicing in the pages itself. This allows ->sendpage() to be replaced by something that can handle multiple multipage folios in a single transaction. Signed-off-by: David Howells <dhowells@redhat.com> cc: Herbert Xu <herbert@gondor.apana.org.au> cc: "David S. Miller" <davem@davemloft.net> cc: Eric Dumazet <edumazet@google.com> cc: Jakub Kicinski <kuba@kernel.org> cc: Paolo Abeni <pabeni@redhat.com> cc: Jens Axboe <axboe@kernel.dk> cc: Matthew Wilcox <willy@infradead.org> cc: linux-crypto@vger.kernel.org cc: netdev@vger.kernel.org Acked-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: Paolo Abeni <pabeni@redhat.com> Signed-off-by: Sasha Levin <sashal@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent 01d1ba1 commit 2b8bbc6

File tree

1 file changed

+8
-44
lines changed

1 file changed

+8
-44
lines changed

crypto/af_alg.c

Lines changed: 8 additions & 44 deletions
Original file line numberDiff line numberDiff line change
@@ -993,53 +993,17 @@ EXPORT_SYMBOL_GPL(af_alg_sendmsg);
993993
ssize_t af_alg_sendpage(struct socket *sock, struct page *page,
994994
int offset, size_t size, int flags)
995995
{
996-
struct sock *sk = sock->sk;
997-
struct alg_sock *ask = alg_sk(sk);
998-
struct af_alg_ctx *ctx = ask->private;
999-
struct af_alg_tsgl *sgl;
1000-
int err = -EINVAL;
996+
struct bio_vec bvec;
997+
struct msghdr msg = {
998+
.msg_flags = flags | MSG_SPLICE_PAGES,
999+
};
10011000

10021001
if (flags & MSG_SENDPAGE_NOTLAST)
1003-
flags |= MSG_MORE;
1004-
1005-
lock_sock(sk);
1006-
if (!ctx->more && ctx->used)
1007-
goto unlock;
1008-
1009-
if (!size)
1010-
goto done;
1011-
1012-
if (!af_alg_writable(sk)) {
1013-
err = af_alg_wait_for_wmem(sk, flags);
1014-
if (err)
1015-
goto unlock;
1016-
}
1017-
1018-
err = af_alg_alloc_tsgl(sk);
1019-
if (err)
1020-
goto unlock;
1021-
1022-
ctx->merge = 0;
1023-
sgl = list_entry(ctx->tsgl_list.prev, struct af_alg_tsgl, list);
1024-
1025-
if (sgl->cur)
1026-
sg_unmark_end(sgl->sg + sgl->cur - 1);
1027-
1028-
sg_mark_end(sgl->sg + sgl->cur);
1029-
1030-
get_page(page);
1031-
sg_set_page(sgl->sg + sgl->cur, page, size, offset);
1032-
sgl->cur++;
1033-
ctx->used += size;
1034-
1035-
done:
1036-
ctx->more = flags & MSG_MORE;
1037-
1038-
unlock:
1039-
af_alg_data_wakeup(sk);
1040-
release_sock(sk);
1002+
msg.msg_flags |= MSG_MORE;
10411003

1042-
return err ?: size;
1004+
bvec_set_page(&bvec, page, size, offset);
1005+
iov_iter_bvec(&msg.msg_iter, ITER_SOURCE, &bvec, 1, size);
1006+
return sock_sendmsg(sock, &msg);
10431007
}
10441008
EXPORT_SYMBOL_GPL(af_alg_sendpage);
10451009

0 commit comments

Comments
 (0)