From: Jacob Nevins Date: Sat, 17 Jun 2006 12:02:03 +0000 (+0000) Subject: Robert Evans spotted that bignum_decimal() failed to cope with being given X-Git-Tag: 0.59~123 X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=commitdiff_plain;h=d75ab2b509eb9e88eef2c2c69a553d66bceca151;p=PuTTY.git Robert Evans spotted that bignum_decimal() failed to cope with being given a zero input. This shouldn't matter for PuTTY, as these routines are only used in PuTTYgen, to output SSH-1 format public key exponents/moduli, which should be nonzero. [originally from svn r6731] --- diff --git a/sshbn.c b/sshbn.c index 728b6fa0..9742c4ad 100644 --- a/sshbn.c +++ b/sshbn.c @@ -1037,9 +1037,14 @@ char *bignum_decimal(Bignum x) * round up (rounding down might make it less than x again). * Therefore if we multiply the bit count by 28/93, rounding * up, we will have enough digits. + * + * i=0 (i.e., x=0) is an irritating special case. */ i = bignum_bitcount(x); - ndigits = (28 * i + 92) / 93; /* multiply by 28/93 and round up */ + if (!i) + ndigits = 1; /* x = 0 */ + else + ndigits = (28 * i + 92) / 93; /* multiply by 28/93 and round up */ ndigits++; /* allow for trailing \0 */ ret = snewn(ndigits, char);