diff options
author | Nick Mathewson <nickm@torproject.org> | 2004-04-08 20:56:33 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2004-04-08 20:56:33 +0000 |
commit | aa7cfd93e53f5d2d01abbc81ce8ee6f6d27ec3c5 (patch) | |
tree | 6cee8a54f8800578928b3365d39288ee468808e5 /src/common/crypto.c | |
parent | d23769239651df818c70f26ab88d57fd712c25bc (diff) | |
download | tor-aa7cfd93e53f5d2d01abbc81ce8ee6f6d27ec3c5.tar.gz tor-aa7cfd93e53f5d2d01abbc81ce8ee6f6d27ec3c5.zip |
Fix base32 implementation; make base32 implementation follow standard; add more tests for base32
svn:r1574
Diffstat (limited to 'src/common/crypto.c')
-rw-r--r-- | src/common/crypto.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/common/crypto.c b/src/common/crypto.c index a6e57129d9..278fe1dedd 100644 --- a/src/common/crypto.c +++ b/src/common/crypto.c @@ -1188,6 +1188,9 @@ base64_decode(char *dest, int destlen, const char *src, int srclen) return ret; } +/* Implement base32 encoding as in rfc3548. Limitation: Requires that + * srclen is a multiple of 5. + */ int base32_encode(char *dest, int destlen, const char *src, int srclen) { @@ -1197,14 +1200,14 @@ base32_encode(char *dest, int destlen, const char *src, int srclen) if ((nbits%5) != 0) /* We need an even multiple of 5 bits. */ return -1; - if ((nbits/5)+1 < destlen) + if ((nbits/5)+1 > destlen) /* Not enough space. */ return -1; for (i=0,bit=0; bit < nbits; ++i, bit+=5) { /* set v to the 16-bit value starting at src[bits/8], 0-padded. */ - v = ((unsigned char)src[bit/8]) << 8; - if (bit+5<nbits) v += src[(bit/8)+1]; + v = ((uint8_t)src[bit/8]) << 8; + if (bit+5<nbits) v += (uint8_t)src[(bit/8)+1]; /* set u to the 5-bit value at the bit'th bit of src. */ u = (v >> (11-(bit%8))) & 0x1F; dest[i] = BASE32_CHARS[u]; |