mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-17 18:56:24 +00:00
ima: Don't ignore errors from crypto_shash_update()
commit 60386b854008adc951c470067f90a2d85b5d520f upstream. Errors returned by crypto_shash_update() are not checked in ima_calc_boot_aggregate_tfm() and thus can be overwritten at the next iteration of the loop. This patch adds a check after calling crypto_shash_update() and returns immediately if the result is not zero. Cc: stable@vger.kernel.org Fixes: 3323eec921efd ("integrity: IMA as an integrity service provider") Signed-off-by: Roberto Sassu <roberto.sassu@huawei.com> Signed-off-by: Mimi Zohar <zohar@linux.ibm.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
47925a5305
commit
d0f7036b12
@ -699,6 +699,8 @@ static int __init ima_calc_boot_aggregate_tfm(char *digest,
|
|||||||
ima_pcrread(i, pcr_i);
|
ima_pcrread(i, pcr_i);
|
||||||
/* now accumulate with current aggregate */
|
/* now accumulate with current aggregate */
|
||||||
rc = crypto_shash_update(shash, pcr_i, TPM_DIGEST_SIZE);
|
rc = crypto_shash_update(shash, pcr_i, TPM_DIGEST_SIZE);
|
||||||
|
if (rc != 0)
|
||||||
|
return rc;
|
||||||
}
|
}
|
||||||
if (!rc)
|
if (!rc)
|
||||||
crypto_shash_final(shash, digest);
|
crypto_shash_final(shash, digest);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user