diff options
| author | deraadt <> | 2017-05-02 03:59:45 +0000 |
|---|---|---|
| committer | deraadt <> | 2017-05-02 03:59:45 +0000 |
| commit | 5904cc0e04409fde39a97e6580535da34eeb4291 (patch) | |
| tree | bb9d050c5c2984047e6475e087694d6764f24157 /src/lib/libcrypto/bn/bn_rand.c | |
| parent | b3449a25972849293bca9a6fc6581f37f6e0faf6 (diff) | |
| download | openbsd-5904cc0e04409fde39a97e6580535da34eeb4291.tar.gz openbsd-5904cc0e04409fde39a97e6580535da34eeb4291.tar.bz2 openbsd-5904cc0e04409fde39a97e6580535da34eeb4291.zip | |
use freezero() instead of memset/explicit_bzero + free. Substantially
reduces conditional logic (-218, +82).
MOD_EXP_CTIME_MIN_CACHE_LINE_WIDTH cache alignment calculation bn/bn_exp.c
wasn'tt quite right. Two other tricky bits with ASN1_STRING_FLAG_NDEF and
BN_FLG_STATIC_DATA where the condition cannot be collapsed completely.
Passes regress. ok beck
Diffstat (limited to 'src/lib/libcrypto/bn/bn_rand.c')
| -rw-r--r-- | src/lib/libcrypto/bn/bn_rand.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/src/lib/libcrypto/bn/bn_rand.c b/src/lib/libcrypto/bn/bn_rand.c index 812fa6a575..8625757140 100644 --- a/src/lib/libcrypto/bn/bn_rand.c +++ b/src/lib/libcrypto/bn/bn_rand.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: bn_rand.c,v 1.19 2017/01/29 17:49:22 beck Exp $ */ | 1 | /* $OpenBSD: bn_rand.c,v 1.20 2017/05/02 03:59:44 deraadt Exp $ */ |
| 2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) | 2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) |
| 3 | * All rights reserved. | 3 | * All rights reserved. |
| 4 | * | 4 | * |
| @@ -186,10 +186,7 @@ bnrand(int pseudorand, BIGNUM *rnd, int bits, int top, int bottom) | |||
| 186 | ret = 1; | 186 | ret = 1; |
| 187 | 187 | ||
| 188 | err: | 188 | err: |
| 189 | if (buf != NULL) { | 189 | freezero(buf, bytes); |
| 190 | explicit_bzero(buf, bytes); | ||
| 191 | free(buf); | ||
| 192 | } | ||
| 193 | bn_check_top(rnd); | 190 | bn_check_top(rnd); |
| 194 | return (ret); | 191 | return (ret); |
| 195 | } | 192 | } |
