diff options
Diffstat (limited to 'src/lib/libcrypto/dsa/dsa_ossl.c')
| -rw-r--r-- | src/lib/libcrypto/dsa/dsa_ossl.c | 39 |
1 files changed, 31 insertions, 8 deletions
diff --git a/src/lib/libcrypto/dsa/dsa_ossl.c b/src/lib/libcrypto/dsa/dsa_ossl.c index b51cf6ad8d..37dd5fc994 100644 --- a/src/lib/libcrypto/dsa/dsa_ossl.c +++ b/src/lib/libcrypto/dsa/dsa_ossl.c | |||
| @@ -64,6 +64,7 @@ | |||
| 64 | #include <openssl/dsa.h> | 64 | #include <openssl/dsa.h> |
| 65 | #include <openssl/rand.h> | 65 | #include <openssl/rand.h> |
| 66 | #include <openssl/asn1.h> | 66 | #include <openssl/asn1.h> |
| 67 | #include <openssl/engine.h> | ||
| 67 | 68 | ||
| 68 | static DSA_SIG *dsa_do_sign(const unsigned char *dgst, int dlen, DSA *dsa); | 69 | static DSA_SIG *dsa_do_sign(const unsigned char *dgst, int dlen, DSA *dsa); |
| 69 | static int dsa_sign_setup(DSA *dsa, BN_CTX *ctx_in, BIGNUM **kinvp, BIGNUM **rp); | 70 | static int dsa_sign_setup(DSA *dsa, BN_CTX *ctx_in, BIGNUM **kinvp, BIGNUM **rp); |
| @@ -91,7 +92,7 @@ dsa_finish, | |||
| 91 | NULL | 92 | NULL |
| 92 | }; | 93 | }; |
| 93 | 94 | ||
| 94 | DSA_METHOD *DSA_OpenSSL(void) | 95 | const DSA_METHOD *DSA_OpenSSL(void) |
| 95 | { | 96 | { |
| 96 | return &openssl_dsa_meth; | 97 | return &openssl_dsa_meth; |
| 97 | } | 98 | } |
| @@ -105,6 +106,11 @@ static DSA_SIG *dsa_do_sign(const unsigned char *dgst, int dlen, DSA *dsa) | |||
| 105 | int i,reason=ERR_R_BN_LIB; | 106 | int i,reason=ERR_R_BN_LIB; |
| 106 | DSA_SIG *ret=NULL; | 107 | DSA_SIG *ret=NULL; |
| 107 | 108 | ||
| 109 | if (!dsa->p || !dsa->q || !dsa->g) | ||
| 110 | { | ||
| 111 | reason=DSA_R_MISSING_PARAMETERS; | ||
| 112 | goto err; | ||
| 113 | } | ||
| 108 | BN_init(&m); | 114 | BN_init(&m); |
| 109 | BN_init(&xr); | 115 | BN_init(&xr); |
| 110 | s=BN_new(); | 116 | s=BN_new(); |
| @@ -167,6 +173,11 @@ static int dsa_sign_setup(DSA *dsa, BN_CTX *ctx_in, BIGNUM **kinvp, BIGNUM **rp) | |||
| 167 | BIGNUM k,*kinv=NULL,*r=NULL; | 173 | BIGNUM k,*kinv=NULL,*r=NULL; |
| 168 | int ret=0; | 174 | int ret=0; |
| 169 | 175 | ||
| 176 | if (!dsa->p || !dsa->q || !dsa->g) | ||
| 177 | { | ||
| 178 | DSAerr(DSA_F_DSA_SIGN_SETUP,DSA_R_MISSING_PARAMETERS); | ||
| 179 | return 0; | ||
| 180 | } | ||
| 170 | if (ctx_in == NULL) | 181 | if (ctx_in == NULL) |
| 171 | { | 182 | { |
| 172 | if ((ctx=BN_CTX_new()) == NULL) goto err; | 183 | if ((ctx=BN_CTX_new()) == NULL) goto err; |
| @@ -179,13 +190,9 @@ static int dsa_sign_setup(DSA *dsa, BN_CTX *ctx_in, BIGNUM **kinvp, BIGNUM **rp) | |||
| 179 | kinv=NULL; | 190 | kinv=NULL; |
| 180 | 191 | ||
| 181 | /* Get random k */ | 192 | /* Get random k */ |
| 182 | for (;;) | 193 | do |
| 183 | { | 194 | if (!BN_rand_range(&k, dsa->q)) goto err; |
| 184 | if (!BN_rand(&k, BN_num_bits(dsa->q), 1, 0)) goto err; | 195 | while (BN_is_zero(&k)); |
| 185 | if (BN_cmp(&k,dsa->q) >= 0) | ||
| 186 | BN_sub(&k,&k,dsa->q); | ||
| 187 | if (!BN_is_zero(&k)) break; | ||
| 188 | } | ||
| 189 | 196 | ||
| 190 | if ((dsa->method_mont_p == NULL) && (dsa->flags & DSA_FLAG_CACHE_MONT_P)) | 197 | if ((dsa->method_mont_p == NULL) && (dsa->flags & DSA_FLAG_CACHE_MONT_P)) |
| 191 | { | 198 | { |
| @@ -228,12 +235,28 @@ static int dsa_do_verify(const unsigned char *dgst, int dgst_len, DSA_SIG *sig, | |||
| 228 | BIGNUM u1,u2,t1; | 235 | BIGNUM u1,u2,t1; |
| 229 | BN_MONT_CTX *mont=NULL; | 236 | BN_MONT_CTX *mont=NULL; |
| 230 | int ret = -1; | 237 | int ret = -1; |
| 238 | if (!dsa->p || !dsa->q || !dsa->g) | ||
| 239 | { | ||
| 240 | DSAerr(DSA_F_DSA_DO_VERIFY,DSA_R_MISSING_PARAMETERS); | ||
| 241 | return -1; | ||
| 242 | } | ||
| 231 | 243 | ||
| 232 | if ((ctx=BN_CTX_new()) == NULL) goto err; | 244 | if ((ctx=BN_CTX_new()) == NULL) goto err; |
| 233 | BN_init(&u1); | 245 | BN_init(&u1); |
| 234 | BN_init(&u2); | 246 | BN_init(&u2); |
| 235 | BN_init(&t1); | 247 | BN_init(&t1); |
| 236 | 248 | ||
| 249 | if (BN_is_zero(sig->r) || sig->r->neg || BN_ucmp(sig->r, dsa->q) >= 0) | ||
| 250 | { | ||
| 251 | ret = 0; | ||
| 252 | goto err; | ||
| 253 | } | ||
| 254 | if (BN_is_zero(sig->s) || sig->s->neg || BN_ucmp(sig->s, dsa->q) >= 0) | ||
| 255 | { | ||
| 256 | ret = 0; | ||
| 257 | goto err; | ||
| 258 | } | ||
| 259 | |||
| 237 | /* Calculate W = inv(S) mod Q | 260 | /* Calculate W = inv(S) mod Q |
| 238 | * save W in u2 */ | 261 | * save W in u2 */ |
| 239 | if ((BN_mod_inverse(&u2,sig->s,dsa->q,ctx)) == NULL) goto err; | 262 | if ((BN_mod_inverse(&u2,sig->s,dsa->q,ctx)) == NULL) goto err; |
