Initialised 'ok' and redo the logic.
The logic with how 'ok' was calculated didn't quite convey what's "ok",
so the logic is slightly redone to make it less confusing.
Reviewed-by: Andy Polyakov <appro@openssl.org>
(cherry picked from commit 06affe3dac
)
This commit is contained in:
parent
f4c5cd3085
commit
186578be45
@ -166,7 +166,7 @@ int gost_do_verify(const unsigned char *dgst, int dgst_len,
|
||||
BIGNUM *q2 = NULL;
|
||||
BIGNUM *u = NULL, *v = NULL, *z1 = NULL, *z2 = NULL;
|
||||
BIGNUM *tmp2 = NULL, *tmp3 = NULL;
|
||||
int ok;
|
||||
int ok = 0;
|
||||
BN_CTX *ctx = BN_CTX_new();
|
||||
if(!ctx) {
|
||||
GOSTerr(GOST_F_GOST_DO_VERIFY, ERR_R_MALLOC_FAILURE);
|
||||
@ -207,9 +207,9 @@ int gost_do_verify(const unsigned char *dgst, int dgst_len,
|
||||
BN_mod_exp(tmp2, dsa->pub_key, z2, dsa->p, ctx);
|
||||
BN_mod_mul(tmp3, tmp, tmp2, dsa->p, ctx);
|
||||
BN_mod(u, tmp3, dsa->q, ctx);
|
||||
ok = BN_cmp(u, sig->r);
|
||||
ok = (BN_cmp(u, sig->r) == 0);
|
||||
|
||||
if (ok != 0) {
|
||||
if (!ok) {
|
||||
GOSTerr(GOST_F_GOST_DO_VERIFY, GOST_R_SIGNATURE_MISMATCH);
|
||||
}
|
||||
err:
|
||||
@ -218,7 +218,7 @@ err:
|
||||
BN_CTX_end(ctx);
|
||||
BN_CTX_free(ctx);
|
||||
}
|
||||
return (ok == 0);
|
||||
return ok;
|
||||
}
|
||||
|
||||
/*
|
||||
|
Loading…
Reference in New Issue
Block a user