summaryrefslogtreecommitdiffstats
path: root/crypto/bn
diff options
context:
space:
mode:
authorGeoff Thorpe <geoff@openssl.org>2003-10-29 20:47:49 +0000
committerGeoff Thorpe <geoff@openssl.org>2003-10-29 20:47:49 +0000
commit31166ec8f33f1d1af25901be4411d47ef15ff340 (patch)
tree736dc02aad43cb6ec9740c40419af02a3534307a /crypto/bn
parent27545970134d703ed96027aac9b67eced124eec3 (diff)
Some provisional bignum debugging has begun to detect inconsistent BIGNUM
structures being passed in to or out of API functions, and this corrects a couple of cases found so far. Also, lop off a couple of bytes of white-space.
Diffstat (limited to 'crypto/bn')
-rw-r--r--crypto/bn/bn_lib.c1
-rw-r--r--crypto/bn/bn_nist.c3
-rw-r--r--crypto/bn/bn_recp.c2
3 files changed, 4 insertions, 2 deletions
diff --git a/crypto/bn/bn_lib.c b/crypto/bn/bn_lib.c
index 8207bce230..783881d3a6 100644
--- a/crypto/bn/bn_lib.c
+++ b/crypto/bn/bn_lib.c
@@ -462,7 +462,6 @@ BIGNUM *bn_expand2(BIGNUM *b, int words)
A[0]=0;
assert(A == &(b->d[b->dmax]));
}
-
return b;
}
diff --git a/crypto/bn/bn_nist.c b/crypto/bn/bn_nist.c
index 19bd540725..2ababfbed1 100644
--- a/crypto/bn/bn_nist.c
+++ b/crypto/bn/bn_nist.c
@@ -823,6 +823,7 @@ int BN_nist_mod_521(BIGNUM *r, const BIGNUM *a, const BIGNUM *field,
if (tmp->top == BN_NIST_521_TOP)
tmp->d[BN_NIST_521_TOP-1] &= BN_NIST_521_TOP_MASK;
+ bn_fix_top(tmp);
if (!BN_uadd(r, tmp, r))
return 0;
top = r->top;
@@ -838,6 +839,6 @@ int BN_nist_mod_521(BIGNUM *r, const BIGNUM *a, const BIGNUM *field,
ret = 1;
err:
BN_CTX_end(ctx);
-
+
return ret;
}
diff --git a/crypto/bn/bn_recp.c b/crypto/bn/bn_recp.c
index ef5fdd4708..22cbcfc49b 100644
--- a/crypto/bn/bn_recp.c
+++ b/crypto/bn/bn_recp.c
@@ -203,6 +203,8 @@ int BN_div_recp(BIGNUM *dv, BIGNUM *rem, const BIGNUM *m,
ret=1;
err:
BN_CTX_end(ctx);
+ if(dv) bn_fix_top(dv);
+ if(rem) bn_fix_top(rem);
return(ret);
}