X-Git-Url: https://wimlib.net/git/?a=blobdiff_plain;f=src%2Fsha1.c;h=1b2abb2f226a3b293a55347c5ec541b2cbc26f9e;hb=a4204528d3fbd8b959025b897493cf68d5cbfc0f;hp=bd83a413745bd0f8c8bd747517c09cad6c939a2d;hpb=19ce03addb8071555d951a965fa0bd7e3ae7224b;p=wimlib diff --git a/src/sha1.c b/src/sha1.c index bd83a413..1b2abb2f 100644 --- a/src/sha1.c +++ b/src/sha1.c @@ -18,11 +18,32 @@ #include "wimlib/endianness.h" #include "wimlib/sha1.h" +#include "wimlib/unaligned.h" /* Dummy SHA-1 message digest of all 0's. This is used in the WIM format to * mean "SHA-1 not specified". */ const u8 zero_hash[20]; +/* + * Builds a hexadecimal string representation of a SHA-1 message digest. + * + * The output buffer must be at least 41 characters. + */ +void +sprint_hash(const u8 hash[SHA1_HASH_SIZE], tchar strbuf[SHA1_HASH_SIZE * 2 + 1]) +{ + int i; + u8 high, low; + + for (i = 0; i < SHA1_HASH_SIZE; i++) { + high = hash[i] >> 4; + low = hash[i] & 0xF; + strbuf[i * 2 + 0] = (high < 10 ? high + '0' : high - 10 + 'a'); + strbuf[i * 2 + 1] = (low < 10 ? low + '0' : low - 10 + 'a'); + } + strbuf[i * 2] = 0; +} + /* If we use libcrypto (e.g. OpenSSL) then we get all the SHA-1 functions for * free. Otherwise we need to implement them ourselves. */ @@ -183,13 +204,12 @@ sha1_final(u8 md[20], SHA_CTX *ctx) * final length is a multiple of the block size. */ static const u8 padding[64] = {0x80, }; be64 finalcount = cpu_to_be64(ctx->bytecount << 3); - be32 *out = (be32 *)md; sha1_update(ctx, padding, 64 - ((ctx->bytecount + 8) & 63)); sha1_update(ctx, &finalcount, 8); for (int i = 0; i < 5; i++) - out[i] = cpu_to_be32(ctx->state[i]); + store_be32_unaligned(cpu_to_be32(ctx->state[i]), &md[i * 4]); } /* Calculate the SHA-1 message digest of the specified buffer.