diff options
author | Paolo Bonzini | 2016-05-20 11:09:54 +0200 |
---|---|---|
committer | Daniel P. Berrange | 2016-06-13 13:41:17 +0200 |
commit | b35c1f3361ebf6ec9ea5022903af4b559bff6063 (patch) | |
tree | 74a8cc5b6b93c0d682876e98ff8240f7c3d34ddc | |
parent | crypto: remove temp files on completion of secrets test (diff) | |
download | qemu-b35c1f3361ebf6ec9ea5022903af4b559bff6063.tar.gz qemu-b35c1f3361ebf6ec9ea5022903af4b559bff6063.tar.xz qemu-b35c1f3361ebf6ec9ea5022903af4b559bff6063.zip |
crypto: assert that qcrypto_hash_digest_len is in range
Otherwise unintended results could happen. For example,
Coverity reports a division by zero in qcrypto_afsplit_hash.
While this cannot really happen, it shows that the contract
of qcrypto_hash_digest_len can be improved.
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
-rw-r--r-- | crypto/hash.c | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/crypto/hash.c b/crypto/hash.c index b90af3495a..2907bffd2e 100644 --- a/crypto/hash.c +++ b/crypto/hash.c @@ -36,9 +36,7 @@ static size_t qcrypto_hash_alg_size[QCRYPTO_HASH_ALG__MAX] = { size_t qcrypto_hash_digest_len(QCryptoHashAlgorithm alg) { - if (alg >= G_N_ELEMENTS(qcrypto_hash_alg_size)) { - return 0; - } + assert(alg < G_N_ELEMENTS(qcrypto_hash_alg_size)); return qcrypto_hash_alg_size[alg]; } |