mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Provide a little-endian version of bignum_from_bytes().
This commit is contained in:
parent
ba3d8fd1b9
commit
7d6bf4a6ca
1
ssh.h
1
ssh.h
@ -572,6 +572,7 @@ Bignum modsub(const Bignum a, const Bignum b, const Bignum n);
|
||||
void decbn(Bignum n);
|
||||
extern Bignum Zero, One;
|
||||
Bignum bignum_from_bytes(const unsigned char *data, int nbytes);
|
||||
Bignum bignum_from_bytes_le(const unsigned char *data, int nbytes);
|
||||
Bignum bignum_random_in_range(const Bignum lower, const Bignum upper);
|
||||
int ssh1_read_bignum(const unsigned char *data, int len, Bignum * result);
|
||||
int bignum_bitcount(Bignum bn);
|
||||
|
22
sshbn.c
22
sshbn.c
@ -1233,6 +1233,28 @@ Bignum bignum_from_bytes(const unsigned char *data, int nbytes)
|
||||
return result;
|
||||
}
|
||||
|
||||
Bignum bignum_from_bytes_le(const unsigned char *data, int nbytes)
|
||||
{
|
||||
Bignum result;
|
||||
int w, i;
|
||||
|
||||
assert(nbytes >= 0 && nbytes < INT_MAX/8);
|
||||
|
||||
w = (nbytes + BIGNUM_INT_BYTES - 1) / BIGNUM_INT_BYTES; /* bytes->words */
|
||||
|
||||
result = newbn(w);
|
||||
for (i = 1; i <= w; i++)
|
||||
result[i] = 0;
|
||||
for (i = 0; i < nbytes; ++i) {
|
||||
unsigned char byte = *data++;
|
||||
result[1 + i / BIGNUM_INT_BYTES] |= byte << (8*i % BIGNUM_INT_BITS);
|
||||
}
|
||||
|
||||
while (result[0] > 1 && result[result[0]] == 0)
|
||||
result[0]--;
|
||||
return result;
|
||||
}
|
||||
|
||||
Bignum bignum_random_in_range(const Bignum lower, const Bignum upper)
|
||||
{
|
||||
Bignum ret = NULL;
|
||||
|
Loading…
Reference in New Issue
Block a user