- Added CTR_DRBG based on AES-256-CTR (NIST SP 800-90) random generator

diff --git a/tests/suites/test_suite_ctr_drbg.function b/tests/suites/test_suite_ctr_drbg.function
new file mode 100644
index 0000000..e817658
--- /dev/null
+++ b/tests/suites/test_suite_ctr_drbg.function
@@ -0,0 +1,77 @@
+BEGIN_HEADER
+#include <polarssl/ctr_drbg.h>
+
+int test_offset;
+int entropy_func( void *p, unsigned char *buf, size_t len )
+{
+    memcpy( buf, p + test_offset, len );
+    test_offset += 32;
+    return( 0 );
+}
+END_HEADER
+
+BEGIN_DEPENDENCIES
+depends_on:POLARSSL_CTR_DRBG_C
+END_DEPENDENCIES
+
+BEGIN_CASE
+ctr_drbg_validate_pr:add_init_string:entropy_string:add1_string:add2_string:result_str
+{
+    unsigned char entropy[512];
+    unsigned char add_init[512];
+    unsigned char add1[512];
+    unsigned char add2[512];
+    ctr_drbg_context ctx;
+    unsigned char buf[512];
+    unsigned char output_str[512];
+    int add_init_len, add1_len, add2_len;
+
+    memset( output_str, 0, 512 );
+
+    unhexify( entropy, {entropy_string} );
+    add_init_len = unhexify( add_init, {add_init_string} );
+    add1_len = unhexify( add1, {add1_string} );
+    add2_len = unhexify( add2, {add2_string} );
+
+    test_offset = 0;
+    TEST_ASSERT( ctr_drbg_init( &ctx, entropy_func, entropy, add_init, add_init_len ) == 0 );
+    ctr_drbg_set_prediction_resistance( &ctx, CTR_DRBG_PR_ON );
+
+    TEST_ASSERT( ctr_drbg_random_with_add( &ctx, buf, 16, add1, add1_len ) == 0 );
+    TEST_ASSERT( ctr_drbg_random_with_add( &ctx, buf, 16, add2, add2_len ) == 0 );
+    hexify( output_str, buf, 16 );
+    TEST_ASSERT( strcmp( (char *) output_str, {result_str} ) == 0 );
+}
+END_CASE
+
+BEGIN_CASE
+ctr_drbg_validate_nopr:add_init_string:entropy_string:add1_string:add_reseed_string:add2_string:result_str
+{
+    unsigned char entropy[512];
+    unsigned char add_init[512];
+    unsigned char add1[512];
+    unsigned char add_reseed[512];
+    unsigned char add2[512];
+    ctr_drbg_context ctx;
+    unsigned char buf[512];
+    unsigned char output_str[512];
+    int add_init_len, add1_len, add_reseed_len, add2_len;
+
+    memset( output_str, 0, 512 );
+
+    unhexify( entropy, {entropy_string} );
+    add_init_len = unhexify( add_init, {add_init_string} );
+    add1_len = unhexify( add1, {add1_string} );
+    add_reseed_len = unhexify( add_reseed, {add_reseed_string} );
+    add2_len = unhexify( add2, {add2_string} );
+
+    test_offset = 0;
+    TEST_ASSERT( ctr_drbg_init( &ctx, entropy_func, entropy, add_init, add_init_len ) == 0 );
+
+    TEST_ASSERT( ctr_drbg_random_with_add( &ctx, buf, 16, add1, add1_len ) == 0 );
+    TEST_ASSERT( ctr_drbg_reseed( &ctx, add_reseed, add_reseed_len ) == 0 );
+    TEST_ASSERT( ctr_drbg_random_with_add( &ctx, buf, 16, add2, add2_len ) == 0 );
+    hexify( output_str, buf, 16 );
+    TEST_ASSERT( strcmp( (char *) output_str, {result_str} ) == 0 );
+}
+END_CASE