sha224 complete
This commit is contained in:
parent
752050aab3
commit
9c82b1fee3
10 changed files with 181 additions and 16 deletions
6
Makefile
6
Makefile
|
@ -57,7 +57,11 @@ SHA_SRC = ft_sha256_init.c \
|
||||||
ft_sha256_padding.c \
|
ft_sha256_padding.c \
|
||||||
ft_sha256_final.c \
|
ft_sha256_final.c \
|
||||||
ft_sha256_digest_string.c \
|
ft_sha256_digest_string.c \
|
||||||
ft_sha256_constants.c
|
ft_sha256_constants.c \
|
||||||
|
ft_sha224_init.c \
|
||||||
|
ft_sha224_update.c \
|
||||||
|
ft_sha224_final.c \
|
||||||
|
ft_sha224_digest_string.c
|
||||||
|
|
||||||
|
|
||||||
SRC = main.c
|
SRC = main.c
|
||||||
|
|
11
inc/ft_sha.h
11
inc/ft_sha.h
|
@ -10,6 +10,9 @@
|
||||||
# define FT_SHA256_STRING_SIZE_BYTE 65
|
# define FT_SHA256_STRING_SIZE_BYTE 65
|
||||||
# define FT_SHA256_REG_SIZE_BYTE 4
|
# define FT_SHA256_REG_SIZE_BYTE 4
|
||||||
|
|
||||||
|
# define FT_SHA224_DIGEST_LENGTH_BYTE 28
|
||||||
|
# define FT_SHA224_STRING_SIZE_BYTE 57
|
||||||
|
|
||||||
/* Define the SHA shift, rotate left, and rotate right macros */
|
/* Define the SHA shift, rotate left, and rotate right macros */
|
||||||
#define SHR(bits, word) ((word) >> (bits))
|
#define SHR(bits, word) ((word) >> (bits))
|
||||||
#define ROTL(bits, word) (((word) << (bits)) | ((word) >> (32 - (bits))))
|
#define ROTL(bits, word) (((word) << (bits)) | ((word) >> (32 - (bits))))
|
||||||
|
@ -55,10 +58,15 @@ typedef struct s_temp_registers
|
||||||
} t_temp_registers;
|
} t_temp_registers;
|
||||||
|
|
||||||
void ft_sha256_init(t_sha256_ctx *ctx);
|
void ft_sha256_init(t_sha256_ctx *ctx);
|
||||||
|
void ft_sha224_init(t_sha256_ctx *ctx);
|
||||||
void ft_sha256_update(t_sha256_ctx *ctx,
|
void ft_sha256_update(t_sha256_ctx *ctx,
|
||||||
BYTE1 *message, BYTE8 len);
|
BYTE1 *message, BYTE8 len);
|
||||||
|
void ft_sha224_update(t_sha256_ctx *ctx,
|
||||||
|
BYTE1 *message, BYTE8 len);
|
||||||
void ft_sha256_final(BYTE1 digest[FT_SHA256_DIGEST_LENGTH_BYTE],
|
void ft_sha256_final(BYTE1 digest[FT_SHA256_DIGEST_LENGTH_BYTE],
|
||||||
t_sha256_ctx *ctx);
|
t_sha256_ctx *ctx);
|
||||||
|
void ft_sha224_final(BYTE1 digest[FT_SHA256_DIGEST_LENGTH_BYTE],
|
||||||
|
t_sha256_ctx *ctx);
|
||||||
void ft_sha256_transform(t_sha256_ctx *ctx,
|
void ft_sha256_transform(t_sha256_ctx *ctx,
|
||||||
BYTE1 block[FT_SHA256_BLOCK_SIZE]);
|
BYTE1 block[FT_SHA256_BLOCK_SIZE]);
|
||||||
void ft_sha256_decode(BYTE4 w[FT_SHA256_WORDS_COUNT],
|
void ft_sha256_decode(BYTE4 w[FT_SHA256_WORDS_COUNT],
|
||||||
|
@ -71,6 +79,9 @@ void ft_sha256_padding(BYTE1 padding[FT_SHA256_BLOCK_SIZE]);
|
||||||
void ft_sha256_digest_string(
|
void ft_sha256_digest_string(
|
||||||
BYTE1 digest[FT_SHA256_DIGEST_LENGTH_BYTE],
|
BYTE1 digest[FT_SHA256_DIGEST_LENGTH_BYTE],
|
||||||
BYTE1 digst_string[FT_SHA256_STRING_SIZE_BYTE]);
|
BYTE1 digst_string[FT_SHA256_STRING_SIZE_BYTE]);
|
||||||
|
void ft_sha224_digest_string(
|
||||||
|
BYTE1 digest[FT_SHA224_DIGEST_LENGTH_BYTE],
|
||||||
|
BYTE1 digst_string[FT_SHA224_STRING_SIZE_BYTE]);
|
||||||
BYTE4 *ft_sha256_constants(void);
|
BYTE4 *ft_sha256_constants(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -24,6 +24,8 @@ CASE(fill_buffer_sha256);
|
||||||
CASE(add_right_padding_sha256);
|
CASE(add_right_padding_sha256);
|
||||||
CASE(compute_digest_sha256);
|
CASE(compute_digest_sha256);
|
||||||
CASE(create_digest_string_sha256);
|
CASE(create_digest_string_sha256);
|
||||||
|
CASE(should_init_ctx_sha224);
|
||||||
|
CASE(compute_digest_sha224);
|
||||||
|
CASE(create_digest_string_sha224);
|
||||||
|
|
||||||
#endif
|
#endif
|
43
src/sha/ft_sha224_digest_string.c
Normal file
43
src/sha/ft_sha224_digest_string.c
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
#include "ft_sha.h"
|
||||||
|
|
||||||
|
static void init_chars(BYTE1 chars[16])
|
||||||
|
{
|
||||||
|
chars[0] = '0';
|
||||||
|
chars[1] = '1';
|
||||||
|
chars[2] = '2';
|
||||||
|
chars[3] = '3';
|
||||||
|
chars[4] = '4';
|
||||||
|
chars[5] = '5';
|
||||||
|
chars[6] = '6';
|
||||||
|
chars[7] = '7';
|
||||||
|
chars[8] = '8';
|
||||||
|
chars[9] = '9';
|
||||||
|
chars[10] = 'a';
|
||||||
|
chars[11] = 'b';
|
||||||
|
chars[12] = 'c';
|
||||||
|
chars[13] = 'd';
|
||||||
|
chars[14] = 'e';
|
||||||
|
chars[15] = 'f';
|
||||||
|
}
|
||||||
|
|
||||||
|
void ft_sha224_digest_string
|
||||||
|
(
|
||||||
|
BYTE1 digest[FT_SHA224_DIGEST_LENGTH_BYTE],
|
||||||
|
BYTE1 string[FT_SHA224_STRING_SIZE_BYTE])
|
||||||
|
{
|
||||||
|
BYTE8 i;
|
||||||
|
BYTE8 j;
|
||||||
|
BYTE1 chars[16];
|
||||||
|
|
||||||
|
i = 0;
|
||||||
|
j = 0;
|
||||||
|
init_chars(chars);
|
||||||
|
while (i < FT_SHA224_DIGEST_LENGTH_BYTE)
|
||||||
|
{
|
||||||
|
string[j] = chars[digest[i] / 16];
|
||||||
|
string[j + 1] = chars[digest[i] % 16];
|
||||||
|
i++;
|
||||||
|
j += 2;
|
||||||
|
}
|
||||||
|
string[FT_SHA224_STRING_SIZE_BYTE - 1] = 0;
|
||||||
|
}
|
10
src/sha/ft_sha224_final.c
Normal file
10
src/sha/ft_sha224_final.c
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
#include "ft_sha.h"
|
||||||
|
|
||||||
|
void ft_sha224_final
|
||||||
|
(
|
||||||
|
BYTE1 digest[FT_SHA256_DIGEST_LENGTH_BYTE],
|
||||||
|
t_sha256_ctx *ctx
|
||||||
|
)
|
||||||
|
{
|
||||||
|
ft_sha256_final(digest, ctx);
|
||||||
|
}
|
17
src/sha/ft_sha224_init.c
Normal file
17
src/sha/ft_sha224_init.c
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
#include "ft_sha.h"
|
||||||
|
#include "libft.h"
|
||||||
|
|
||||||
|
void ft_sha224_init(t_sha256_ctx *ctx)
|
||||||
|
{
|
||||||
|
ctx->a = 0xc1059ed8;
|
||||||
|
ctx->b = 0x367cd507;
|
||||||
|
ctx->c = 0x3070dd17;
|
||||||
|
ctx->d = 0xf70e5939;
|
||||||
|
ctx->e = 0xffc00b31;
|
||||||
|
ctx->f = 0x68581511;
|
||||||
|
ctx->g = 0x64f98fa7;
|
||||||
|
ctx->h = 0xbefa4fa4;
|
||||||
|
|
||||||
|
ctx->bit_len = 0;
|
||||||
|
ft_bzero(ctx->block, FT_SHA256_BLOCK_SIZE);
|
||||||
|
}
|
6
src/sha/ft_sha224_update.c
Normal file
6
src/sha/ft_sha224_update.c
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
#include "ft_sha.h"
|
||||||
|
|
||||||
|
void ft_sha224_update(t_sha256_ctx *ctx, BYTE1 *message, BYTE8 len)
|
||||||
|
{
|
||||||
|
ft_sha256_update(ctx, message, len);
|
||||||
|
}
|
|
@ -36,5 +36,4 @@ void ft_sha256_final
|
||||||
ft_sha256_update(ctx, padding, padding_len);
|
ft_sha256_update(ctx, padding, padding_len);
|
||||||
ft_sha256_update(ctx, length_as_bytes, FT_SHA256_MESSAGE_LENGTH_BYTE);
|
ft_sha256_update(ctx, length_as_bytes, FT_SHA256_MESSAGE_LENGTH_BYTE);
|
||||||
fill_digest(digest, ctx);
|
fill_digest(digest, ctx);
|
||||||
// ft_bzero(ctx, sizeof(t_sha256_ctx));
|
|
||||||
}
|
}
|
|
@ -25,6 +25,29 @@ TEST_RESULT should_init_ctx_sha256(TEST_PARAMS, TEST_DATA)
|
||||||
return MUNIT_OK;
|
return MUNIT_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_RESULT should_init_ctx_sha224(TEST_PARAMS, TEST_DATA)
|
||||||
|
{
|
||||||
|
UNUSED(test_data);
|
||||||
|
UNUSED(test_params);
|
||||||
|
t_sha256_ctx ctx;
|
||||||
|
|
||||||
|
ft_sha224_init(&ctx);
|
||||||
|
|
||||||
|
munit_assert_uint(ctx.a, ==, 0xc1059ed8);
|
||||||
|
munit_assert_uint(ctx.b, ==, 0x367cd507);
|
||||||
|
munit_assert_uint(ctx.c, ==, 0x3070dd17);
|
||||||
|
munit_assert_uint(ctx.d, ==, 0xf70e5939);
|
||||||
|
munit_assert_uint(ctx.e, ==, 0xffc00b31);
|
||||||
|
munit_assert_uint(ctx.f, ==, 0x68581511);
|
||||||
|
munit_assert_uint(ctx.g, ==, 0x64f98fa7);
|
||||||
|
munit_assert_uint(ctx.h, ==, 0xbefa4fa4);
|
||||||
|
munit_assert_true(ctx.bit_len == 0);
|
||||||
|
for (int i = 0; i < 64; i++)
|
||||||
|
munit_assert_uchar(ctx.block[i], ==, 0);
|
||||||
|
|
||||||
|
return MUNIT_OK;
|
||||||
|
}
|
||||||
|
|
||||||
TEST_RESULT decode_string_to_int_sha256(TEST_PARAMS, TEST_DATA)
|
TEST_RESULT decode_string_to_int_sha256(TEST_PARAMS, TEST_DATA)
|
||||||
{
|
{
|
||||||
UNUSED(test_params);
|
UNUSED(test_params);
|
||||||
|
@ -191,6 +214,30 @@ TEST_RESULT compute_digest_sha256(TEST_PARAMS, TEST_DATA)
|
||||||
return MUNIT_OK;
|
return MUNIT_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_RESULT compute_digest_sha224(TEST_PARAMS, TEST_DATA)
|
||||||
|
{
|
||||||
|
UNUSED(test_data);
|
||||||
|
UNUSED(test_params);
|
||||||
|
|
||||||
|
BYTE1 message[] = "abc";
|
||||||
|
t_sha256_ctx ctx;
|
||||||
|
BYTE1 digest[FT_SHA256_DIGEST_LENGTH_BYTE];
|
||||||
|
|
||||||
|
ft_sha224_init(&ctx);
|
||||||
|
ft_sha224_update(&ctx, message, ft_strlen((const char *)message));
|
||||||
|
ft_sha224_final(digest, &ctx);
|
||||||
|
|
||||||
|
munit_assert_uint32(ctx.a, ==, 0x23097d22);
|
||||||
|
munit_assert_uint32(ctx.b, ==, 0x3405d822);
|
||||||
|
munit_assert_uint32(ctx.c, ==, 0x8642a477);
|
||||||
|
munit_assert_uint32(ctx.d, ==, 0xbda255b3);
|
||||||
|
munit_assert_uint32(ctx.e, ==, 0x2aadbce4);
|
||||||
|
munit_assert_uint32(ctx.f, ==, 0xbda0b3f7);
|
||||||
|
munit_assert_uint32(ctx.g, ==, 0xe36c9da7);
|
||||||
|
|
||||||
|
return MUNIT_OK;
|
||||||
|
}
|
||||||
|
|
||||||
TEST_RESULT create_digest_string_sha256(TEST_PARAMS, TEST_DATA)
|
TEST_RESULT create_digest_string_sha256(TEST_PARAMS, TEST_DATA)
|
||||||
{
|
{
|
||||||
UNUSED(test_data);
|
UNUSED(test_data);
|
||||||
|
@ -211,5 +258,28 @@ TEST_RESULT create_digest_string_sha256(TEST_PARAMS, TEST_DATA)
|
||||||
munit_assert_string_equal((const char *)message_digest,
|
munit_assert_string_equal((const char *)message_digest,
|
||||||
(const char *)digest_string);
|
(const char *)digest_string);
|
||||||
|
|
||||||
|
return MUNIT_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_RESULT create_digest_string_sha224(TEST_PARAMS, TEST_DATA)
|
||||||
|
{
|
||||||
|
UNUSED(test_data);
|
||||||
|
UNUSED(test_params);
|
||||||
|
|
||||||
|
BYTE1 message[] = "abc";
|
||||||
|
BYTE1 message_digest[] =
|
||||||
|
"23097d223405d8228642a477bda255b32aadbce4bda0b3f7e36c9da7";
|
||||||
|
t_sha256_ctx ctx;
|
||||||
|
BYTE1 digest[FT_SHA256_DIGEST_LENGTH_BYTE];
|
||||||
|
BYTE1 digest_string[FT_SHA224_STRING_SIZE_BYTE];
|
||||||
|
|
||||||
|
ft_sha224_init(&ctx);
|
||||||
|
ft_sha224_update(&ctx, message, ft_strlen((const char *)message));
|
||||||
|
ft_sha224_final(digest, &ctx);
|
||||||
|
ft_sha224_digest_string(digest, digest_string);
|
||||||
|
|
||||||
|
munit_assert_string_equal((const char *)message_digest,
|
||||||
|
(const char *)digest_string);
|
||||||
|
|
||||||
return MUNIT_OK;
|
return MUNIT_OK;
|
||||||
}
|
}
|
29
t/tests.c
29
t/tests.c
|
@ -12,31 +12,34 @@ MunitTest md5_tests[] = {
|
||||||
};
|
};
|
||||||
|
|
||||||
MunitTest sha_tests[] = {
|
MunitTest sha_tests[] = {
|
||||||
IT("/init_ctx", should_init_ctx_sha256, NULL, NULL, 0, NULL),
|
IT("/init_ctx_256", should_init_ctx_sha256, NULL, NULL, 0, NULL),
|
||||||
|
IT("/init_ctx_224", should_init_ctx_sha224, NULL, NULL, 0, NULL),
|
||||||
IT("/decode_string", decode_string_to_int_sha256, NULL, NULL, 0, NULL),
|
IT("/decode_string", decode_string_to_int_sha256, NULL, NULL, 0, NULL),
|
||||||
IT("/encode_len", encode_len_to_string_sha256, NULL, NULL, 0, NULL),
|
IT("/encode_len", encode_len_to_string_sha256, NULL, NULL, 0, NULL),
|
||||||
IT("/enc_register", encode_register_to_string_sha256, NULL, NULL, 0, NULL),
|
IT("/enc_register", encode_register_to_string_sha256, NULL, NULL, 0, NULL),
|
||||||
IT("/update_bit_count", update_bit_count_sha256, NULL, NULL, 0, NULL),
|
IT("/update_bit_count", update_bit_count_sha256, NULL, NULL, 0, NULL),
|
||||||
IT("/fill_buffer", fill_buffer_sha256, NULL, NULL, 0, NULL),
|
IT("/fill_buffer", fill_buffer_sha256, NULL, NULL, 0, NULL),
|
||||||
IT("/add_right_padding", add_right_padding_sha256, NULL, NULL, 0, NULL),
|
IT("/add_right_padding", add_right_padding_sha256, NULL, NULL, 0, NULL),
|
||||||
IT("/compute_digest", compute_digest_sha256, NULL, NULL, 0, NULL),
|
IT("/compute_digest_256", compute_digest_sha256, NULL, NULL, 0, NULL),
|
||||||
IT("/creates_string", create_digest_string_sha256, NULL, NULL, 0, NULL),
|
IT("/compute_digest_224", compute_digest_sha224, NULL, NULL, 0, NULL),
|
||||||
|
IT("/creates_string_256", create_digest_string_sha256, NULL, NULL, 0, NULL),
|
||||||
|
IT("/creates_string_224", create_digest_string_sha224, NULL, NULL, 0, NULL),
|
||||||
END_IT};
|
END_IT};
|
||||||
|
|
||||||
static const MunitSuite ft_ssl_suites[] = {
|
static const MunitSuite ft_ssl_suites[] = {
|
||||||
{
|
{
|
||||||
(char *)"/md5_suite", /* name */
|
(char *)"/md5_suite", /* name */
|
||||||
md5_tests, /* tests */
|
md5_tests, /* tests */
|
||||||
NULL, /* suites */
|
NULL, /* suites */
|
||||||
1, /* iterations */
|
1, /* iterations */
|
||||||
MUNIT_SUITE_OPTION_NONE /* options */
|
MUNIT_SUITE_OPTION_NONE /* options */
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
(char *)"/sha_suite", /* name */
|
(char *)"/sha_suite", /* name */
|
||||||
sha_tests, /* tests */
|
sha_tests, /* tests */
|
||||||
NULL, /* suites */
|
NULL, /* suites */
|
||||||
1, /* iterations */
|
1, /* iterations */
|
||||||
MUNIT_SUITE_OPTION_NONE /* options */
|
MUNIT_SUITE_OPTION_NONE /* options */
|
||||||
},
|
},
|
||||||
{NULL, NULL, NULL, 0, MUNIT_SUITE_OPTION_NONE}
|
{NULL, NULL, NULL, 0, MUNIT_SUITE_OPTION_NONE}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue