Edit

kc3-lang/libtommath/bn_mp_reduce_is_2k.c

Branch :

  • Show log

    Commit

  • Author : Tom St Denis
    Date : 2003-06-06 19:35:48
    Hash : ef490f30
    Message : added libtommath-0.19

  • bn_mp_reduce_is_2k.c
  • /* LibTomMath, multiple-precision integer library -- Tom St Denis
     *
     * LibTomMath is library that provides for multiple-precision
     * integer arithmetic as well as number theoretic functionality.
     *
     * The library is designed directly after the MPI library by
     * Michael Fromberger but has been written from scratch with
     * additional optimizations in place.
     *
     * The library is free for all purposes without any express
     * guarantee it works.
     *
     * Tom St Denis, tomstdenis@iahu.ca, http://math.libtomcrypt.org
     */
    #include <tommath.h>
    
    /* determines if mp_reduce_2k can be used */
    int 
    mp_reduce_is_2k(mp_int *a)
    {
       int ix, iy;
       
       if (a->used == 0) {
          return 0;
       } else if (a->used == 1) {
          return 1;
       } else if (a->used > 1) {
          iy = mp_count_bits(a);
          for (ix = DIGIT_BIT; ix < iy; ix++) {
              if ((a->dp[ix/DIGIT_BIT] & 
                  ((mp_digit)1 << (mp_digit)(ix % DIGIT_BIT))) == 0) {
                 return 0;
              }
          }
       }
       return 1;
    }