This extends the debugging macros to use "pollution" during
bn_correct_top(), previously only bn_check_top() did this.
This commit is contained in:
parent
18f62d4b82
commit
f75abcefed
@ -617,15 +617,6 @@ BIGNUM *bn_dup_expand(const BIGNUM *a, int words);
|
|||||||
* defined. This not only improves external code, it provides more test
|
* defined. This not only improves external code, it provides more test
|
||||||
* coverage for openssl's own code.
|
* coverage for openssl's own code.
|
||||||
*/
|
*/
|
||||||
#define bn_correct_top(a) \
|
|
||||||
{ \
|
|
||||||
BN_ULONG *ftl; \
|
|
||||||
if ((a)->top > 0) \
|
|
||||||
{ \
|
|
||||||
for (ftl= &((a)->d[(a)->top-1]); (a)->top > 0; (a)->top--) \
|
|
||||||
if (*(ftl--)) break; \
|
|
||||||
} \
|
|
||||||
}
|
|
||||||
|
|
||||||
/* #define BN_DEBUG_RAND */
|
/* #define BN_DEBUG_RAND */
|
||||||
|
|
||||||
@ -640,42 +631,54 @@ BIGNUM *bn_dup_expand(const BIGNUM *a, int words);
|
|||||||
int RAND_pseudo_bytes(unsigned char *buf,int num);
|
int RAND_pseudo_bytes(unsigned char *buf,int num);
|
||||||
#define BN_DEBUG_TRIX
|
#define BN_DEBUG_TRIX
|
||||||
#endif
|
#endif
|
||||||
#define bn_check_top(a) \
|
#define bn_pollute(a) \
|
||||||
do { \
|
do { \
|
||||||
const BIGNUM *_tbignum = (a); \
|
const BIGNUM *_bnum1 = (a); \
|
||||||
assert((_tbignum->top == 0) || \
|
if(_bnum1->top < _bnum1->dmax) { \
|
||||||
(_tbignum->d[_tbignum->top - 1] != 0)); \
|
|
||||||
if(_tbignum->top < _tbignum->dmax) { \
|
|
||||||
/* We cast away const without the compiler knowing, any \
|
/* We cast away const without the compiler knowing, any \
|
||||||
* *genuinely* constant variables that aren't mutable \
|
* *genuinely* constant variables that aren't mutable \
|
||||||
* wouldn't be constructed with top!=dmax. */ \
|
* wouldn't be constructed with top!=dmax. */ \
|
||||||
BN_ULONG *_not_const; \
|
BN_ULONG *_not_const; \
|
||||||
memcpy(&_not_const, &_tbignum->d, sizeof(BN_ULONG*)); \
|
memcpy(&_not_const, &_bnum1->d, sizeof(BN_ULONG*)); \
|
||||||
RAND_pseudo_bytes((unsigned char *)(_not_const + _tbignum->top), \
|
RAND_pseudo_bytes((unsigned char *)(_not_const + _bnum1->top), \
|
||||||
(_tbignum->dmax - _tbignum->top) * sizeof(BN_ULONG)); \
|
(_bnum1->dmax - _bnum1->top) * sizeof(BN_ULONG)); \
|
||||||
} \
|
} \
|
||||||
} while(0)
|
} while(0)
|
||||||
#ifdef BN_DEBUG_TRIX
|
#ifdef BN_DEBUG_TRIX
|
||||||
#undef RAND_pseudo_bytes
|
#undef RAND_pseudo_bytes
|
||||||
#endif
|
#endif
|
||||||
#else /* !BN_DEBUG_RAND */
|
#else
|
||||||
|
#define bn_pollute(a)
|
||||||
|
#endif
|
||||||
#define bn_check_top(a) \
|
#define bn_check_top(a) \
|
||||||
do { \
|
do { \
|
||||||
const BIGNUM *_tbignum = (a); \
|
const BIGNUM *_bnum2 = (a); \
|
||||||
assert((_tbignum->top == 0) || \
|
assert((_bnum2->top == 0) || \
|
||||||
(_tbignum->d[_tbignum->top - 1] != 0)); \
|
(_bnum2->d[_bnum2->top - 1] != 0)); \
|
||||||
|
bn_pollute(_bnum2); \
|
||||||
} while(0)
|
} while(0)
|
||||||
#endif
|
|
||||||
|
|
||||||
#define bn_fix_top(a) bn_check_top(a)
|
#define bn_fix_top(a) bn_check_top(a)
|
||||||
|
|
||||||
#else /* !BN_DEBUG */
|
#else /* !BN_DEBUG */
|
||||||
|
|
||||||
|
#define bn_pollute(a)
|
||||||
#define bn_check_top(a)
|
#define bn_check_top(a)
|
||||||
#define bn_fix_top(a) bn_correct_top(a)
|
#define bn_fix_top(a) bn_correct_top(a)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define bn_correct_top(a) \
|
||||||
|
{ \
|
||||||
|
BN_ULONG *ftl; \
|
||||||
|
if ((a)->top > 0) \
|
||||||
|
{ \
|
||||||
|
for (ftl= &((a)->d[(a)->top-1]); (a)->top > 0; (a)->top--) \
|
||||||
|
if (*(ftl--)) break; \
|
||||||
|
} \
|
||||||
|
bn_pollute(a); \
|
||||||
|
}
|
||||||
|
|
||||||
BN_ULONG bn_mul_add_words(BN_ULONG *rp, const BN_ULONG *ap, int num, BN_ULONG w);
|
BN_ULONG bn_mul_add_words(BN_ULONG *rp, const BN_ULONG *ap, int num, BN_ULONG w);
|
||||||
BN_ULONG bn_mul_words(BN_ULONG *rp, const BN_ULONG *ap, int num, BN_ULONG w);
|
BN_ULONG bn_mul_words(BN_ULONG *rp, const BN_ULONG *ap, int num, BN_ULONG w);
|
||||||
void bn_sqr_words(BN_ULONG *rp, const BN_ULONG *ap, int num);
|
void bn_sqr_words(BN_ULONG *rp, const BN_ULONG *ap, int num);
|
||||||
|
Loading…
Reference in New Issue
Block a user