| Manuel Pégourié-Gonnard | 6801f39 | 2014-01-30 17:22:14 +0100 | [diff] [blame^] | 1 | /* BEGIN_HEADER */ | 
|  | 2 | #include <polarssl/hmac_drbg.h> | 
|  | 3 |  | 
|  | 4 | typedef struct | 
|  | 5 | { | 
|  | 6 | unsigned char *p; | 
|  | 7 | size_t len; | 
|  | 8 | } entropy_ctx; | 
|  | 9 |  | 
|  | 10 | int entropy_func( void *data, unsigned char *buf, size_t len ) | 
|  | 11 | { | 
|  | 12 | entropy_ctx *ctx = (entropy_ctx *) data; | 
|  | 13 |  | 
|  | 14 | if( len > ctx->len ) | 
|  | 15 | return( -1 ); | 
|  | 16 |  | 
|  | 17 | memcpy( buf, ctx->p, len ); | 
|  | 18 |  | 
|  | 19 | ctx->p += len; | 
|  | 20 | ctx->len -= len; | 
|  | 21 |  | 
|  | 22 | return( 0 ); | 
|  | 23 | } | 
|  | 24 | /* END_HEADER */ | 
|  | 25 |  | 
|  | 26 | /* BEGIN_DEPENDENCIES | 
|  | 27 | * depends_on:POLARSSL_HMAC_DRBG_C | 
|  | 28 | * END_DEPENDENCIES | 
|  | 29 | */ | 
|  | 30 |  | 
|  | 31 | /* BEGIN_CASE */ | 
|  | 32 | void hmac_drbg_no_reseed( int md_alg, | 
|  | 33 | char *entropy_hex, char *custom_hex, | 
|  | 34 | char *add1_hex, char *add2_hex, | 
|  | 35 | char *output_hex ) | 
|  | 36 | { | 
|  | 37 | unsigned char entropy[512]; | 
|  | 38 | unsigned char custom[512]; | 
|  | 39 | unsigned char add1[512]; | 
|  | 40 | unsigned char add2[512]; | 
|  | 41 | unsigned char output[512]; | 
|  | 42 | unsigned char my_output[512]; | 
|  | 43 | size_t custom_len, add1_len, add2_len, out_len; | 
|  | 44 | entropy_ctx p_entropy; | 
|  | 45 | const md_info_t *md_info; | 
|  | 46 | hmac_drbg_context ctx; | 
|  | 47 |  | 
|  | 48 | memset( my_output, 0, sizeof my_output ); | 
|  | 49 |  | 
|  | 50 | custom_len = unhexify( custom, custom_hex ); | 
|  | 51 | add1_len = unhexify( add1, add1_hex ); | 
|  | 52 | add2_len = unhexify( add2, add2_hex ); | 
|  | 53 | out_len = unhexify( output, output_hex ); | 
|  | 54 | p_entropy.len = unhexify( entropy, entropy_hex ); | 
|  | 55 | p_entropy.p = entropy; | 
|  | 56 |  | 
|  | 57 | TEST_ASSERT( ( md_info = md_info_from_type( md_alg ) ) != NULL ); | 
|  | 58 | TEST_ASSERT( hmac_drbg_init( &ctx, md_info, entropy_func, &p_entropy, | 
|  | 59 | custom, custom_len ) == 0 ); | 
|  | 60 | TEST_ASSERT( hmac_drbg_random_with_add( &ctx, my_output, out_len, | 
|  | 61 | add1, add1_len ) == 0 ); | 
|  | 62 | TEST_ASSERT( hmac_drbg_random_with_add( &ctx, my_output, out_len, | 
|  | 63 | add2, add2_len ) == 0 ); | 
|  | 64 | hmac_drbg_free( &ctx ); | 
|  | 65 |  | 
|  | 66 | /* Check output is correct */ | 
|  | 67 | TEST_ASSERT( memcmp( my_output, output, out_len ) == 0 ); | 
|  | 68 |  | 
|  | 69 | /* Check we didn't write more bytes than needed */ | 
|  | 70 | TEST_ASSERT( my_output[out_len + 0] == 0 ); | 
|  | 71 | TEST_ASSERT( my_output[out_len + 1] == 0 ); | 
|  | 72 | TEST_ASSERT( my_output[out_len + 2] == 0 ); | 
|  | 73 | TEST_ASSERT( my_output[out_len + 3] == 0 ); | 
|  | 74 | } | 
|  | 75 | /* END_CASE */ | 
|  | 76 |  |