blob: 7349517a41e35f54b3b42568f9e7eb3b81db345d [file] [log] [blame]
Paul Bakker0e04d0e2011-11-27 14:46:59 +00001BEGIN_HEADER
2#include <polarssl/ctr_drbg.h>
3
4int test_offset;
5int entropy_func( void *p, unsigned char *buf, size_t len )
6{
7 memcpy( buf, p + test_offset, len );
8 test_offset += 32;
9 return( 0 );
10}
Paul Bakker18d32912011-12-10 21:42:49 +000011
12int ctr_drbg_init_entropy_len(
13 ctr_drbg_context *ctx,
14 int (*f_entropy)(void *, unsigned char *, size_t),
15 void *p_entropy,
16 const unsigned char *custom,
17 size_t len,
18 size_t entropy_len );
Paul Bakker0e04d0e2011-11-27 14:46:59 +000019END_HEADER
20
21BEGIN_DEPENDENCIES
22depends_on:POLARSSL_CTR_DRBG_C
23END_DEPENDENCIES
24
25BEGIN_CASE
26ctr_drbg_validate_pr:add_init_string:entropy_string:add1_string:add2_string:result_str
27{
28 unsigned char entropy[512];
29 unsigned char add_init[512];
30 unsigned char add1[512];
31 unsigned char add2[512];
32 ctr_drbg_context ctx;
33 unsigned char buf[512];
34 unsigned char output_str[512];
35 int add_init_len, add1_len, add2_len;
36
37 memset( output_str, 0, 512 );
38
39 unhexify( entropy, {entropy_string} );
40 add_init_len = unhexify( add_init, {add_init_string} );
41 add1_len = unhexify( add1, {add1_string} );
42 add2_len = unhexify( add2, {add2_string} );
43
44 test_offset = 0;
Paul Bakker18d32912011-12-10 21:42:49 +000045 TEST_ASSERT( ctr_drbg_init_entropy_len( &ctx, entropy_func, entropy, add_init, add_init_len, 32 ) == 0 );
Paul Bakker0e04d0e2011-11-27 14:46:59 +000046 ctr_drbg_set_prediction_resistance( &ctx, CTR_DRBG_PR_ON );
47
48 TEST_ASSERT( ctr_drbg_random_with_add( &ctx, buf, 16, add1, add1_len ) == 0 );
49 TEST_ASSERT( ctr_drbg_random_with_add( &ctx, buf, 16, add2, add2_len ) == 0 );
50 hexify( output_str, buf, 16 );
51 TEST_ASSERT( strcmp( (char *) output_str, {result_str} ) == 0 );
52}
53END_CASE
54
55BEGIN_CASE
56ctr_drbg_validate_nopr:add_init_string:entropy_string:add1_string:add_reseed_string:add2_string:result_str
57{
58 unsigned char entropy[512];
59 unsigned char add_init[512];
60 unsigned char add1[512];
61 unsigned char add_reseed[512];
62 unsigned char add2[512];
63 ctr_drbg_context ctx;
64 unsigned char buf[512];
65 unsigned char output_str[512];
66 int add_init_len, add1_len, add_reseed_len, add2_len;
67
68 memset( output_str, 0, 512 );
69
70 unhexify( entropy, {entropy_string} );
71 add_init_len = unhexify( add_init, {add_init_string} );
72 add1_len = unhexify( add1, {add1_string} );
73 add_reseed_len = unhexify( add_reseed, {add_reseed_string} );
74 add2_len = unhexify( add2, {add2_string} );
75
76 test_offset = 0;
Paul Bakker18d32912011-12-10 21:42:49 +000077 TEST_ASSERT( ctr_drbg_init_entropy_len( &ctx, entropy_func, entropy, add_init, add_init_len, 32 ) == 0 );
Paul Bakker0e04d0e2011-11-27 14:46:59 +000078
79 TEST_ASSERT( ctr_drbg_random_with_add( &ctx, buf, 16, add1, add1_len ) == 0 );
80 TEST_ASSERT( ctr_drbg_reseed( &ctx, add_reseed, add_reseed_len ) == 0 );
81 TEST_ASSERT( ctr_drbg_random_with_add( &ctx, buf, 16, add2, add2_len ) == 0 );
82 hexify( output_str, buf, 16 );
83 TEST_ASSERT( strcmp( (char *) output_str, {result_str} ) == 0 );
84}
85END_CASE