From: Andy Polyakov <appro@openssl.org>
Date: Wed, 25 Jul 2018 08:29:51 +0000 (+0200)
Subject: bn/bn_mod.c: harmonize BN_mod_add_quick with original implementation.
X-Git-Tag: OpenSSL_1_1_1-pre9~81
X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=70a579ae2f37437a1e02331eeaa84e1b68ba021e;p=openssl

bn/bn_mod.c: harmonize BN_mod_add_quick with original implementation.

New implementation failed to correctly reset r->neg flag. Spotted by
OSSFuzz.

Reviewed-by: Rich Salz <rsalz@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/6783)
---

diff --git a/crypto/bn/bn_mod.c b/crypto/bn/bn_mod.c
index 463d2d69a8..d8e2e12c1e 100644
--- a/crypto/bn/bn_mod.c
+++ b/crypto/bn/bn_mod.c
@@ -83,6 +83,7 @@ int bn_mod_add_fixed_top(BIGNUM *r, const BIGNUM *a, const BIGNUM *b,
         ((volatile BN_ULONG *)tp)[i] = 0;
     }
     r->top = mtop;
+    r->neg = 0;
 
     if (tp != storage)
         OPENSSL_free(tp);