Sophie

Sophie

distrib > Mageia > 4 > x86_64 > by-pkgid > 9e72f3e7ecf68cce016a7c5c59e863d3 > files > 1013

lib64polarssl-devel-1.3.8-1.mga4.x86_64.rpm

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.5"/>
<title>PolarSSL v1.3.8: test_suite_ctr_drbg.c File Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td style="padding-left: 0.5em;">
   <div id="projectname">PolarSSL v1.3.8
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.5 -->
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="modules.html"><span>Modules</span></a></li>
      <li><a href="annotated.html"><span>Data&#160;Structures</span></a></li>
      <li class="current"><a href="files.html"><span>Files</span></a></li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="files.html"><span>File&#160;List</span></a></li>
      <li><a href="globals.html"><span>Globals</span></a></li>
    </ul>
  </div>
<div id="nav-path" class="navpath">
  <ul>
<li class="navelem"><a class="el" href="dir_4f509e352d63276a36e2e40095d881a8.html">build</a></li><li class="navelem"><a class="el" href="dir_5a04b5d5ef3d0213b7570e3504db7e76.html">tests</a></li>  </ul>
</div>
</div><!-- top -->
<div class="header">
  <div class="summary">
<a href="#nested-classes">Data Structures</a> &#124;
<a href="#define-members">Macros</a> &#124;
<a href="#func-members">Functions</a> &#124;
<a href="#var-members">Variables</a>  </div>
  <div class="headertitle">
<div class="title">test_suite_ctr_drbg.c File Reference</div>  </div>
</div><!--header-->
<div class="contents">
<div class="textblock"><code>#include &lt;<a class="el" href="config_8h_source.html">polarssl/config.h</a>&gt;</code><br/>
<code>#include &lt;inttypes.h&gt;</code><br/>
<code>#include &lt;assert.h&gt;</code><br/>
<code>#include &lt;stdlib.h&gt;</code><br/>
<code>#include &lt;string.h&gt;</code><br/>
<code>#include &lt;stdio.h&gt;</code><br/>
</div><div class="textblock"><div class="dynheader">
Include dependency graph for test_suite_ctr_drbg.c:</div>
<div class="dyncontent">
<div class="center"><img src="test__suite__ctr__drbg_8c__incl.png" border="0" usemap="#test__suite__ctr__drbg_8c" alt=""/></div>
<map name="test__suite__ctr__drbg_8c" id="test__suite__ctr__drbg_8c">
</map>
</div>
</div>
<p><a href="test__suite__ctr__drbg_8c_source.html">Go to the source code of this file.</a></p>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="nested-classes"></a>
Data Structures</h2></td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structrnd__buf__info.html">rnd_buf_info</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structrnd__pseudo__info.html">rnd_pseudo_info</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Info structure for the pseudo random function.  <a href="structrnd__pseudo__info.html#details">More...</a><br/></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="define-members"></a>
Macros</h2></td></tr>
<tr class="memitem:a2a0cfb9e59f28e2a1a5fd1880fb20d4b"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a2a0cfb9e59f28e2a1a5fd1880fb20d4b">polarssl_malloc</a>&#160;&#160;&#160;malloc</td></tr>
<tr class="separator:a2a0cfb9e59f28e2a1a5fd1880fb20d4b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3c8219c194813f302bf78fe73566cb2d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a3c8219c194813f302bf78fe73566cb2d">polarssl_free</a>&#160;&#160;&#160;free</td></tr>
<tr class="separator:a3c8219c194813f302bf78fe73566cb2d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a37e0e1a97807195e2de54fd6487751d3"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a37e0e1a97807195e2de54fd6487751d3">GET_UINT32_BE</a>(n, b, i)</td></tr>
<tr class="separator:a37e0e1a97807195e2de54fd6487751d3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a4671795996d0aae650c87a82bca7b880"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a4671795996d0aae650c87a82bca7b880">PUT_UINT32_BE</a>(n, b, i)</td></tr>
<tr class="separator:a4671795996d0aae650c87a82bca7b880"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afc6a7362c0f0c9cfa8fc76b3281e2b37"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#afc6a7362c0f0c9cfa8fc76b3281e2b37">polarssl_printf</a>&#160;&#160;&#160;printf</td></tr>
<tr class="separator:afc6a7362c0f0c9cfa8fc76b3281e2b37"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2a0cfb9e59f28e2a1a5fd1880fb20d4b"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a2a0cfb9e59f28e2a1a5fd1880fb20d4b">polarssl_malloc</a>&#160;&#160;&#160;malloc</td></tr>
<tr class="separator:a2a0cfb9e59f28e2a1a5fd1880fb20d4b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3c8219c194813f302bf78fe73566cb2d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a3c8219c194813f302bf78fe73566cb2d">polarssl_free</a>&#160;&#160;&#160;free</td></tr>
<tr class="separator:a3c8219c194813f302bf78fe73566cb2d"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
Functions</h2></td></tr>
<tr class="memitem:a8e923080751a9d1549322c6e29831f2b"><td class="memItemLeft" align="right" valign="top">static int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a8e923080751a9d1549322c6e29831f2b">unhexify</a> (unsigned char *obuf, const char *ibuf)</td></tr>
<tr class="separator:a8e923080751a9d1549322c6e29831f2b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2bbbdbb793443cd7030f6de781fdb24c"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a2bbbdbb793443cd7030f6de781fdb24c">hexify</a> (unsigned char *obuf, const unsigned char *ibuf, int len)</td></tr>
<tr class="separator:a2bbbdbb793443cd7030f6de781fdb24c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0e6bb0f08219d2533686a051671ea136"><td class="memItemLeft" align="right" valign="top">static unsigned char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a0e6bb0f08219d2533686a051671ea136">zero_alloc</a> (size_t len)</td></tr>
<tr class="memdesc:a0e6bb0f08219d2533686a051671ea136"><td class="mdescLeft">&#160;</td><td class="mdescRight">Allocate and zeroize a buffer.  <a href="#a0e6bb0f08219d2533686a051671ea136">More...</a><br/></td></tr>
<tr class="separator:a0e6bb0f08219d2533686a051671ea136"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac697d22aa551723b8a5c53513142083e"><td class="memItemLeft" align="right" valign="top">static unsigned char *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#ac697d22aa551723b8a5c53513142083e">unhexify_alloc</a> (const char *ibuf, size_t *olen)</td></tr>
<tr class="memdesc:ac697d22aa551723b8a5c53513142083e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Allocate and fill a buffer from hex data.  <a href="#ac697d22aa551723b8a5c53513142083e">More...</a><br/></td></tr>
<tr class="separator:ac697d22aa551723b8a5c53513142083e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab5dc647984c24a80195e8d196ca7daea"><td class="memItemLeft" align="right" valign="top">static int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#ab5dc647984c24a80195e8d196ca7daea">rnd_std_rand</a> (void *rng_state, unsigned char *output, size_t len)</td></tr>
<tr class="memdesc:ab5dc647984c24a80195e8d196ca7daea"><td class="mdescLeft">&#160;</td><td class="mdescRight">This function just returns data from rand().  <a href="#ab5dc647984c24a80195e8d196ca7daea">More...</a><br/></td></tr>
<tr class="separator:ab5dc647984c24a80195e8d196ca7daea"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af55f96a58bf1b4a5cf1c887f3f7da756"><td class="memItemLeft" align="right" valign="top">static int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#af55f96a58bf1b4a5cf1c887f3f7da756">rnd_zero_rand</a> (void *rng_state, unsigned char *output, size_t len)</td></tr>
<tr class="memdesc:af55f96a58bf1b4a5cf1c887f3f7da756"><td class="mdescLeft">&#160;</td><td class="mdescRight">This function only returns zeros.  <a href="#af55f96a58bf1b4a5cf1c887f3f7da756">More...</a><br/></td></tr>
<tr class="separator:af55f96a58bf1b4a5cf1c887f3f7da756"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a805c6ac51b5b7de9dba4d8e16f74b492"><td class="memItemLeft" align="right" valign="top">static int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a805c6ac51b5b7de9dba4d8e16f74b492">rnd_buffer_rand</a> (void *rng_state, unsigned char *output, size_t len)</td></tr>
<tr class="memdesc:a805c6ac51b5b7de9dba4d8e16f74b492"><td class="mdescLeft">&#160;</td><td class="mdescRight">This function returns random based on a buffer it receives.  <a href="#a805c6ac51b5b7de9dba4d8e16f74b492">More...</a><br/></td></tr>
<tr class="separator:a805c6ac51b5b7de9dba4d8e16f74b492"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a497e9778400622edb18bc8f91e1ae247"><td class="memItemLeft" align="right" valign="top">static int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a497e9778400622edb18bc8f91e1ae247">rnd_pseudo_rand</a> (void *rng_state, unsigned char *output, size_t len)</td></tr>
<tr class="memdesc:a497e9778400622edb18bc8f91e1ae247"><td class="mdescLeft">&#160;</td><td class="mdescRight">This function returns random based on a pseudo random function.  <a href="#a497e9778400622edb18bc8f91e1ae247">More...</a><br/></td></tr>
<tr class="separator:a497e9778400622edb18bc8f91e1ae247"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a17715f24511880554adfaa3bb3fb78c8"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a17715f24511880554adfaa3bb3fb78c8">dep_check</a> (char *str)</td></tr>
<tr class="separator:a17715f24511880554adfaa3bb3fb78c8"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a29dbb5eb8f02ffc96025e8fe2cc425a4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a29dbb5eb8f02ffc96025e8fe2cc425a4">dispatch_test</a> (int cnt, char *params[50])</td></tr>
<tr class="separator:a29dbb5eb8f02ffc96025e8fe2cc425a4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6a746923d2acc242d80c5337ba4ef440"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a6a746923d2acc242d80c5337ba4ef440">get_line</a> (FILE *f, char *buf, size_t len)</td></tr>
<tr class="separator:a6a746923d2acc242d80c5337ba4ef440"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3654c0e70995844871b42a55014e3a69"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a3654c0e70995844871b42a55014e3a69">parse_arguments</a> (char *buf, size_t len, char *params[50])</td></tr>
<tr class="separator:a3654c0e70995844871b42a55014e3a69"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr>
<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="var-members"></a>
Variables</h2></td></tr>
<tr class="memitem:a6fba163c212fa9a84ae7f4f519639d37"><td class="memItemLeft" align="right" valign="top">static int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="test__suite__ctr__drbg_8c.html#a6fba163c212fa9a84ae7f4f519639d37">test_errors</a> = 0</td></tr>
<tr class="separator:a6fba163c212fa9a84ae7f4f519639d37"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<h2 class="groupheader">Macro Definition Documentation</h2>
<a class="anchor" id="a37e0e1a97807195e2de54fd6487751d3"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define GET_UINT32_BE</td>
          <td>(</td>
          <td class="paramtype">&#160;</td>
          <td class="paramname">n, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">&#160;</td>
          <td class="paramname">b, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">&#160;</td>
          <td class="paramname">i&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">
<b>Value:</b><div class="fragment"><div class="line">{                                                       \</div>
<div class="line">    (n) = ( (uint32_t) (b)[(i)    ] &lt;&lt; 24 )             \</div>
<div class="line">        | ( (uint32_t) (b)[(i) + 1] &lt;&lt; 16 )             \</div>
<div class="line">        | ( (uint32_t) (b)[(i) + 2] &lt;&lt;  8 )             \</div>
<div class="line">        | ( (uint32_t) (b)[(i) + 3]       );            \</div>
<div class="line">}</div>
</div><!-- fragment -->
<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00048">48</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="a3c8219c194813f302bf78fe73566cb2d"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define polarssl_free&#160;&#160;&#160;free</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00320">320</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="a3c8219c194813f302bf78fe73566cb2d"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define polarssl_free&#160;&#160;&#160;free</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00320">320</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="a2a0cfb9e59f28e2a1a5fd1880fb20d4b"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define polarssl_malloc&#160;&#160;&#160;malloc</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00319">319</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="a2a0cfb9e59f28e2a1a5fd1880fb20d4b"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define polarssl_malloc&#160;&#160;&#160;malloc</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00319">319</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="afc6a7362c0f0c9cfa8fc76b3281e2b37"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define polarssl_printf&#160;&#160;&#160;printf</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00318">318</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="a4671795996d0aae650c87a82bca7b880"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define PUT_UINT32_BE</td>
          <td>(</td>
          <td class="paramtype">&#160;</td>
          <td class="paramname">n, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">&#160;</td>
          <td class="paramname">b, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">&#160;</td>
          <td class="paramname">i&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">
<b>Value:</b><div class="fragment"><div class="line">{                                                       \</div>
<div class="line">    (b)[(i)    ] = (<span class="keywordtype">unsigned</span> char) ( (n) &gt;&gt; 24 );       \</div>
<div class="line">    (b)[(i) + 1] = (<span class="keywordtype">unsigned</span> char) ( (n) &gt;&gt; 16 );       \</div>
<div class="line">    (b)[(i) + 2] = (<span class="keywordtype">unsigned</span> char) ( (n) &gt;&gt;  8 );       \</div>
<div class="line">    (b)[(i) + 3] = (<span class="keywordtype">unsigned</span> char) ( (n)       );       \</div>
<div class="line">}</div>
</div><!-- fragment -->
<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00058">58</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

<p>Referenced by <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00279">rnd_pseudo_rand()</a>.</p>

</div>
</div>
<h2 class="groupheader">Function Documentation</h2>
<a class="anchor" id="a17715f24511880554adfaa3bb3fb78c8"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int dep_check </td>
          <td>(</td>
          <td class="paramtype">char *&#160;</td>
          <td class="paramname"><em>str</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00584">584</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="a29dbb5eb8f02ffc96025e8fe2cc425a4"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int dispatch_test </td>
          <td>(</td>
          <td class="paramtype">int&#160;</td>
          <td class="paramname"><em>cnt</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char *&#160;</td>
          <td class="paramname"><em>params</em>[50]&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00594">594</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

<p>References <a class="el" href="test__suite__hmac__shax_8c_source.html#l00352">verify_int()</a>, and <a class="el" href="test__suite__hmac__shax_8c_source.html#l00337">verify_string()</a>.</p>

</div>
</div>
<a class="anchor" id="a6a746923d2acc242d80c5337ba4ef440"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int get_line </td>
          <td>(</td>
          <td class="paramtype">FILE *&#160;</td>
          <td class="paramname"><em>f</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char *&#160;</td>
          <td class="paramname"><em>buf</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>len</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00728">728</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="a2bbbdbb793443cd7030f6de781fdb24c"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">static void hexify </td>
          <td>(</td>
          <td class="paramtype">unsigned char *&#160;</td>
          <td class="paramname"><em>obuf</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const unsigned char *&#160;</td>
          <td class="paramname"><em>ibuf</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">int&#160;</td>
          <td class="paramname"><em>len</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00101">101</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="ae66f6b31b5ad750f1fe042a706a4e3d4"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int main </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00805">805</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

<p>References <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00692">dep_check()</a>, <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00702">dispatch_test()</a>, <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00956">get_line()</a>, <a class="el" href="memory__buffer__alloc_8h.html#a422e29785ed0ae2e31ca9688a0f18267">memory_buffer_alloc_free()</a>, <a class="el" href="memory__buffer__alloc_8h.html#af2745e4cbfe3339911913ed02dccce91">memory_buffer_alloc_init()</a>, and <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00972">parse_arguments()</a>.</p>

</div>
</div>
<a class="anchor" id="a3654c0e70995844871b42a55014e3a69"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int parse_arguments </td>
          <td>(</td>
          <td class="paramtype">char *&#160;</td>
          <td class="paramname"><em>buf</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>len</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">char *&#160;</td>
          <td class="paramname"><em>params</em>[50]&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00744">744</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="a805c6ac51b5b7de9dba4d8e16f74b492"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">static int rnd_buffer_rand </td>
          <td>(</td>
          <td class="paramtype">void *&#160;</td>
          <td class="paramname"><em>rng_state</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">unsigned char *&#160;</td>
          <td class="paramname"><em>output</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>len</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>This function returns random based on a buffer it receives. </p>
<p>rng_state shall be a pointer to a <a class="el" href="structrnd__buf__info.html">rnd_buf_info</a> structure.</p>
<p>The number of bytes released from the buffer on each call to the random function is specified by per_call. (Can be between 1 and 4)</p>
<p>After the buffer is empty it will return rand(); </p>

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00233">233</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

<p>References <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00209">rnd_buf_info::buf</a>, <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00210">rnd_buf_info::length</a>, and <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00181">rnd_std_rand()</a>.</p>

</div>
</div>
<a class="anchor" id="a497e9778400622edb18bc8f91e1ae247"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">static int rnd_pseudo_rand </td>
          <td>(</td>
          <td class="paramtype">void *&#160;</td>
          <td class="paramname"><em>rng_state</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">unsigned char *&#160;</td>
          <td class="paramname"><em>output</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>len</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>This function returns random based on a pseudo random function. </p>
<p>This means the results should be identical on all systems. Pseudo random is based on the XTEA encryption algorithm to generate pseudorandom.</p>
<p>rng_state shall be a pointer to a <a class="el" href="structrnd__pseudo__info.html" title="Info structure for the pseudo random function. ">rnd_pseudo_info</a> structure. </p>

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00279">279</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

<p>References <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00258">rnd_pseudo_info::key</a>, <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00058">PUT_UINT32_BE</a>, <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00181">rnd_std_rand()</a>, <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00259">rnd_pseudo_info::v0</a>, and <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00259">rnd_pseudo_info::v1</a>.</p>

</div>
</div>
<a class="anchor" id="ab5dc647984c24a80195e8d196ca7daea"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">static int rnd_std_rand </td>
          <td>(</td>
          <td class="paramtype">void *&#160;</td>
          <td class="paramname"><em>rng_state</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">unsigned char *&#160;</td>
          <td class="paramname"><em>output</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>len</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>This function just returns data from rand(). </p>
<p>Although predictable and often similar on multiple runs, this does not result in identical random on each run. So do not use this if the results of a test depend on the random data that is generated.</p>
<p>rng_state shall be NULL. </p>

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00181">181</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

<p>Referenced by <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00233">rnd_buffer_rand()</a>, and <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00279">rnd_pseudo_rand()</a>.</p>

</div>
</div>
<a class="anchor" id="af55f96a58bf1b4a5cf1c887f3f7da756"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">static int rnd_zero_rand </td>
          <td>(</td>
          <td class="paramtype">void *&#160;</td>
          <td class="paramname"><em>rng_state</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">unsigned char *&#160;</td>
          <td class="paramname"><em>output</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>len</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>This function only returns zeros. </p>
<p>rng_state shall be NULL. </p>

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00206">206</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
<a class="anchor" id="a8e923080751a9d1549322c6e29831f2b"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">static int unhexify </td>
          <td>(</td>
          <td class="paramtype">unsigned char *&#160;</td>
          <td class="paramname"><em>obuf</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>ibuf</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00067">67</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

<p>Referenced by <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00155">unhexify_alloc()</a>.</p>

</div>
</div>
<a class="anchor" id="ac697d22aa551723b8a5c53513142083e"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">static unsigned char* unhexify_alloc </td>
          <td>(</td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>ibuf</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t *&#160;</td>
          <td class="paramname"><em>olen</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Allocate and fill a buffer from hex data. </p>
<p>The buffer is sized exactly as needed. This allows to detect buffer overruns (including overreads) when running the test suite under valgrind.</p>
<p>If the size if zero, a pointer to a zeroized 1-byte buffer is returned.</p>
<p>For convenience, dies if allocation fails. </p>

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00155">155</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

<p>References <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00310">polarssl_malloc</a>, <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00067">unhexify()</a>, and <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00132">zero_alloc()</a>.</p>

</div>
</div>
<a class="anchor" id="a0e6bb0f08219d2533686a051671ea136"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">static unsigned char* zero_alloc </td>
          <td>(</td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>len</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Allocate and zeroize a buffer. </p>
<p>If the size if zero, a pointer to a zeroized 1-byte buffer is returned.</p>
<p>For convenience, dies if allocation fails. </p>

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00132">132</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

<p>References <a class="el" href="test__suite__aes_8cbc_8c_source.html#l00310">polarssl_malloc</a>.</p>

<p>Referenced by <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00155">unhexify_alloc()</a>.</p>

</div>
</div>
<h2 class="groupheader">Variable Documentation</h2>
<a class="anchor" id="a6fba163c212fa9a84ae7f4f519639d37"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">int test_errors = 0</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Definition at line <a class="el" href="test__suite__ctr__drbg_8c_source.html#l00323">323</a> of file <a class="el" href="test__suite__ctr__drbg_8c_source.html">test_suite_ctr_drbg.c</a>.</p>

</div>
</div>
</div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Thu Jul 31 2014 11:35:56 for PolarSSL v1.3.8 by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.5
</small></address>
</body>
</html>