diff options
author | Herbert Xu <herbert@gondor.apana.org.au> | 2020-05-30 00:23:49 +1000 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2020-08-21 13:05:30 +0200 |
commit | 60259e04cf61df7c7696e7e9e3855488faf6638c (patch) | |
tree | d636f803c42aa8ad11aee57d266f868745aab08a /crypto/algif_skcipher.c | |
parent | 0f6c859f12a81750654641faf064a9faa8cf58ac (diff) | |
download | linux-crypto-60259e04cf61df7c7696e7e9e3855488faf6638c.tar.gz linux-crypto-60259e04cf61df7c7696e7e9e3855488faf6638c.zip |
crypto: algif_aead - Only wake up when ctx->more is zero
[ Upstream commit a52eb0489f96f7318fce6b1afe1cabd46c750746 ]
AEAD does not support partial requests so we must not wake up
while ctx->more is set. In order to distinguish between the
case of no data sent yet and a zero-length request, a new init
flag has been added to ctx.
SKCIPHER has also been modified to ensure that at least a block
of data is available if there is more data to come.
Fixes: c1b1fa586429 ("crypto: af_alg - consolidation of...")
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'crypto/algif_skcipher.c')
-rw-r--r-- | crypto/algif_skcipher.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/crypto/algif_skcipher.c b/crypto/algif_skcipher.c index ec5567c8..a51ba22f 100644 --- a/crypto/algif_skcipher.c +++ b/crypto/algif_skcipher.c @@ -61,8 +61,8 @@ static int _skcipher_recvmsg(struct socket *sock, struct msghdr *msg, int err = 0; size_t len = 0; - if (!ctx->used) { - err = af_alg_wait_for_data(sk, flags); + if (!ctx->init || (ctx->more && ctx->used < bs)) { + err = af_alg_wait_for_data(sk, flags, bs); if (err) return err; } |