Sophie

Sophie

distrib > Mandriva > current > i586 > media > main-updates > by-pkgid > e0236b39c613e86bcee76bad717809a5 > files > 217

libapr-devel-1.4.6-0.1mdv2010.2.i586.rpm

<!-- This comment will put IE 6, 7 and 8 in quirks mode -->
<!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"/>
<title>Apache Portable Runtime: Random Functions</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javaScript" src="search/search.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css"/>
</head>
<body onload='searchBox.OnSelectItem(0);'>
<!-- Generated by Doxygen 1.6.3 -->
<script type="text/javascript"><!--
var searchBox = new SearchBox("searchBox", "search",false,'Search');
--></script>
<div class="navigation" id="top">
  <div class="tabs">
    <ul>
      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
      <li><a href="modules.html"><span>Modules</span></a></li>
      <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
      <li>
        <div id="MSearchBox" class="MSearchBoxInactive">
        <img id="MSearchSelect" src="search/search.png"
             onmouseover="return searchBox.OnSearchSelectShow()"
             onmouseout="return searchBox.OnSearchSelectHide()"
             alt=""/>
        <input type="text" id="MSearchField" value="Search" accesskey="S"
             onfocus="searchBox.OnSearchFieldFocus(true)" 
             onblur="searchBox.OnSearchFieldFocus(false)" 
             onkeyup="searchBox.OnSearchFieldChange(event)"/>
        <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
        </div>
      </li>
    </ul>
  </div>
</div>
<div class="contents">
<h1>Random Functions<br/>
<small>
[<a class="el" href="group___a_p_r.html">Apache Portability Runtime library</a>]</small>
</h1><table border="0" cellpadding="0" cellspacing="0">
<tr><td colspan="2"><h2>Data Structures</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a></td></tr>
<tr><td colspan="2"><h2>Typedefs</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ga30fbaf80424a9f1a0e9cc51072f65127"></a><!-- doxytag: member="apr_random::apr_crypto_hash_t" ref="ga30fbaf80424a9f1a0e9cc51072f65127" args="" -->
typedef struct <a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><b>apr_crypto_hash_t</b></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="gad2775bc1cdb376d9dec0e97283b4bdd9"></a><!-- doxytag: member="apr_random::apr_crypto_hash_init_t" ref="gad2775bc1cdb376d9dec0e97283b4bdd9" args="(apr_crypto_hash_t *hash)" -->
typedef void&nbsp;</td><td class="memItemRight" valign="bottom"><b>apr_crypto_hash_init_t</b> (<a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *hash)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ga2f8a4fb18078a76357327ea55936c1ea"></a><!-- doxytag: member="apr_random::apr_crypto_hash_add_t" ref="ga2f8a4fb18078a76357327ea55936c1ea" args="(apr_crypto_hash_t *hash, const void *data, apr_size_t bytes)" -->
typedef void&nbsp;</td><td class="memItemRight" valign="bottom"><b>apr_crypto_hash_add_t</b> (<a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *hash, const void *data, apr_size_t bytes)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="gab70ea9133870efdb5532d20d4bcf7442"></a><!-- doxytag: member="apr_random::apr_crypto_hash_finish_t" ref="gab70ea9133870efdb5532d20d4bcf7442" args="(apr_crypto_hash_t *hash, unsigned char *result)" -->
typedef void&nbsp;</td><td class="memItemRight" valign="bottom"><b>apr_crypto_hash_finish_t</b> (<a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *hash, unsigned char *result)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">typedef struct <a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a></td></tr>
<tr><td colspan="2"><h2>Functions</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#ga564e4c380e820a9b0d9e877d4852a65e">apr_generate_random_bytes</a> (unsigned char *buf, apr_size_t length)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#gae992c6f642e9661d2417cd8f2df8d345">apr_crypto_sha256_new</a> (<a class="el" href="group__apr__pools.html#gaf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#ga0184a90774212132f883c463811aacdc">apr_random_init</a> (<a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *g, <a class="el" href="group__apr__pools.html#gaf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p, <a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *pool_hash, <a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *key_hash, <a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *prng_hash)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#ga7a73c9bcf026b63847aeae483c53191f">apr_random_standard_new</a> (<a class="el" href="group__apr__pools.html#gaf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#ga8cf2875644c1dffc0c336289bd370efb">apr_random_add_entropy</a> (<a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *g, const void *entropy_, apr_size_t bytes)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#gab9a63359bb9543d746e6fd46933b7256">apr_random_insecure_bytes</a> (<a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *g, void *random, apr_size_t bytes)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#ga9f0607e06656a1c76cc5ee878fd94f09">apr_random_secure_bytes</a> (<a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *g, void *random, apr_size_t bytes)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#ga37d8d7529cf972c605ebce97c57f8825">apr_random_barrier</a> (<a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *g)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#ga99d0c0722eeef2951e8ccede2e1451fa">apr_random_secure_ready</a> (<a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *r)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#ga6465698bdc752d07abc8c515aac6e2c0">apr_random_insecure_ready</a> (<a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *r)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__apr__random.html#gaa1ab9b8adeeb6e37bb29def249ff9e6a">apr_random_after_fork</a> (<a class="el" href="structapr__proc__t.html">apr_proc_t</a> *proc)</td></tr>
</table>
<hr/><h2>Typedef Documentation</h2>
<a class="anchor" id="ga33073741e56b1bafe52ba58cefcbbf96"></a><!-- doxytag: member="apr_random.h::apr_random_t" ref="ga33073741e56b1bafe52ba58cefcbbf96" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">typedef struct <a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> <a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Opaque PRNG structure. </p>

</div>
</div>
<hr/><h2>Function Documentation</h2>
<a class="anchor" id="gae992c6f642e9661d2417cd8f2df8d345"></a><!-- doxytag: member="apr_random.h::apr_crypto_sha256_new" ref="gae992c6f642e9661d2417cd8f2df8d345" args="(apr_pool_t *p)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a>* apr_crypto_sha256_new </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="group__apr__pools.html#gaf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *&nbsp;</td>
          <td class="paramname"> <em>p</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Allocate and initialize the SHA-256 context </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>p</em>&nbsp;</td><td>The pool to allocate from </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="ga564e4c380e820a9b0d9e877d4852a65e"></a><!-- doxytag: member="apr_general.h::apr_generate_random_bytes" ref="ga564e4c380e820a9b0d9e877d4852a65e" args="(unsigned char *buf, apr_size_t length)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> apr_generate_random_bytes </td>
          <td>(</td>
          <td class="paramtype">unsigned char *&nbsp;</td>
          <td class="paramname"> <em>buf</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">apr_size_t&nbsp;</td>
          <td class="paramname"> <em>length</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Generate random bytes. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>buf</em>&nbsp;</td><td>Buffer to fill with random bytes </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>length</em>&nbsp;</td><td>Length of buffer in bytes </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="ga8cf2875644c1dffc0c336289bd370efb"></a><!-- doxytag: member="apr_random.h::apr_random_add_entropy" ref="ga8cf2875644c1dffc0c336289bd370efb" args="(apr_random_t *g, const void *entropy_, apr_size_t bytes)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void apr_random_add_entropy </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *&nbsp;</td>
          <td class="paramname"> <em>g</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const void *&nbsp;</td>
          <td class="paramname"> <em>entropy_</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">apr_size_t&nbsp;</td>
          <td class="paramname"> <em>bytes</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Mix the randomness pools. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>g</em>&nbsp;</td><td>The PRNG state </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>entropy_</em>&nbsp;</td><td>Entropy buffer </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>bytes</em>&nbsp;</td><td>Length of entropy_ in bytes </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="gaa1ab9b8adeeb6e37bb29def249ff9e6a"></a><!-- doxytag: member="apr_random.h::apr_random_after_fork" ref="gaa1ab9b8adeeb6e37bb29def249ff9e6a" args="(apr_proc_t *proc)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void apr_random_after_fork </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="structapr__proc__t.html">apr_proc_t</a> *&nbsp;</td>
          <td class="paramname"> <em>proc</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Mix the randomness pools after forking. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>proc</em>&nbsp;</td><td>The resulting process handle from <a class="el" href="group__apr__thread__proc.html#ga3d0415bf69b0a629a929833e82758b85">apr_proc_fork()</a> </td></tr>
  </table>
  </dd>
</dl>
<dl class="remark"><dt><b>Remarks:</b></dt><dd>Call this in the child after forking to mix the randomness pools. Note that its generally a bad idea to fork a process with a real PRNG in it - better to have the PRNG externally and get the randomness from there. However, if you really must do it, then you should supply all your entropy to all the PRNGs - don't worry, they won't produce the same output. </dd>
<dd>
Note that <a class="el" href="group__apr__thread__proc.html#ga3d0415bf69b0a629a929833e82758b85">apr_proc_fork()</a> calls this for you, so only weird applications need ever call it themselves. </dd></dl>

</div>
</div>
<a class="anchor" id="ga37d8d7529cf972c605ebce97c57f8825"></a><!-- doxytag: member="apr_random.h::apr_random_barrier" ref="ga37d8d7529cf972c605ebce97c57f8825" args="(apr_random_t *g)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void apr_random_barrier </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *&nbsp;</td>
          <td class="paramname"> <em>g</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Ensures that E bits of conditional entropy are mixed into the PRNG before any further randomness is extracted. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>g</em>&nbsp;</td><td>The RNG state </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="ga0184a90774212132f883c463811aacdc"></a><!-- doxytag: member="apr_random.h::apr_random_init" ref="ga0184a90774212132f883c463811aacdc" args="(apr_random_t *g, apr_pool_t *p, apr_crypto_hash_t *pool_hash, apr_crypto_hash_t *key_hash, apr_crypto_hash_t *prng_hash)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void apr_random_init </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *&nbsp;</td>
          <td class="paramname"> <em>g</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="group__apr__pools.html#gaf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *&nbsp;</td>
          <td class="paramname"> <em>p</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *&nbsp;</td>
          <td class="paramname"> <em>pool_hash</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *&nbsp;</td>
          <td class="paramname"> <em>key_hash</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="structapr__crypto__hash__t.html">apr_crypto_hash_t</a> *&nbsp;</td>
          <td class="paramname"> <em>prng_hash</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Initialize a PRNG state </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>g</em>&nbsp;</td><td>The PRNG state </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>p</em>&nbsp;</td><td>The pool to allocate from </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>pool_hash</em>&nbsp;</td><td>Pool hash functions </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>key_hash</em>&nbsp;</td><td>Key hash functions </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>prng_hash</em>&nbsp;</td><td>PRNG hash functions </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="gab9a63359bb9543d746e6fd46933b7256"></a><!-- doxytag: member="apr_random.h::apr_random_insecure_bytes" ref="gab9a63359bb9543d746e6fd46933b7256" args="(apr_random_t *g, void *random, apr_size_t bytes)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> apr_random_insecure_bytes </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *&nbsp;</td>
          <td class="paramname"> <em>g</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">void *&nbsp;</td>
          <td class="paramname"> <em>random</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">apr_size_t&nbsp;</td>
          <td class="paramname"> <em>bytes</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Generate cryptographically insecure random bytes. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>g</em>&nbsp;</td><td>The RNG state </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>random</em>&nbsp;</td><td>Buffer to fill with random bytes </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>bytes</em>&nbsp;</td><td>Length of buffer in bytes </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="ga6465698bdc752d07abc8c515aac6e2c0"></a><!-- doxytag: member="apr_random.h::apr_random_insecure_ready" ref="ga6465698bdc752d07abc8c515aac6e2c0" args="(apr_random_t *r)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> apr_random_insecure_ready </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *&nbsp;</td>
          <td class="paramname"> <em>r</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Return APR_SUCCESS if the PRNG has been seeded with enough data, APR_ENOTENOUGHENTROPY otherwise. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>r</em>&nbsp;</td><td>The PRNG state </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="ga9f0607e06656a1c76cc5ee878fd94f09"></a><!-- doxytag: member="apr_random.h::apr_random_secure_bytes" ref="ga9f0607e06656a1c76cc5ee878fd94f09" args="(apr_random_t *g, void *random, apr_size_t bytes)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> apr_random_secure_bytes </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *&nbsp;</td>
          <td class="paramname"> <em>g</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">void *&nbsp;</td>
          <td class="paramname"> <em>random</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">apr_size_t&nbsp;</td>
          <td class="paramname"> <em>bytes</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Generate cryptographically secure random bytes. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>g</em>&nbsp;</td><td>The RNG state </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>random</em>&nbsp;</td><td>Buffer to fill with random bytes </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>bytes</em>&nbsp;</td><td>Length of buffer in bytes </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="ga99d0c0722eeef2951e8ccede2e1451fa"></a><!-- doxytag: member="apr_random.h::apr_random_secure_ready" ref="ga99d0c0722eeef2951e8ccede2e1451fa" args="(apr_random_t *r)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="group__apr__errno.html#gaf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> apr_random_secure_ready </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a> *&nbsp;</td>
          <td class="paramname"> <em>r</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Return APR_SUCCESS if the cryptographic PRNG has been seeded with enough data, APR_ENOTENOUGHENTROPY otherwise. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>r</em>&nbsp;</td><td>The RNG state </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="ga7a73c9bcf026b63847aeae483c53191f"></a><!-- doxytag: member="apr_random.h::apr_random_standard_new" ref="ga7a73c9bcf026b63847aeae483c53191f" args="(apr_pool_t *p)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="group__apr__random.html#ga33073741e56b1bafe52ba58cefcbbf96">apr_random_t</a>* apr_random_standard_new </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="group__apr__pools.html#gaf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *&nbsp;</td>
          <td class="paramname"> <em>p</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Allocate and initialize (apr_crypto_sha256_new) a new PRNG state. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>p</em>&nbsp;</td><td>The pool to allocate from </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
</div>
<!--- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&nbsp;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&nbsp;</span>Data Structures</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&nbsp;</span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&nbsp;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&nbsp;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&nbsp;</span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&nbsp;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&nbsp;</span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark">&nbsp;</span>Defines</a></div>

<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="" frameborder="0" 
        name="MSearchResults" id="MSearchResults">
</iframe>
</div>

<hr class="footer"/><address style="text-align: right;"><small>Generated on Tue Feb 14 10:09:01 2012 for Apache Portable Runtime by&nbsp;
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.3 </small></address>
</body>
</html>