summaryrefslogtreecommitdiffstats
path: root/crypto/des
diff options
context:
space:
mode:
authorTomas Mraz <tomas@openssl.org>2021-11-01 08:39:21 +0100
committerPauli <pauli@openssl.org>2021-11-03 09:31:16 +1000
commitc686efc43fe1327451b5a7f5638c9efc3085d784 (patch)
tree7dacdcae3c1900255cecd69daa7b12838063aa65 /crypto/des
parent47d82af0827ec46876e8cc859cd76b256d81c3c4 (diff)
DES_set_key(): return values as DES_set_key_checked() but always set
This avoids using accidentally uninitialized key schedule in applications that use DES_set_key() not expecting it to check the key which is the default on OpenSSL <= 1.1.1 Fixes #16859 Reviewed-by: Matt Caswell <matt@openssl.org> Reviewed-by: Paul Dale <pauli@openssl.org> (Merged from https://github.com/openssl/openssl/pull/16944) (cherry picked from commit 6450ea27ffdc22194f27e90796ce5538af2d81e2)
Diffstat (limited to 'crypto/des')
-rw-r--r--crypto/des/set_key.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/crypto/des/set_key.c b/crypto/des/set_key.c
index 9510dc2c6a..ce7fb901f0 100644
--- a/crypto/des/set_key.c
+++ b/crypto/des/set_key.c
@@ -279,9 +279,17 @@ static const DES_LONG des_skb[8][64] = {
}
};
+/* Return values as DES_set_key_checked() but always set the key */
int DES_set_key(const_DES_cblock *key, DES_key_schedule *schedule)
{
- return DES_set_key_checked(key, schedule);
+ int ret = 0;
+
+ if (!DES_check_key_parity(key))
+ ret = -1;
+ if (DES_is_weak_key(key))
+ ret = -2;
+ DES_set_key_unchecked(key, schedule);
+ return ret;
}
/*-