Non-termination in gcry_mpi_invm, behavior of gcry_mpi_powm
    Florian Dold 
    dold at in.tum.de
       
    Tue Feb  4 02:36:59 CET 2014
    
    
  
Hi!
There's a small problem with gcry_mpi_invm and negative numbers.
The following code does not terminate, when it should just set
x to (-1 mod 17) = 16.
gcry_mpi_t x = gcry_mpi_new (0);
gcry_mpi_t p = gcry_mpi_new (0);
if ((NULL == x) || (NULL == p)) abort();
gcry_mpi_set_ui (x, 0);
gcry_mpi_sub_ui (x, x, 1);
gcry_mpi_set_ui (p, 17);
gcry_mpi_invm (x, x, p);
Furthermore, I've noticed that gcry_mpi_powm has no return value.  What
happens, in general, if the result does not exist, e.g. for
"gcry_mpi_powm(x,2,-1,4)"?
- Florian
    
    
More information about the Gcrypt-devel
mailing list