mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-02 22:46:30 +02:00
See ChangeLog: Thu Jan 7 18:00:58 CET 1999 Werner Koch
This commit is contained in:
parent
e3e8d9b92f
commit
7d0efec7cf
31 changed files with 621 additions and 223 deletions
|
@ -1,3 +1,10 @@
|
|||
Thu Jan 7 18:00:58 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||
|
||||
* mpi-bit.c (mpi_normalize): New.
|
||||
(mpi_get_nbits): Normalize the MPI.
|
||||
* mpi-bit.c (mpi_cmp): Normalize the MPI before the compare.
|
||||
|
||||
|
||||
Tue Dec 8 13:15:16 CET 1998 Werner Koch <wk@isil.d.shuttle.de>
|
||||
|
||||
* config.links: Moved the case for powerpc*linux
|
||||
|
|
|
@ -48,7 +48,19 @@ __clz_tab[] =
|
|||
#define A_LIMB_1 ((mpi_limb_t)1)
|
||||
|
||||
|
||||
/****************
|
||||
* Sometimes we have MSL (most significant limbs) which are 0;
|
||||
* this is for some reasons not good, so this function removes them.
|
||||
*/
|
||||
void
|
||||
mpi_normalize( MPI a )
|
||||
{
|
||||
if( mpi_is_protected(a) )
|
||||
return;
|
||||
|
||||
for( ; a->nlimbs && !a->d[a->nlimbs-1]; a->nlimbs-- )
|
||||
;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
@ -67,6 +79,7 @@ mpi_get_nbits( MPI a )
|
|||
return n;
|
||||
}
|
||||
|
||||
mpi_normalize( a );
|
||||
if( a->nlimbs ) {
|
||||
mpi_limb_t alimb = a->d[a->nlimbs-1];
|
||||
if( alimb )
|
||||
|
|
|
@ -46,27 +46,28 @@ mpi_cmp_ui( MPI u, unsigned long v )
|
|||
int
|
||||
mpi_cmp( MPI u, MPI v )
|
||||
{
|
||||
mpi_size_t usize = u->nlimbs;
|
||||
mpi_size_t vsize = v->nlimbs;
|
||||
mpi_size_t usize, vsize;
|
||||
int cmp;
|
||||
|
||||
/* FIXME: are the numbers always normalized? */
|
||||
mpi_normalize( u );
|
||||
mpi_normalize( v );
|
||||
usize = u->nlimbs;
|
||||
vsize = v->nlimbs;
|
||||
if( !u->sign && v->sign )
|
||||
return 1;
|
||||
else if( u->sign && !v->sign )
|
||||
if( u->sign && !v->sign )
|
||||
return -1;
|
||||
else if( usize != vsize && !u->sign && !v->sign )
|
||||
if( usize != vsize && !u->sign && !v->sign )
|
||||
return usize - vsize;
|
||||
else if( usize != vsize && u->sign && v->sign )
|
||||
if( usize != vsize && u->sign && v->sign )
|
||||
return vsize + usize;
|
||||
else if( !usize )
|
||||
if( !usize )
|
||||
return 0;
|
||||
else if( !(cmp=mpihelp_cmp( u->d, v->d, usize )) )
|
||||
if( !(cmp=mpihelp_cmp( u->d, v->d, usize )) )
|
||||
return 0;
|
||||
else if( (cmp < 0?1:0) == (u->sign?1:0))
|
||||
if( (cmp < 0?1:0) == (u->sign?1:0))
|
||||
return 1;
|
||||
else
|
||||
return -1;
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue