diff options
| author | jsing <> | 2023-03-11 14:13:11 +0000 |
|---|---|---|
| committer | jsing <> | 2023-03-11 14:13:11 +0000 |
| commit | 0011bd4b5ca21dd631b72942920a62fa4a90fa88 (patch) | |
| tree | 0e761bee36c1a19143b0930f375dcd4bbe41820a /src | |
| parent | 7cfbad9af6db4ef1d10fba9d2f470cc280d8e37e (diff) | |
| download | openbsd-0011bd4b5ca21dd631b72942920a62fa4a90fa88.tar.gz openbsd-0011bd4b5ca21dd631b72942920a62fa4a90fa88.tar.bz2 openbsd-0011bd4b5ca21dd631b72942920a62fa4a90fa88.zip | |
Correct sign handling in BN_add_word().
A sign handling bug was introduced to BN_add_word() in bn_word.c r1.18.
When handling addition to a negative bignum, the BN_sub_word() call can
result in the sign being flipped, which we need to account for. Use the
same code in BN_sub_word() - while not technically needed here it keeps
the code consistent.
Issue discovered by tb@
ok tb@
Diffstat (limited to 'src')
| -rw-r--r-- | src/lib/libcrypto/bn/bn_word.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/lib/libcrypto/bn/bn_word.c b/src/lib/libcrypto/bn/bn_word.c index a44221c35f..c900f9ee2e 100644 --- a/src/lib/libcrypto/bn/bn_word.c +++ b/src/lib/libcrypto/bn/bn_word.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: bn_word.c,v 1.18 2023/02/13 04:25:37 jsing Exp $ */ | 1 | /* $OpenBSD: bn_word.c,v 1.19 2023/03/11 14:13:11 jsing 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 | * |
| @@ -152,7 +152,7 @@ BN_add_word(BIGNUM *a, BN_ULONG w) | |||
| 152 | if (a->neg) { | 152 | if (a->neg) { |
| 153 | a->neg = 0; | 153 | a->neg = 0; |
| 154 | i = BN_sub_word(a, w); | 154 | i = BN_sub_word(a, w); |
| 155 | BN_set_negative(a, 1); | 155 | BN_set_negative(a, !a->neg); |
| 156 | return (i); | 156 | return (i); |
| 157 | } | 157 | } |
| 158 | for (i = 0; w != 0 && i < a->top; i++) { | 158 | for (i = 0; w != 0 && i < a->top; i++) { |
| @@ -189,7 +189,7 @@ BN_sub_word(BIGNUM *a, BN_ULONG w) | |||
| 189 | if (a->neg) { | 189 | if (a->neg) { |
| 190 | a->neg = 0; | 190 | a->neg = 0; |
| 191 | i = BN_add_word(a, w); | 191 | i = BN_add_word(a, w); |
| 192 | BN_set_negative(a, 1); | 192 | BN_set_negative(a, !a->neg); |
| 193 | return (i); | 193 | return (i); |
| 194 | } | 194 | } |
| 195 | 195 | ||
