From: Herbert Xu Date: Fri, 6 Oct 2023 01:41:55 +0000 (+0800) Subject: dm crypt: Fix reqsize in crypt_iv_eboiv_gen X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=152d0bcdf1efcb54a4fa20f694e9c7bbb6d06cbf;p=linux.git dm crypt: Fix reqsize in crypt_iv_eboiv_gen A skcipher_request object is made up of struct skcipher_request followed by a variable-sized trailer. The allocation of the skcipher_request and IV in crypt_iv_eboiv_gen is missing the memory for struct skcipher_request. Fix it by adding it to reqsize. Fixes: e3023094dffb ("dm crypt: Avoid using MAX_CIPHER_BLOCKSIZE") Cc: #6.5+ Reported-by: Tatu Heikkilä Reviewed-by: Mike Snitzer Signed-off-by: Herbert Xu --- diff --git a/drivers/md/dm-crypt.c b/drivers/md/dm-crypt.c index f2662c21a6dfe..5315fd261c23b 100644 --- a/drivers/md/dm-crypt.c +++ b/drivers/md/dm-crypt.c @@ -753,7 +753,8 @@ static int crypt_iv_eboiv_gen(struct crypt_config *cc, u8 *iv, int err; u8 *buf; - reqsize = ALIGN(crypto_skcipher_reqsize(tfm), __alignof__(__le64)); + reqsize = sizeof(*req) + crypto_skcipher_reqsize(tfm); + reqsize = ALIGN(reqsize, __alignof__(__le64)); req = kmalloc(reqsize + cc->iv_size, GFP_NOIO); if (!req)