提交 bbe24045 编写于 作者: E Eric Biggers 提交者: James Morris

KEYS: DH: forbid using digest_null as the KDF hash

Requesting "digest_null" in the keyctl_kdf_params caused an infinite
loop in kdf_ctr() because the "null" hash has a digest size of 0.  Fix
it by rejecting hash algorithms with a digest size of 0.
Signed-off-by: NEric Biggers <ebiggers@google.com>
Signed-off-by: NDavid Howells <dhowells@redhat.com>
Acked-by: NStephan Mueller <smueller@chronox.de>
Signed-off-by: NJames Morris <james.l.morris@oracle.com>
上级 0620fddb
...@@ -89,6 +89,7 @@ static int kdf_alloc(struct kdf_sdesc **sdesc_ret, char *hashname) ...@@ -89,6 +89,7 @@ static int kdf_alloc(struct kdf_sdesc **sdesc_ret, char *hashname)
struct crypto_shash *tfm; struct crypto_shash *tfm;
struct kdf_sdesc *sdesc; struct kdf_sdesc *sdesc;
int size; int size;
int err;
/* allocate synchronous hash */ /* allocate synchronous hash */
tfm = crypto_alloc_shash(hashname, 0, 0); tfm = crypto_alloc_shash(hashname, 0, 0);
...@@ -97,16 +98,25 @@ static int kdf_alloc(struct kdf_sdesc **sdesc_ret, char *hashname) ...@@ -97,16 +98,25 @@ static int kdf_alloc(struct kdf_sdesc **sdesc_ret, char *hashname)
return PTR_ERR(tfm); return PTR_ERR(tfm);
} }
err = -EINVAL;
if (crypto_shash_digestsize(tfm) == 0)
goto out_free_tfm;
err = -ENOMEM;
size = sizeof(struct shash_desc) + crypto_shash_descsize(tfm); size = sizeof(struct shash_desc) + crypto_shash_descsize(tfm);
sdesc = kmalloc(size, GFP_KERNEL); sdesc = kmalloc(size, GFP_KERNEL);
if (!sdesc) if (!sdesc)
return -ENOMEM; goto out_free_tfm;
sdesc->shash.tfm = tfm; sdesc->shash.tfm = tfm;
sdesc->shash.flags = 0x0; sdesc->shash.flags = 0x0;
*sdesc_ret = sdesc; *sdesc_ret = sdesc;
return 0; return 0;
out_free_tfm:
crypto_free_shash(tfm);
return err;
} }
static void kdf_dealloc(struct kdf_sdesc *sdesc) static void kdf_dealloc(struct kdf_sdesc *sdesc)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册