commit
						bd14983023
					
				| @ -34,7 +34,7 @@ int mp_get_bit(const mp_int *a, int b) | |||||||
|     * otherwise (limb >= a->used) would be true for a = 0 |     * otherwise (limb >= a->used) would be true for a = 0 | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|    if (mp_iszero(a)) { |    if (mp_iszero(a) != MP_NO) { | ||||||
|       return MP_NO; |       return MP_NO; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
| @ -45,7 +45,7 @@ int mp_get_bit(const mp_int *a, int b) | |||||||
|    bit = (mp_digit)(1) << (b % DIGIT_BIT); |    bit = (mp_digit)(1) << (b % DIGIT_BIT); | ||||||
| 
 | 
 | ||||||
|    isset = a->dp[limb] & bit; |    isset = a->dp[limb] & bit; | ||||||
|    return (isset != 0) ? MP_YES : MP_NO; |    return (isset != 0u) ? MP_YES : MP_NO; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -28,7 +28,7 @@ int mp_jacobi(const mp_int *a, const mp_int *n, int *c) | |||||||
|       return MP_VAL; |       return MP_VAL; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    return mp_kronecker(a,n,c); |    return mp_kronecker(a, n, c); | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -34,10 +34,10 @@ int mp_kronecker(const mp_int *a, const mp_int *p, int *c) | |||||||
|    int e = MP_OKAY; |    int e = MP_OKAY; | ||||||
|    int v, k; |    int v, k; | ||||||
| 
 | 
 | ||||||
|    const int table[8] = {0, 1, 0, -1, 0, -1, 0, 1}; |    static const int table[8] = {0, 1, 0, -1, 0, -1, 0, 1}; | ||||||
| 
 | 
 | ||||||
|    if (mp_iszero(p)) { |    if (mp_iszero(p) != MP_NO) { | ||||||
|       if (a->used == 1 && a->dp[0] == 1) { |       if ((a->used == 1) && (a->dp[0] == 1u)) { | ||||||
|          *c = 1; |          *c = 1; | ||||||
|          return e; |          return e; | ||||||
|       } else { |       } else { | ||||||
| @ -46,7 +46,7 @@ int mp_kronecker(const mp_int *a, const mp_int *p, int *c) | |||||||
|       } |       } | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    if (mp_iseven(a) && mp_iseven(p)) { |    if ((mp_iseven(a) != MP_NO) && (mp_iseven(p) != MP_NO)) { | ||||||
|       *c = 0; |       *c = 0; | ||||||
|       return e; |       return e; | ||||||
|    } |    } | ||||||
| @ -66,7 +66,7 @@ int mp_kronecker(const mp_int *a, const mp_int *p, int *c) | |||||||
|    if ((v & 0x1) == 0) { |    if ((v & 0x1) == 0) { | ||||||
|       k = 1; |       k = 1; | ||||||
|    } else { |    } else { | ||||||
|       k = table[a->dp[0] & 7]; |       k = table[a->dp[0] & 7u]; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    if (p1.sign == MP_NEG) { |    if (p1.sign == MP_NEG) { | ||||||
| @ -81,8 +81,8 @@ int mp_kronecker(const mp_int *a, const mp_int *p, int *c) | |||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    for (;;) { |    for (;;) { | ||||||
|       if (mp_iszero(&a1)) { |       if (mp_iszero(&a1) != MP_NO) { | ||||||
|          if (mp_cmp_d(&p1, 1) == MP_EQ) { |          if (mp_cmp_d(&p1, 1uL) == MP_EQ) { | ||||||
|             *c = k; |             *c = k; | ||||||
|             goto LBL_KRON; |             goto LBL_KRON; | ||||||
|          } else { |          } else { | ||||||
| @ -97,7 +97,7 @@ int mp_kronecker(const mp_int *a, const mp_int *p, int *c) | |||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if ((v & 0x1) == 1) { |       if ((v & 0x1) == 1) { | ||||||
|          k = k * table[p1.dp[0] & 7]; |          k = k * table[p1.dp[0] & 7u]; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if (a1.sign == MP_NEG) { |       if (a1.sign == MP_NEG) { | ||||||
| @ -106,17 +106,17 @@ int mp_kronecker(const mp_int *a, const mp_int *p, int *c) | |||||||
|           * a1.dp[0] + 1 cannot overflow because the MSB |           * a1.dp[0] + 1 cannot overflow because the MSB | ||||||
|           * of the type mp_digit is not set by definition |           * of the type mp_digit is not set by definition | ||||||
|           */ |           */ | ||||||
|          if ((a1.dp[0] + 1) & p1.dp[0] & 2u) { |          if (((a1.dp[0] + 1u) & p1.dp[0] & 2u) != 0u) { | ||||||
|             k = -k; |             k = -k; | ||||||
|          } |          } | ||||||
|       } else { |       } else { | ||||||
|          /* compute k = (-1)^((a1-1)*(p1-1)/4) * k */ |          /* compute k = (-1)^((a1-1)*(p1-1)/4) * k */ | ||||||
|          if (a1.dp[0] & p1.dp[0] & 2u) { |          if ((a1.dp[0] & p1.dp[0] & 2u) != 0u) { | ||||||
|             k = -k; |             k = -k; | ||||||
|          } |          } | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if ((e = mp_copy(&a1,&r)) != MP_OKAY) { |       if ((e = mp_copy(&a1, &r)) != MP_OKAY) { | ||||||
|          goto LBL_KRON; |          goto LBL_KRON; | ||||||
|       } |       } | ||||||
|       r.sign = MP_ZPOS; |       r.sign = MP_ZPOS; | ||||||
|  | |||||||
| @ -35,32 +35,33 @@ | |||||||
| #endif | #endif | ||||||
| int mp_prime_frobenius_underwood(const mp_int *N, int *result) | int mp_prime_frobenius_underwood(const mp_int *N, int *result) | ||||||
| { | { | ||||||
|    mp_int T1z,T2z,Np1z,sz,tz; |    mp_int T1z, T2z, Np1z, sz, tz; | ||||||
| 
 | 
 | ||||||
|    int a, ap2, length, i, j, isset; |    int a, ap2, length, i, j, isset; | ||||||
|    int e = MP_OKAY; |    int e; | ||||||
| 
 | 
 | ||||||
|    *result = MP_NO; |    *result = MP_NO; | ||||||
| 
 | 
 | ||||||
|    if ((e = mp_init_multi(&T1z,&T2z,&Np1z,&sz,&tz, NULL)) != MP_OKAY) { |    if ((e = mp_init_multi(&T1z, &T2z, &Np1z, &sz, &tz, NULL)) != MP_OKAY) { | ||||||
|       return e; |       return e; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    for (a = 0; a < LTM_FROBENIUS_UNDERWOOD_A; a++) { |    for (a = 0; a < LTM_FROBENIUS_UNDERWOOD_A; a++) { | ||||||
|       /* TODO: That's ugly! No, really, it is! */ |       /* TODO: That's ugly! No, really, it is! */ | ||||||
|       if (a==2||a==4||a==7||a==8||a==10||a==14||a==18||a==23||a==26||a==28) { |       if ((a==2) || (a==4) || (a==7) || (a==8) || (a==10) || | ||||||
|  |           (a==14) || (a==18) || (a==23) || (a==26) || (a==28)) { | ||||||
|          continue; |          continue; | ||||||
|       } |       } | ||||||
|       /* (32764^2 - 4) < 2^31, no bigint for >MP_8BIT needed) */ |       /* (32764^2 - 4) < 2^31, no bigint for >MP_8BIT needed) */ | ||||||
|       if ((e = mp_set_long(&T1z,(unsigned long)a)) != MP_OKAY) { |       if ((e = mp_set_long(&T1z, (unsigned long)a)) != MP_OKAY) { | ||||||
|          goto LBL_FU_ERR; |          goto LBL_FU_ERR; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if ((e = mp_sqr(&T1z,&T1z)) != MP_OKAY) { |       if ((e = mp_sqr(&T1z, &T1z)) != MP_OKAY) { | ||||||
|          goto LBL_FU_ERR; |          goto LBL_FU_ERR; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if ((e = mp_sub_d(&T1z,4,&T1z)) != MP_OKAY) { |       if ((e = mp_sub_d(&T1z, 4uL, &T1z)) != MP_OKAY) { | ||||||
|          goto LBL_FU_ERR; |          goto LBL_FU_ERR; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
| @ -83,25 +84,25 @@ int mp_prime_frobenius_underwood(const mp_int *N, int *result) | |||||||
|       goto LBL_FU_ERR; |       goto LBL_FU_ERR; | ||||||
|    } |    } | ||||||
|    /* Composite if N and (a+4)*(2*a+5) are not coprime */ |    /* Composite if N and (a+4)*(2*a+5) are not coprime */ | ||||||
|    if ((e = mp_set_long(&T1z, (unsigned long)((a+4)*(2*a+5)))) != MP_OKAY) { |    if ((e = mp_set_long(&T1z, (unsigned long)((a+4)*((2*a)+5)))) != MP_OKAY) { | ||||||
|       goto LBL_FU_ERR; |       goto LBL_FU_ERR; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    if ((e = mp_gcd(N,&T1z,&T1z)) != MP_OKAY) { |    if ((e = mp_gcd(N, &T1z, &T1z)) != MP_OKAY) { | ||||||
|       goto LBL_FU_ERR; |       goto LBL_FU_ERR; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    if (!(T1z.used == 1 && T1z.dp[0] == 1u)) { |    if (!((T1z.used == 1) && (T1z.dp[0] == 1u))) { | ||||||
|       goto LBL_FU_ERR; |       goto LBL_FU_ERR; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    ap2 = a + 2; |    ap2 = a + 2; | ||||||
|    if ((e = mp_add_d(N,1u,&Np1z)) != MP_OKAY) { |    if ((e = mp_add_d(N, 1uL, &Np1z)) != MP_OKAY) { | ||||||
|       goto LBL_FU_ERR; |       goto LBL_FU_ERR; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    mp_set(&sz,1u); |    mp_set(&sz, 1uL); | ||||||
|    mp_set(&tz,2u); |    mp_set(&tz, 2uL); | ||||||
|    length = mp_count_bits(&Np1z); |    length = mp_count_bits(&Np1z); | ||||||
| 
 | 
 | ||||||
|    for (i = length - 2; i >= 0; i--) { |    for (i = length - 2; i >= 0; i--) { | ||||||
| @ -110,16 +111,16 @@ int mp_prime_frobenius_underwood(const mp_int *N, int *result) | |||||||
|        * tz   = ((tz-sz)*(tz+sz))%N; |        * tz   = ((tz-sz)*(tz+sz))%N; | ||||||
|        * sz   = temp; |        * sz   = temp; | ||||||
|        */ |        */ | ||||||
|       if ((e = mp_mul_2(&tz,&T2z)) != MP_OKAY) { |       if ((e = mp_mul_2(&tz, &T2z)) != MP_OKAY) { | ||||||
|          goto LBL_FU_ERR; |          goto LBL_FU_ERR; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       /* a = 0 at about 50% of the cases (non-square and odd input) */ |       /* a = 0 at about 50% of the cases (non-square and odd input) */ | ||||||
|       if (a != 0) { |       if (a != 0) { | ||||||
|          if ((e = mp_mul_d(&sz,(mp_digit)a,&T1z)) != MP_OKAY) { |          if ((e = mp_mul_d(&sz, (mp_digit)a, &T1z)) != MP_OKAY) { | ||||||
|             goto LBL_FU_ERR; |             goto LBL_FU_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = mp_add(&T1z,&T2z,&T2z)) != MP_OKAY) { |          if ((e = mp_add(&T1z, &T2z, &T2z)) != MP_OKAY) { | ||||||
|             goto LBL_FU_ERR; |             goto LBL_FU_ERR; | ||||||
|          } |          } | ||||||
|       } |       } | ||||||
| @ -142,7 +143,7 @@ int mp_prime_frobenius_underwood(const mp_int *N, int *result) | |||||||
|       if ((e = mp_mod(&T1z, N, &sz)) != MP_OKAY) { |       if ((e = mp_mod(&T1z, N, &sz)) != MP_OKAY) { | ||||||
|          goto LBL_FU_ERR; |          goto LBL_FU_ERR; | ||||||
|       } |       } | ||||||
|       if ((isset = mp_get_bit(&Np1z,i)) == MP_VAL) { |       if ((isset = mp_get_bit(&Np1z, i)) == MP_VAL) { | ||||||
|          e = isset; |          e = isset; | ||||||
|          goto LBL_FU_ERR; |          goto LBL_FU_ERR; | ||||||
|       } |       } | ||||||
| @ -153,11 +154,11 @@ int mp_prime_frobenius_underwood(const mp_int *N, int *result) | |||||||
|           *  sz   = temp |           *  sz   = temp | ||||||
|           */ |           */ | ||||||
|          if (a == 0) { |          if (a == 0) { | ||||||
|             if ((e = mp_mul_2(&sz,&T1z)) != MP_OKAY) { |             if ((e = mp_mul_2(&sz, &T1z)) != MP_OKAY) { | ||||||
|                goto LBL_FU_ERR; |                goto LBL_FU_ERR; | ||||||
|             } |             } | ||||||
|          } else { |          } else { | ||||||
|             if ((e = mp_mul_d(&sz, (mp_digit) ap2, &T1z)) != MP_OKAY) { |             if ((e = mp_mul_d(&sz, (mp_digit)ap2, &T1z)) != MP_OKAY) { | ||||||
|                goto LBL_FU_ERR; |                goto LBL_FU_ERR; | ||||||
|             } |             } | ||||||
|          } |          } | ||||||
| @ -170,23 +171,23 @@ int mp_prime_frobenius_underwood(const mp_int *N, int *result) | |||||||
|          if ((e = mp_sub(&T2z, &sz, &tz)) != MP_OKAY) { |          if ((e = mp_sub(&T2z, &sz, &tz)) != MP_OKAY) { | ||||||
|             goto LBL_FU_ERR; |             goto LBL_FU_ERR; | ||||||
|          } |          } | ||||||
|          mp_exch(&sz,&T1z); |          mp_exch(&sz, &T1z); | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    if ((e = mp_set_long(&T1z, (unsigned long)(2 * a + 5))) != MP_OKAY) { |    if ((e = mp_set_long(&T1z, (unsigned long)((2 * a) + 5))) != MP_OKAY) { | ||||||
|       goto LBL_FU_ERR; |       goto LBL_FU_ERR; | ||||||
|    } |    } | ||||||
|    if ((e = mp_mod(&T1z,N,&T1z)) != MP_OKAY) { |    if ((e = mp_mod(&T1z, N, &T1z)) != MP_OKAY) { | ||||||
|       goto LBL_FU_ERR; |       goto LBL_FU_ERR; | ||||||
|    } |    } | ||||||
|    if (mp_iszero(&sz) && (mp_cmp(&tz, &T1z) == MP_EQ)) { |    if ((mp_iszero(&sz) != MP_NO) && (mp_cmp(&tz, &T1z) == MP_EQ)) { | ||||||
|       *result = MP_YES; |       *result = MP_YES; | ||||||
|       goto LBL_FU_ERR; |       goto LBL_FU_ERR; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
| LBL_FU_ERR: | LBL_FU_ERR: | ||||||
|    mp_clear_multi(&tz,&sz,&Np1z,&T2z,&T1z, NULL); |    mp_clear_multi(&tz, &sz, &Np1z, &T2z, &T1z, NULL); | ||||||
|    return e; |    return e; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -41,11 +41,11 @@ int mp_prime_is_prime(const mp_int *a, int t, int *result) | |||||||
|    /* Some shortcuts */ |    /* Some shortcuts */ | ||||||
|    /* N > 3 */ |    /* N > 3 */ | ||||||
|    if (a->used == 1) { |    if (a->used == 1) { | ||||||
|       if (a->dp[0] == 0 || a->dp[0] == 1) { |       if ((a->dp[0] == 0u) || (a->dp[0] == 1u)) { | ||||||
|          *result = 0; |          *result = 0; | ||||||
|          return MP_OKAY; |          return MP_OKAY; | ||||||
|       } |       } | ||||||
|       if (a->dp[0] == 2) { |       if (a->dp[0] == 2u) { | ||||||
|          *result = 1; |          *result = 1; | ||||||
|          return MP_OKAY; |          return MP_OKAY; | ||||||
|       } |       } | ||||||
| @ -90,7 +90,7 @@ int mp_prime_is_prime(const mp_int *a, int t, int *result) | |||||||
|    /*
 |    /*
 | ||||||
|        Run the Miller-Rabin test with base 2 for the BPSW test. |        Run the Miller-Rabin test with base 2 for the BPSW test. | ||||||
|     */ |     */ | ||||||
|    if ((err = mp_init_set(&b,2)) != MP_OKAY) { |    if ((err = mp_init_set(&b, 2uL)) != MP_OKAY) { | ||||||
|       return err; |       return err; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
| @ -197,7 +197,7 @@ int mp_prime_is_prime(const mp_int *a, int t, int *result) | |||||||
|          goto LBL_B; |          goto LBL_B; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if (mp_cmp(a,&b) == MP_LT) { |       if (mp_cmp(a, &b) == MP_LT) { | ||||||
|          p_max = 12; |          p_max = 12; | ||||||
|       } else { |       } else { | ||||||
|          /* 0x2be6951adc5b22410a5fd = 3317044064679887385961981 */ |          /* 0x2be6951adc5b22410a5fd = 3317044064679887385961981 */ | ||||||
| @ -205,7 +205,7 @@ int mp_prime_is_prime(const mp_int *a, int t, int *result) | |||||||
|             goto LBL_B; |             goto LBL_B; | ||||||
|          } |          } | ||||||
| 
 | 
 | ||||||
|          if (mp_cmp(a,&b) == MP_LT) { |          if (mp_cmp(a, &b) == MP_LT) { | ||||||
|             p_max = 13; |             p_max = 13; | ||||||
|          } else { |          } else { | ||||||
|             err = MP_VAL; |             err = MP_VAL; | ||||||
| @ -224,7 +224,7 @@ int mp_prime_is_prime(const mp_int *a, int t, int *result) | |||||||
|       } |       } | ||||||
|       /* we did bases 2 and 3  already, skip them */ |       /* we did bases 2 and 3  already, skip them */ | ||||||
|       for (ix = 2; ix < p_max; ix++) { |       for (ix = 2; ix < p_max; ix++) { | ||||||
|          mp_set(&b,ltm_prime_tab[ix]); |          mp_set(&b, ltm_prime_tab[ix]); | ||||||
|          if ((err = mp_prime_miller_rabin(a, &b, &res)) != MP_OKAY) { |          if ((err = mp_prime_miller_rabin(a, &b, &res)) != MP_OKAY) { | ||||||
|             goto LBL_B; |             goto LBL_B; | ||||||
|          } |          } | ||||||
| @ -307,7 +307,7 @@ int mp_prime_is_prime(const mp_int *a, int t, int *result) | |||||||
|          } |          } | ||||||
| #endif | #endif | ||||||
|          /* Ceil, because small numbers have a right to live, too, */ |          /* Ceil, because small numbers have a right to live, too, */ | ||||||
|          len = (int)((fips_rand + DIGIT_BIT) / DIGIT_BIT); |          len = (((int)fips_rand + DIGIT_BIT) / DIGIT_BIT); | ||||||
|          /*  Unlikely. */ |          /*  Unlikely. */ | ||||||
|          if (len < 0) { |          if (len < 0) { | ||||||
|             ix--; |             ix--; | ||||||
| @ -339,7 +339,7 @@ int mp_prime_is_prime(const mp_int *a, int t, int *result) | |||||||
|          } |          } | ||||||
| 
 | 
 | ||||||
|          /* Although the chance for b <= 3 is miniscule, try again. */ |          /* Although the chance for b <= 3 is miniscule, try again. */ | ||||||
|          if (mp_cmp_d(&b,3) != MP_GT) { |          if (mp_cmp_d(&b, 3uL) != MP_GT) { | ||||||
|             ix--; |             ix--; | ||||||
|             continue; |             continue; | ||||||
|          } |          } | ||||||
|  | |||||||
| @ -85,7 +85,7 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|    mp_int Dz, gcd, Np1, Uz, Vz, U2mz, V2mz, Qmz, Q2mz, Qkdz, T1z, T2z, T3z, T4z, Q2kdz; |    mp_int Dz, gcd, Np1, Uz, Vz, U2mz, V2mz, Qmz, Q2mz, Qkdz, T1z, T2z, T3z, T4z, Q2kdz; | ||||||
|    /* CZ TODO: Some of them need the full 32 bit, hence the (temporary) exclusion of MP_8BIT */ |    /* CZ TODO: Some of them need the full 32 bit, hence the (temporary) exclusion of MP_8BIT */ | ||||||
|    int32_t D, Ds, J, sign, P, Q, r, s, u, Nbits; |    int32_t D, Ds, J, sign, P, Q, r, s, u, Nbits; | ||||||
|    int e = MP_OKAY; |    int e; | ||||||
|    int isset; |    int isset; | ||||||
| 
 | 
 | ||||||
|    *result = MP_NO; |    *result = MP_NO; | ||||||
| @ -109,7 +109,7 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|    for (;;) { |    for (;;) { | ||||||
|       Ds   = sign * D; |       Ds   = sign * D; | ||||||
|       sign = -sign; |       sign = -sign; | ||||||
|       if ((e = mp_set_long(&Dz,(unsigned long) D)) != MP_OKAY) { |       if ((e = mp_set_long(&Dz, (unsigned long)D)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_gcd(a, &Dz, &gcd)) != MP_OKAY) { |       if ((e = mp_gcd(a, &Dz, &gcd)) != MP_OKAY) { | ||||||
| @ -118,7 +118,7 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|       /* if 1 < GCD < N then N is composite with factor "D", and
 |       /* if 1 < GCD < N then N is composite with factor "D", and
 | ||||||
|          Jacobi(D,N) is technically undefined (but often returned |          Jacobi(D,N) is technically undefined (but often returned | ||||||
|          as zero). */ |          as zero). */ | ||||||
|       if ((mp_cmp_d(&gcd,1u) == MP_GT) && (mp_cmp(&gcd,a) == MP_LT)) { |       if ((mp_cmp_d(&gcd, 1uL) == MP_GT) && (mp_cmp(&gcd, a) == MP_LT)) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if (Ds < 0) { |       if (Ds < 0) { | ||||||
| @ -133,7 +133,7 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|       } |       } | ||||||
|       D += 2; |       D += 2; | ||||||
| 
 | 
 | ||||||
|       if (D > INT_MAX - 2) { |       if (D > (INT_MAX - 2)) { | ||||||
|          e = MP_VAL; |          e = MP_VAL; | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
| @ -172,7 +172,7 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|       Baillie-PSW test based on the strong Lucas-Selfridge test |       Baillie-PSW test based on the strong Lucas-Selfridge test | ||||||
|       should be more reliable. */ |       should be more reliable. */ | ||||||
| 
 | 
 | ||||||
|    if ((e = mp_add_d(a,1u,&Np1)) != MP_OKAY) { |    if ((e = mp_add_d(a, 1uL, &Np1)) != MP_OKAY) { | ||||||
|       goto LBL_LS_ERR; |       goto LBL_LS_ERR; | ||||||
|    } |    } | ||||||
|    s = mp_cnt_lsb(&Np1); |    s = mp_cnt_lsb(&Np1); | ||||||
| @ -198,21 +198,21 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|       combined with the previous totals for U and V, using the |       combined with the previous totals for U and V, using the | ||||||
|       composition formulas for addition of indices. */ |       composition formulas for addition of indices. */ | ||||||
| 
 | 
 | ||||||
|    mp_set(&Uz, 1u);    /* U=U_1 */ |    mp_set(&Uz, 1uL);    /* U=U_1 */ | ||||||
|    mp_set(&Vz, (mp_digit)P);    /* V=V_1 */ |    mp_set(&Vz, (mp_digit)P);    /* V=V_1 */ | ||||||
|    mp_set(&U2mz, 1u);  /* U_1 */ |    mp_set(&U2mz, 1uL);  /* U_1 */ | ||||||
|    mp_set(&V2mz, (mp_digit)P);  /* V_1 */ |    mp_set(&V2mz, (mp_digit)P);  /* V_1 */ | ||||||
| 
 | 
 | ||||||
|    if (Q < 0) { |    if (Q < 0) { | ||||||
|       Q = -Q; |       Q = -Q; | ||||||
|       if ((e = mp_set_long(&Qmz, (unsigned long) Q)) != MP_OKAY) { |       if ((e = mp_set_long(&Qmz, (unsigned long)Q)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_mul_2(&Qmz, &Q2mz)) != MP_OKAY) { |       if ((e = mp_mul_2(&Qmz, &Q2mz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       /* Initializes calculation of Q^d */ |       /* Initializes calculation of Q^d */ | ||||||
|       if ((e = mp_set_long(&Qkdz, (unsigned long) Q)) != MP_OKAY) { |       if ((e = mp_set_long(&Qkdz, (unsigned long)Q)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       Qmz.sign = MP_NEG; |       Qmz.sign = MP_NEG; | ||||||
| @ -220,14 +220,14 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|       Qkdz.sign = MP_NEG; |       Qkdz.sign = MP_NEG; | ||||||
|       Q = -Q; |       Q = -Q; | ||||||
|    } else { |    } else { | ||||||
|       if ((e = mp_set_long(&Qmz, (unsigned long) Q)) != MP_OKAY) { |       if ((e = mp_set_long(&Qmz, (unsigned long)Q)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_mul_2(&Qmz, &Q2mz)) != MP_OKAY) { |       if ((e = mp_mul_2(&Qmz, &Q2mz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       /* Initializes calculation of Q^d */ |       /* Initializes calculation of Q^d */ | ||||||
|       if ((e = mp_set_long(&Qkdz, (unsigned long) Q)) != MP_OKAY) { |       if ((e = mp_set_long(&Qkdz, (unsigned long)Q)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
| @ -242,34 +242,34 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|        * V_2m = V_m*V_m - 2*Q^m |        * V_2m = V_m*V_m - 2*Q^m | ||||||
|        */ |        */ | ||||||
| 
 | 
 | ||||||
|       if ((e = mp_mul(&U2mz,&V2mz,&U2mz)) != MP_OKAY) { |       if ((e = mp_mul(&U2mz, &V2mz, &U2mz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_mod(&U2mz,a,&U2mz)) != MP_OKAY) { |       if ((e = mp_mod(&U2mz, a, &U2mz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_sqr(&V2mz,&V2mz)) != MP_OKAY) { |       if ((e = mp_sqr(&V2mz, &V2mz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_sub(&V2mz,&Q2mz,&V2mz)) != MP_OKAY) { |       if ((e = mp_sub(&V2mz, &Q2mz, &V2mz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_mod(&V2mz,a,&V2mz)) != MP_OKAY) { |       if ((e = mp_mod(&V2mz, a, &V2mz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       /* Must calculate powers of Q for use in V_2m, also for Q^d later */ |       /* Must calculate powers of Q for use in V_2m, also for Q^d later */ | ||||||
|       if ((e = mp_sqr(&Qmz,&Qmz)) != MP_OKAY) { |       if ((e = mp_sqr(&Qmz, &Qmz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       /* prevents overflow */ /* CZ  still necessary without a fixed prealloc'd mem.? */ |       /* prevents overflow */ /* CZ  still necessary without a fixed prealloc'd mem.? */ | ||||||
|       if ((e = mp_mod(&Qmz,a,&Qmz)) != MP_OKAY) { |       if ((e = mp_mod(&Qmz, a, &Qmz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_mul_2(&Qmz,&Q2mz)) != MP_OKAY) { |       if ((e = mp_mul_2(&Qmz, &Q2mz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if ((isset = mp_get_bit(&Dz,u)) == MP_VAL) { |       if ((isset = mp_get_bit(&Dz, u)) == MP_VAL) { | ||||||
|          e = isset; |          e = isset; | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
| @ -282,26 +282,26 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|           * Be careful with division by 2 (mod N)! |           * Be careful with division by 2 (mod N)! | ||||||
|           */ |           */ | ||||||
| 
 | 
 | ||||||
|          if ((e = mp_mul(&U2mz,&Vz,&T1z)) != MP_OKAY) { |          if ((e = mp_mul(&U2mz, &Vz, &T1z)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = mp_mul(&Uz,&V2mz,&T2z)) != MP_OKAY) { |          if ((e = mp_mul(&Uz, &V2mz, &T2z)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = mp_mul(&V2mz,&Vz,&T3z)) != MP_OKAY) { |          if ((e = mp_mul(&V2mz, &Vz, &T3z)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = mp_mul(&U2mz,&Uz,&T4z)) != MP_OKAY) { |          if ((e = mp_mul(&U2mz, &Uz, &T4z)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = s_mp_mul_si(&T4z,(long)Ds,&T4z)) != MP_OKAY) { |          if ((e = s_mp_mul_si(&T4z, (long)Ds, &T4z)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = mp_add(&T1z,&T2z,&Uz)) != MP_OKAY) { |          if ((e = mp_add(&T1z, &T2z, &Uz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if (mp_isodd(&Uz)) { |          if (mp_isodd(&Uz) != MP_NO) { | ||||||
|             if ((e = mp_add(&Uz,a,&Uz)) != MP_OKAY) { |             if ((e = mp_add(&Uz, a, &Uz)) != MP_OKAY) { | ||||||
|                goto LBL_LS_ERR; |                goto LBL_LS_ERR; | ||||||
|             } |             } | ||||||
|          } |          } | ||||||
| @ -310,41 +310,41 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|           * Thomas R. Nicely used GMP's mpz_fdiv_q_2exp(). |           * Thomas R. Nicely used GMP's mpz_fdiv_q_2exp(). | ||||||
|           * But mp_div_2() does not do so, it is truncating instead. |           * But mp_div_2() does not do so, it is truncating instead. | ||||||
|           */ |           */ | ||||||
|          if ((e = mp_div_2(&Uz,&Uz)) != MP_OKAY) { |          if ((e = mp_div_2(&Uz, &Uz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((Uz.sign == MP_NEG) && mp_isodd(&Uz)) { |          if ((Uz.sign == MP_NEG) && (mp_isodd(&Uz) != MP_NO)) { | ||||||
|             if ((e = mp_sub_d(&Uz,1u,&Uz)) != MP_OKAY) { |             if ((e = mp_sub_d(&Uz, 1uL, &Uz)) != MP_OKAY) { | ||||||
|                goto LBL_LS_ERR; |                goto LBL_LS_ERR; | ||||||
|             } |             } | ||||||
|          } |          } | ||||||
|          if ((e = mp_add(&T3z,&T4z,&Vz)) != MP_OKAY) { |          if ((e = mp_add(&T3z, &T4z, &Vz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if (mp_isodd(&Vz)) { |          if (mp_isodd(&Vz) != MP_NO) { | ||||||
|             if ((e = mp_add(&Vz,a,&Vz)) != MP_OKAY) { |             if ((e = mp_add(&Vz, a, &Vz)) != MP_OKAY) { | ||||||
|                goto LBL_LS_ERR; |                goto LBL_LS_ERR; | ||||||
|             } |             } | ||||||
|          } |          } | ||||||
|          if ((e = mp_div_2(&Vz,&Vz)) != MP_OKAY) { |          if ((e = mp_div_2(&Vz, &Vz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if (Vz.sign == MP_NEG && mp_isodd(&Vz)) { |          if ((Vz.sign == MP_NEG) && (mp_isodd(&Vz) != MP_NO)) { | ||||||
|             if ((e = mp_sub_d(&Vz,1,&Vz)) != MP_OKAY) { |             if ((e = mp_sub_d(&Vz, 1uL, &Vz)) != MP_OKAY) { | ||||||
|                goto LBL_LS_ERR; |                goto LBL_LS_ERR; | ||||||
|             } |             } | ||||||
|          } |          } | ||||||
|          if ((e = mp_mod(&Uz,a,&Uz)) != MP_OKAY) { |          if ((e = mp_mod(&Uz, a, &Uz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = mp_mod(&Vz,a,&Vz)) != MP_OKAY) { |          if ((e = mp_mod(&Vz, a, &Vz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          /* Calculating Q^d for later use */ |          /* Calculating Q^d for later use */ | ||||||
|          if ((e = mp_mul(&Qkdz,&Qmz,&Qkdz)) != MP_OKAY) { |          if ((e = mp_mul(&Qkdz, &Qmz, &Qkdz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = mp_mod(&Qkdz,a,&Qkdz)) != MP_OKAY) { |          if ((e = mp_mod(&Qkdz, a, &Qkdz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|       } |       } | ||||||
| @ -352,7 +352,7 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
| 
 | 
 | ||||||
|    /* If U_d or V_d is congruent to 0 mod N, then N is a prime or a
 |    /* If U_d or V_d is congruent to 0 mod N, then N is a prime or a
 | ||||||
|       strong Lucas pseudoprime. */ |       strong Lucas pseudoprime. */ | ||||||
|    if (mp_iszero(&Uz) || mp_iszero(&Vz)) { |    if ((mp_iszero(&Uz) != MP_NO) || (mp_iszero(&Vz) != MP_NO)) { | ||||||
|       *result = MP_YES; |       *result = MP_YES; | ||||||
|       goto LBL_LS_ERR; |       goto LBL_LS_ERR; | ||||||
|    } |    } | ||||||
| @ -369,33 +369,33 @@ int mp_prime_strong_lucas_selfridge(const mp_int *a, int *result) | |||||||
|       Lucas pseudoprime. */ |       Lucas pseudoprime. */ | ||||||
| 
 | 
 | ||||||
|    /* Initialize 2*Q^(d*2^r) for V_2m */ |    /* Initialize 2*Q^(d*2^r) for V_2m */ | ||||||
|    if ((e = mp_mul_2(&Qkdz,&Q2kdz)) != MP_OKAY) { |    if ((e = mp_mul_2(&Qkdz, &Q2kdz)) != MP_OKAY) { | ||||||
|       goto LBL_LS_ERR; |       goto LBL_LS_ERR; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    for (r = 1; r < s; r++) { |    for (r = 1; r < s; r++) { | ||||||
|       if ((e = mp_sqr(&Vz,&Vz)) != MP_OKAY) { |       if ((e = mp_sqr(&Vz, &Vz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_sub(&Vz,&Q2kdz,&Vz)) != MP_OKAY) { |       if ((e = mp_sub(&Vz, &Q2kdz, &Vz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if ((e = mp_mod(&Vz,a,&Vz)) != MP_OKAY) { |       if ((e = mp_mod(&Vz, a, &Vz)) != MP_OKAY) { | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       if (mp_iszero(&Vz)) { |       if (mp_iszero(&Vz) != MP_NO) { | ||||||
|          *result = MP_YES; |          *result = MP_YES; | ||||||
|          goto LBL_LS_ERR; |          goto LBL_LS_ERR; | ||||||
|       } |       } | ||||||
|       /* Calculate Q^{d*2^r} for next r (final iteration irrelevant). */ |       /* Calculate Q^{d*2^r} for next r (final iteration irrelevant). */ | ||||||
|       if (r < (s - 1)) { |       if (r < (s - 1)) { | ||||||
|          if ((e = mp_sqr(&Qkdz,&Qkdz)) != MP_OKAY) { |          if ((e = mp_sqr(&Qkdz, &Qkdz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = mp_mod(&Qkdz,a,&Qkdz)) != MP_OKAY) { |          if ((e = mp_mod(&Qkdz, a, &Qkdz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|          if ((e = mp_mul_2(&Qkdz,&Q2kdz)) != MP_OKAY) { |          if ((e = mp_mul_2(&Qkdz, &Q2kdz)) != MP_OKAY) { | ||||||
|             goto LBL_LS_ERR; |             goto LBL_LS_ERR; | ||||||
|          } |          } | ||||||
|       } |       } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user