<!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: ecdh.h Source File</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 Page</span></a></li> <li><a href="modules.html"><span>Modules</span></a></li> <li><a href="annotated.html"><span>Data 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 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_6a9bbd12bf4e19a18c45e270f8fae3fd.html">include</a></li><li class="navelem"><a class="el" href="dir_04272d44da4745cf8b8bfc767d6c6523.html">polarssl</a></li> </ul> </div> </div><!-- top --> <div class="header"> <div class="headertitle"> <div class="title">ecdh.h</div> </div> </div><!--header--> <div class="contents"> <a href="ecdh_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span> </div> <div class="line"><a name="l00027"></a><span class="lineno"> 27</span> <span class="preprocessor">#ifndef POLARSSL_ECDH_H</span></div> <div class="line"><a name="l00028"></a><span class="lineno"> 28</span> <span class="preprocessor"></span><span class="preprocessor">#define POLARSSL_ECDH_H</span></div> <div class="line"><a name="l00029"></a><span class="lineno"> 29</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00030"></a><span class="lineno"> 30</span> <span class="preprocessor">#include "<a class="code" href="ecp_8h.html">ecp.h</a>"</span></div> <div class="line"><a name="l00031"></a><span class="lineno"> 31</span> </div> <div class="line"><a name="l00032"></a><span class="lineno"> 32</span> <span class="preprocessor">#ifdef __cplusplus</span></div> <div class="line"><a name="l00033"></a><span class="lineno"> 33</span> <span class="preprocessor"></span><span class="keyword">extern</span> <span class="stringliteral">"C"</span> {</div> <div class="line"><a name="l00034"></a><span class="lineno"> 34</span> <span class="preprocessor">#endif</span></div> <div class="line"><a name="l00035"></a><span class="lineno"> 35</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00039"></a><span class="lineno"><a class="line" href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541"> 39</a></span> <span class="keyword">typedef</span> <span class="keyword">enum</span></div> <div class="line"><a name="l00040"></a><span class="lineno"> 40</span> {</div> <div class="line"><a name="l00041"></a><span class="lineno"><a class="line" href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541a4f39c37b7d803309ca21379b6f523c2b"> 41</a></span>  <a class="code" href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541a4f39c37b7d803309ca21379b6f523c2b">POLARSSL_ECDH_OURS</a>,</div> <div class="line"><a name="l00042"></a><span class="lineno"><a class="line" href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541a862cefa3ef046471b16b39376cb98e39"> 42</a></span>  <a class="code" href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541a862cefa3ef046471b16b39376cb98e39">POLARSSL_ECDH_THEIRS</a>,</div> <div class="line"><a name="l00043"></a><span class="lineno"> 43</span> } <a class="code" href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541">ecdh_side</a>;</div> <div class="line"><a name="l00044"></a><span class="lineno"> 44</span> </div> <div class="line"><a name="l00048"></a><span class="lineno"><a class="line" href="structecdh__context.html"> 48</a></span> <span class="keyword">typedef</span> <span class="keyword">struct</span></div> <div class="line"><a name="l00049"></a><span class="lineno"> 49</span> {</div> <div class="line"><a name="l00050"></a><span class="lineno"><a class="line" href="structecdh__context.html#a88b34483e99977b9672252a89db3711e"> 50</a></span>  <a class="code" href="structecp__group.html">ecp_group</a> <a class="code" href="structecdh__context.html#a88b34483e99977b9672252a89db3711e">grp</a>; </div> <div class="line"><a name="l00051"></a><span class="lineno"><a class="line" href="structecdh__context.html#a267e859b37b63b0aa28d9b98aeb89aa9"> 51</a></span>  <a class="code" href="structmpi.html">mpi</a> <a class="code" href="structecdh__context.html#a267e859b37b63b0aa28d9b98aeb89aa9">d</a>; </div> <div class="line"><a name="l00052"></a><span class="lineno"><a class="line" href="structecdh__context.html#a7909411787ad822b05dcc93d55d237cf"> 52</a></span>  <a class="code" href="structecp__point.html">ecp_point</a> <a class="code" href="structecdh__context.html#a7909411787ad822b05dcc93d55d237cf">Q</a>; </div> <div class="line"><a name="l00053"></a><span class="lineno"><a class="line" href="structecdh__context.html#ae74dbf3df7dd7503b5ebaa7a73dbbfeb"> 53</a></span>  <a class="code" href="structecp__point.html">ecp_point</a> <a class="code" href="structecdh__context.html#ae74dbf3df7dd7503b5ebaa7a73dbbfeb">Qp</a>; </div> <div class="line"><a name="l00054"></a><span class="lineno"><a class="line" href="structecdh__context.html#ac969f132f7e7be95e6272071e2d92847"> 54</a></span>  <a class="code" href="structmpi.html">mpi</a> <a class="code" href="structecdh__context.html#ac969f132f7e7be95e6272071e2d92847">z</a>; </div> <div class="line"><a name="l00055"></a><span class="lineno"><a class="line" href="structecdh__context.html#a3a321f6f85a382bbf8f6415c462414d2"> 55</a></span>  <span class="keywordtype">int</span> <a class="code" href="structecdh__context.html#a3a321f6f85a382bbf8f6415c462414d2">point_format</a>; </div> <div class="line"><a name="l00056"></a><span class="lineno"><a class="line" href="structecdh__context.html#abad2ff46bf513d9a81cf0da1cd2492d3"> 56</a></span>  <a class="code" href="structecp__point.html">ecp_point</a> <a class="code" href="structecdh__context.html#abad2ff46bf513d9a81cf0da1cd2492d3">Vi</a>; </div> <div class="line"><a name="l00057"></a><span class="lineno"><a class="line" href="structecdh__context.html#aaa7c985bae9a31b20c1fd667010a3719"> 57</a></span>  <a class="code" href="structecp__point.html">ecp_point</a> <a class="code" href="structecdh__context.html#aaa7c985bae9a31b20c1fd667010a3719">Vf</a>; </div> <div class="line"><a name="l00058"></a><span class="lineno"><a class="line" href="structecdh__context.html#ad8c268fa490819a67a8f5eec9df4f569"> 58</a></span>  <a class="code" href="structmpi.html">mpi</a> <a class="code" href="structecdh__context.html#ad8c268fa490819a67a8f5eec9df4f569">_d</a>; </div> <div class="line"><a name="l00059"></a><span class="lineno"> 59</span> }</div> <div class="line"><a name="l00060"></a><span class="lineno"> 60</span> <a class="code" href="structecdh__context.html">ecdh_context</a>;</div> <div class="line"><a name="l00061"></a><span class="lineno"> 61</span> </div> <div class="line"><a name="l00075"></a><span class="lineno"> 75</span> <span class="keywordtype">int</span> <a class="code" href="ecdh_8h.html#a9d54a86910330450fb99cea9845c53c9">ecdh_gen_public</a>( <a class="code" href="structecp__group.html">ecp_group</a> *grp, <a class="code" href="structmpi.html">mpi</a> *d, <a class="code" href="structecp__point.html">ecp_point</a> *Q,</div> <div class="line"><a name="l00076"></a><span class="lineno"> 76</span>  <span class="keywordtype">int</span> (*f_rng)(<span class="keywordtype">void</span> *, <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *, <span class="keywordtype">size_t</span>),</div> <div class="line"><a name="l00077"></a><span class="lineno"> 77</span>  <span class="keywordtype">void</span> *p_rng );</div> <div class="line"><a name="l00078"></a><span class="lineno"> 78</span> </div> <div class="line"><a name="l00097"></a><span class="lineno"> 97</span> <span class="keywordtype">int</span> <a class="code" href="ecdh_8h.html#af4a8cc9a1009e4307afe4088d769a6bd">ecdh_compute_shared</a>( <a class="code" href="structecp__group.html">ecp_group</a> *grp, <a class="code" href="structmpi.html">mpi</a> *z,</div> <div class="line"><a name="l00098"></a><span class="lineno"> 98</span>  <span class="keyword">const</span> <a class="code" href="structecp__point.html">ecp_point</a> *Q, <span class="keyword">const</span> <a class="code" href="structmpi.html">mpi</a> *d,</div> <div class="line"><a name="l00099"></a><span class="lineno"> 99</span>  <span class="keywordtype">int</span> (*f_rng)(<span class="keywordtype">void</span> *, <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *, <span class="keywordtype">size_t</span>),</div> <div class="line"><a name="l00100"></a><span class="lineno"> 100</span>  <span class="keywordtype">void</span> *p_rng );</div> <div class="line"><a name="l00101"></a><span class="lineno"> 101</span> </div> <div class="line"><a name="l00107"></a><span class="lineno"> 107</span> <span class="keywordtype">void</span> <a class="code" href="ecdh_8h.html#a80d76b7ea7bd03f987045790528fa9fe">ecdh_init</a>( <a class="code" href="structecdh__context.html">ecdh_context</a> *ctx );</div> <div class="line"><a name="l00108"></a><span class="lineno"> 108</span> </div> <div class="line"><a name="l00114"></a><span class="lineno"> 114</span> <span class="keywordtype">void</span> <a class="code" href="ecdh_8h.html#ac58b9cd610b9bf65274d917c89756a5b">ecdh_free</a>( <a class="code" href="structecdh__context.html">ecdh_context</a> *ctx );</div> <div class="line"><a name="l00115"></a><span class="lineno"> 115</span> </div> <div class="line"><a name="l00132"></a><span class="lineno"> 132</span> <span class="keywordtype">int</span> <a class="code" href="ecdh_8h.html#a0fb5133b05e53e0f5d576cfe5dce2d20">ecdh_make_params</a>( <a class="code" href="structecdh__context.html">ecdh_context</a> *ctx, <span class="keywordtype">size_t</span> *olen,</div> <div class="line"><a name="l00133"></a><span class="lineno"> 133</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *buf, <span class="keywordtype">size_t</span> blen,</div> <div class="line"><a name="l00134"></a><span class="lineno"> 134</span>  <span class="keywordtype">int</span> (*f_rng)(<span class="keywordtype">void</span> *, <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *, <span class="keywordtype">size_t</span>),</div> <div class="line"><a name="l00135"></a><span class="lineno"> 135</span>  <span class="keywordtype">void</span> *p_rng );</div> <div class="line"><a name="l00136"></a><span class="lineno"> 136</span> </div> <div class="line"><a name="l00147"></a><span class="lineno"> 147</span> <span class="keywordtype">int</span> <a class="code" href="ecdh_8h.html#ab0412adb0eb89eab15c6da4f1e99a75d">ecdh_read_params</a>( <a class="code" href="structecdh__context.html">ecdh_context</a> *ctx,</div> <div class="line"><a name="l00148"></a><span class="lineno"> 148</span>  <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> **buf, <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *end );</div> <div class="line"><a name="l00149"></a><span class="lineno"> 149</span> </div> <div class="line"><a name="l00162"></a><span class="lineno"> 162</span> <span class="keywordtype">int</span> <a class="code" href="ecdh_8h.html#ab610fdc63f2d5085cfe6b2ab024e96fb">ecdh_get_params</a>( <a class="code" href="structecdh__context.html">ecdh_context</a> *ctx, <span class="keyword">const</span> <a class="code" href="structecp__keypair.html">ecp_keypair</a> *key,</div> <div class="line"><a name="l00163"></a><span class="lineno"> 163</span>  <a class="code" href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541">ecdh_side</a> side );</div> <div class="line"><a name="l00164"></a><span class="lineno"> 164</span> </div> <div class="line"><a name="l00178"></a><span class="lineno"> 178</span> <span class="keywordtype">int</span> <a class="code" href="ecdh_8h.html#ae91b8624edc6f81fbdef9137cf1fd703">ecdh_make_public</a>( <a class="code" href="structecdh__context.html">ecdh_context</a> *ctx, <span class="keywordtype">size_t</span> *olen,</div> <div class="line"><a name="l00179"></a><span class="lineno"> 179</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *buf, <span class="keywordtype">size_t</span> blen,</div> <div class="line"><a name="l00180"></a><span class="lineno"> 180</span>  <span class="keywordtype">int</span> (*f_rng)(<span class="keywordtype">void</span> *, <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *, <span class="keywordtype">size_t</span>),</div> <div class="line"><a name="l00181"></a><span class="lineno"> 181</span>  <span class="keywordtype">void</span> *p_rng );</div> <div class="line"><a name="l00182"></a><span class="lineno"> 182</span> </div> <div class="line"><a name="l00193"></a><span class="lineno"> 193</span> <span class="keywordtype">int</span> <a class="code" href="ecdh_8h.html#ac630688764d91d5e462cf46af7cafa3a">ecdh_read_public</a>( <a class="code" href="structecdh__context.html">ecdh_context</a> *ctx,</div> <div class="line"><a name="l00194"></a><span class="lineno"> 194</span>  <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *buf, <span class="keywordtype">size_t</span> blen );</div> <div class="line"><a name="l00195"></a><span class="lineno"> 195</span> </div> <div class="line"><a name="l00209"></a><span class="lineno"> 209</span> <span class="keywordtype">int</span> <a class="code" href="ecdh_8h.html#a51fead5ce830e844d27165630e0205ce">ecdh_calc_secret</a>( <a class="code" href="structecdh__context.html">ecdh_context</a> *ctx, <span class="keywordtype">size_t</span> *olen,</div> <div class="line"><a name="l00210"></a><span class="lineno"> 210</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *buf, <span class="keywordtype">size_t</span> blen,</div> <div class="line"><a name="l00211"></a><span class="lineno"> 211</span>  <span class="keywordtype">int</span> (*f_rng)(<span class="keywordtype">void</span> *, <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *, <span class="keywordtype">size_t</span>),</div> <div class="line"><a name="l00212"></a><span class="lineno"> 212</span>  <span class="keywordtype">void</span> *p_rng );</div> <div class="line"><a name="l00213"></a><span class="lineno"> 213</span> </div> <div class="line"><a name="l00219"></a><span class="lineno"> 219</span> <span class="keywordtype">int</span> <a class="code" href="ecdh_8h.html#acdb6b5b461eee93ac484d0323c8f86e0">ecdh_self_test</a>( <span class="keywordtype">int</span> verbose );</div> <div class="line"><a name="l00220"></a><span class="lineno"> 220</span> </div> <div class="line"><a name="l00221"></a><span class="lineno"> 221</span> <span class="preprocessor">#ifdef __cplusplus</span></div> <div class="line"><a name="l00222"></a><span class="lineno"> 222</span> <span class="preprocessor"></span>}</div> <div class="line"><a name="l00223"></a><span class="lineno"> 223</span> <span class="preprocessor">#endif</span></div> <div class="line"><a name="l00224"></a><span class="lineno"> 224</span> <span class="preprocessor"></span></div> <div class="line"><a name="l00225"></a><span class="lineno"> 225</span> <span class="preprocessor">#endif </span><span class="comment">/* ecdh.h */</span><span class="preprocessor"></span></div> <div class="ttc" id="ecdh_8h_html_a0fb5133b05e53e0f5d576cfe5dce2d20"><div class="ttname"><a href="ecdh_8h.html#a0fb5133b05e53e0f5d576cfe5dce2d20">ecdh_make_params</a></div><div class="ttdeci">int ecdh_make_params(ecdh_context *ctx, size_t *olen, unsigned char *buf, size_t blen, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng)</div><div class="ttdoc">Generate a public key and a TLS ServerKeyExchange payload. </div></div> <div class="ttc" id="ecdh_8h_html_ae91b8624edc6f81fbdef9137cf1fd703"><div class="ttname"><a href="ecdh_8h.html#ae91b8624edc6f81fbdef9137cf1fd703">ecdh_make_public</a></div><div class="ttdeci">int ecdh_make_public(ecdh_context *ctx, size_t *olen, unsigned char *buf, size_t blen, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng)</div><div class="ttdoc">Generate a public key and a TLS ClientKeyExchange payload. </div></div> <div class="ttc" id="ecdh_8h_html_a51fead5ce830e844d27165630e0205ce"><div class="ttname"><a href="ecdh_8h.html#a51fead5ce830e844d27165630e0205ce">ecdh_calc_secret</a></div><div class="ttdeci">int ecdh_calc_secret(ecdh_context *ctx, size_t *olen, unsigned char *buf, size_t blen, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng)</div><div class="ttdoc">Derive and export the shared secret. </div></div> <div class="ttc" id="ecp_8h_html"><div class="ttname"><a href="ecp_8h.html">ecp.h</a></div><div class="ttdoc">Elliptic curves over GF(p) </div></div> <div class="ttc" id="ecdh_8h_html_ac630688764d91d5e462cf46af7cafa3a"><div class="ttname"><a href="ecdh_8h.html#ac630688764d91d5e462cf46af7cafa3a">ecdh_read_public</a></div><div class="ttdeci">int ecdh_read_public(ecdh_context *ctx, const unsigned char *buf, size_t blen)</div><div class="ttdoc">Parse and process a TLS ClientKeyExchange payload. </div></div> <div class="ttc" id="structecdh__context_html_aaa7c985bae9a31b20c1fd667010a3719"><div class="ttname"><a href="structecdh__context.html#aaa7c985bae9a31b20c1fd667010a3719">ecdh_context::Vf</a></div><div class="ttdeci">ecp_point Vf</div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00057">ecdh.h:57</a></div></div> <div class="ttc" id="ecdh_8h_html_af4a8cc9a1009e4307afe4088d769a6bd"><div class="ttname"><a href="ecdh_8h.html#af4a8cc9a1009e4307afe4088d769a6bd">ecdh_compute_shared</a></div><div class="ttdeci">int ecdh_compute_shared(ecp_group *grp, mpi *z, const ecp_point *Q, const mpi *d, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng)</div><div class="ttdoc">Compute shared secret Raw function that only does the core computation. </div></div> <div class="ttc" id="ecdh_8h_html_a9d54a86910330450fb99cea9845c53c9"><div class="ttname"><a href="ecdh_8h.html#a9d54a86910330450fb99cea9845c53c9">ecdh_gen_public</a></div><div class="ttdeci">int ecdh_gen_public(ecp_group *grp, mpi *d, ecp_point *Q, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng)</div><div class="ttdoc">Generate a public key. </div></div> <div class="ttc" id="structecdh__context_html_ad8c268fa490819a67a8f5eec9df4f569"><div class="ttname"><a href="structecdh__context.html#ad8c268fa490819a67a8f5eec9df4f569">ecdh_context::_d</a></div><div class="ttdeci">mpi _d</div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00058">ecdh.h:58</a></div></div> <div class="ttc" id="structecp__group_html"><div class="ttname"><a href="structecp__group.html">ecp_group</a></div><div class="ttdoc">ECP group structure. </div><div class="ttdef"><b>Definition:</b> <a href="ecp_8h_source.html#l00136">ecp.h:136</a></div></div> <div class="ttc" id="ecdh_8h_html_ab610fdc63f2d5085cfe6b2ab024e96fb"><div class="ttname"><a href="ecdh_8h.html#ab610fdc63f2d5085cfe6b2ab024e96fb">ecdh_get_params</a></div><div class="ttdeci">int ecdh_get_params(ecdh_context *ctx, const ecp_keypair *key, ecdh_side side)</div><div class="ttdoc">Setup an ECDH context from an EC key. </div></div> <div class="ttc" id="structecp__keypair_html"><div class="ttname"><a href="structecp__keypair.html">ecp_keypair</a></div><div class="ttdoc">ECP key pair structure. </div><div class="ttdef"><b>Definition:</b> <a href="ecp_8h_source.html#l00163">ecp.h:163</a></div></div> <div class="ttc" id="structmpi_html"><div class="ttname"><a href="structmpi.html">mpi</a></div><div class="ttdoc">MPI structure. </div><div class="ttdef"><b>Definition:</b> <a href="bignum_8h_source.html#l00182">bignum.h:182</a></div></div> <div class="ttc" id="structecdh__context_html_a267e859b37b63b0aa28d9b98aeb89aa9"><div class="ttname"><a href="structecdh__context.html#a267e859b37b63b0aa28d9b98aeb89aa9">ecdh_context::d</a></div><div class="ttdeci">mpi d</div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00051">ecdh.h:51</a></div></div> <div class="ttc" id="structecdh__context_html_ae74dbf3df7dd7503b5ebaa7a73dbbfeb"><div class="ttname"><a href="structecdh__context.html#ae74dbf3df7dd7503b5ebaa7a73dbbfeb">ecdh_context::Qp</a></div><div class="ttdeci">ecp_point Qp</div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00053">ecdh.h:53</a></div></div> <div class="ttc" id="ecdh_8h_html_a4afa1322ebd6c0b06f5143bbae929541a862cefa3ef046471b16b39376cb98e39"><div class="ttname"><a href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541a862cefa3ef046471b16b39376cb98e39">POLARSSL_ECDH_THEIRS</a></div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00042">ecdh.h:42</a></div></div> <div class="ttc" id="structecp__point_html"><div class="ttname"><a href="structecp__point.html">ecp_point</a></div><div class="ttdoc">ECP point structure (jacobian coordinates) </div><div class="ttdef"><b>Definition:</b> <a href="ecp_8h_source.html#l00104">ecp.h:104</a></div></div> <div class="ttc" id="structecdh__context_html_a3a321f6f85a382bbf8f6415c462414d2"><div class="ttname"><a href="structecdh__context.html#a3a321f6f85a382bbf8f6415c462414d2">ecdh_context::point_format</a></div><div class="ttdeci">int point_format</div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00055">ecdh.h:55</a></div></div> <div class="ttc" id="ecdh_8h_html_a4afa1322ebd6c0b06f5143bbae929541"><div class="ttname"><a href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541">ecdh_side</a></div><div class="ttdeci">ecdh_side</div><div class="ttdoc">When importing from an EC key, select if it is our key or the peer&#39;s key. </div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00039">ecdh.h:39</a></div></div> <div class="ttc" id="structecdh__context_html_ac969f132f7e7be95e6272071e2d92847"><div class="ttname"><a href="structecdh__context.html#ac969f132f7e7be95e6272071e2d92847">ecdh_context::z</a></div><div class="ttdeci">mpi z</div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00054">ecdh.h:54</a></div></div> <div class="ttc" id="ecdh_8h_html_ab0412adb0eb89eab15c6da4f1e99a75d"><div class="ttname"><a href="ecdh_8h.html#ab0412adb0eb89eab15c6da4f1e99a75d">ecdh_read_params</a></div><div class="ttdeci">int ecdh_read_params(ecdh_context *ctx, const unsigned char **buf, const unsigned char *end)</div><div class="ttdoc">Parse and procress a TLS ServerKeyExhange payload. </div></div> <div class="ttc" id="structecdh__context_html"><div class="ttname"><a href="structecdh__context.html">ecdh_context</a></div><div class="ttdoc">ECDH context structure. </div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00048">ecdh.h:48</a></div></div> <div class="ttc" id="ecdh_8h_html_a80d76b7ea7bd03f987045790528fa9fe"><div class="ttname"><a href="ecdh_8h.html#a80d76b7ea7bd03f987045790528fa9fe">ecdh_init</a></div><div class="ttdeci">void ecdh_init(ecdh_context *ctx)</div><div class="ttdoc">Initialize context. </div></div> <div class="ttc" id="ecdh_8h_html_a4afa1322ebd6c0b06f5143bbae929541a4f39c37b7d803309ca21379b6f523c2b"><div class="ttname"><a href="ecdh_8h.html#a4afa1322ebd6c0b06f5143bbae929541a4f39c37b7d803309ca21379b6f523c2b">POLARSSL_ECDH_OURS</a></div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00041">ecdh.h:41</a></div></div> <div class="ttc" id="structecdh__context_html_abad2ff46bf513d9a81cf0da1cd2492d3"><div class="ttname"><a href="structecdh__context.html#abad2ff46bf513d9a81cf0da1cd2492d3">ecdh_context::Vi</a></div><div class="ttdeci">ecp_point Vi</div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00056">ecdh.h:56</a></div></div> <div class="ttc" id="ecdh_8h_html_acdb6b5b461eee93ac484d0323c8f86e0"><div class="ttname"><a href="ecdh_8h.html#acdb6b5b461eee93ac484d0323c8f86e0">ecdh_self_test</a></div><div class="ttdeci">int ecdh_self_test(int verbose)</div><div class="ttdoc">Checkup routine. </div></div> <div class="ttc" id="ecdh_8h_html_ac58b9cd610b9bf65274d917c89756a5b"><div class="ttname"><a href="ecdh_8h.html#ac58b9cd610b9bf65274d917c89756a5b">ecdh_free</a></div><div class="ttdeci">void ecdh_free(ecdh_context *ctx)</div><div class="ttdoc">Free context. </div></div> <div class="ttc" id="structecdh__context_html_a88b34483e99977b9672252a89db3711e"><div class="ttname"><a href="structecdh__context.html#a88b34483e99977b9672252a89db3711e">ecdh_context::grp</a></div><div class="ttdeci">ecp_group grp</div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00050">ecdh.h:50</a></div></div> <div class="ttc" id="structecdh__context_html_a7909411787ad822b05dcc93d55d237cf"><div class="ttname"><a href="structecdh__context.html#a7909411787ad822b05dcc93d55d237cf">ecdh_context::Q</a></div><div class="ttdeci">ecp_point Q</div><div class="ttdef"><b>Definition:</b> <a href="ecdh_8h_source.html#l00052">ecdh.h:52</a></div></div> </div><!-- fragment --></div><!-- contents --> <!-- start footer part --> <hr class="footer"/><address class="footer"><small> Generated on Thu Jul 31 2014 11:35:51 for PolarSSL v1.3.8 by  <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/> </a> 1.8.5 </small></address> </body> </html>