mirror of
https://github.com/seigler/dash-docs
synced 2025-07-27 17:56:16 +00:00
141 lines
92 KiB
HTML
141 lines
92 KiB
HTML
<!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.14"/>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
|
<title>Dash Core: src/secp256k1/src/hash_impl.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="navtree.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="resize.js"></script>
|
|
<script type="text/javascript" src="navtreedata.js"></script>
|
|
<script type="text/javascript" src="navtree.js"></script>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
$(document).ready(initResizable);
|
|
/* @license-end */</script>
|
|
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
<script type="text/javascript" src="search/search.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 id="projectlogo"><img alt="Logo" src="bitcoin_logo_doxygen.png"/></td>
|
|
<td id="projectalign" style="padding-left: 0.5em;">
|
|
<div id="projectname">Dash Core
|
|
 <span id="projectnumber">0.12.2.1</span>
|
|
</div>
|
|
<div id="projectbrief">P2P Digital Currency</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<!-- end header part -->
|
|
<!-- Generated by Doxygen 1.8.14 -->
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
var searchBox = new SearchBox("searchBox", "search",false,'Search');
|
|
/* @license-end */
|
|
</script>
|
|
<script type="text/javascript" src="menudata.js"></script>
|
|
<script type="text/javascript" src="menu.js"></script>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
$(function() {
|
|
initMenu('',true,false,'search.php','Search');
|
|
$(document).ready(function() { init_search(); });
|
|
});
|
|
/* @license-end */</script>
|
|
<div id="main-nav"></div>
|
|
</div><!-- top -->
|
|
<div id="side-nav" class="ui-resizable side-nav-resizable">
|
|
<div id="nav-tree">
|
|
<div id="nav-tree-contents">
|
|
<div id="nav-sync" class="sync"></div>
|
|
</div>
|
|
</div>
|
|
<div id="splitbar" style="-moz-user-select:none;"
|
|
class="ui-resizable-handle">
|
|
</div>
|
|
</div>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
$(document).ready(function(){initNavTree('hash__impl_8h_source.html','');});
|
|
/* @license-end */
|
|
</script>
|
|
<div id="doc-content">
|
|
<!-- window showing the filter options -->
|
|
<div id="MSearchSelectWindow"
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
</div>
|
|
|
|
<!-- iframe showing the search results (closed by default) -->
|
|
<div id="MSearchResultsWindow">
|
|
<iframe src="javascript:void(0)" frameborder="0"
|
|
name="MSearchResults" id="MSearchResults">
|
|
</iframe>
|
|
</div>
|
|
|
|
<div class="header">
|
|
<div class="headertitle">
|
|
<div class="title">hash_impl.h</div> </div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
<a href="hash__impl_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> <span class="comment">/**********************************************************************</span></div><div class="line"><a name="l00002"></a><span class="lineno"> 2</span> <span class="comment"> * Copyright (c) 2014 Pieter Wuille *</span></div><div class="line"><a name="l00003"></a><span class="lineno"> 3</span> <span class="comment"> * Distributed under the MIT software license, see the accompanying *</span></div><div class="line"><a name="l00004"></a><span class="lineno"> 4</span> <span class="comment"> * file COPYING or http://www.opensource.org/licenses/mit-license.php.*</span></div><div class="line"><a name="l00005"></a><span class="lineno"> 5</span> <span class="comment"> **********************************************************************/</span></div><div class="line"><a name="l00006"></a><span class="lineno"> 6</span> </div><div class="line"><a name="l00007"></a><span class="lineno"> 7</span> <span class="preprocessor">#ifndef _SECP256K1_HASH_IMPL_H_</span></div><div class="line"><a name="l00008"></a><span class="lineno"> 8</span> <span class="preprocessor">#define _SECP256K1_HASH_IMPL_H_</span></div><div class="line"><a name="l00009"></a><span class="lineno"> 9</span> </div><div class="line"><a name="l00010"></a><span class="lineno"> 10</span> <span class="preprocessor">#include "<a class="code" href="secp256k1_2src_2hash_8h.html">hash.h</a>"</span></div><div class="line"><a name="l00011"></a><span class="lineno"> 11</span> </div><div class="line"><a name="l00012"></a><span class="lineno"> 12</span> <span class="preprocessor">#include <stdlib.h></span></div><div class="line"><a name="l00013"></a><span class="lineno"> 13</span> <span class="preprocessor">#include <stdint.h></span></div><div class="line"><a name="l00014"></a><span class="lineno"> 14</span> <span class="preprocessor">#include <string.h></span></div><div class="line"><a name="l00015"></a><span class="lineno"> 15</span> </div><div class="line"><a name="l00016"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#ab0a0d1ad13c7e4d3cb38c89f7127c85a"> 16</a></span> <span class="preprocessor">#define Ch(x,y,z) ((z) ^ ((x) & ((y) ^ (z))))</span></div><div class="line"><a name="l00017"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a447cd1d7fb703b62666400976be24bf3"> 17</a></span> <span class="preprocessor">#define Maj(x,y,z) (((x) & (y)) | ((z) & ((x) | (y))))</span></div><div class="line"><a name="l00018"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a613f88ad88919b6ed21ff223070f9a21"> 18</a></span> <span class="preprocessor">#define Sigma0(x) (((x) >> 2 | (x) << 30) ^ ((x) >> 13 | (x) << 19) ^ ((x) >> 22 | (x) << 10))</span></div><div class="line"><a name="l00019"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a6d34508d6d962274083fcd992fb4e340"> 19</a></span> <span class="preprocessor">#define Sigma1(x) (((x) >> 6 | (x) << 26) ^ ((x) >> 11 | (x) << 21) ^ ((x) >> 25 | (x) << 7))</span></div><div class="line"><a name="l00020"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff"> 20</a></span> <span class="preprocessor">#define sigma0(x) (((x) >> 7 | (x) << 25) ^ ((x) >> 18 | (x) << 14) ^ ((x) >> 3))</span></div><div class="line"><a name="l00021"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97"> 21</a></span> <span class="preprocessor">#define sigma1(x) (((x) >> 17 | (x) << 15) ^ ((x) >> 19 | (x) << 13) ^ ((x) >> 10))</span></div><div class="line"><a name="l00022"></a><span class="lineno"> 22</span> </div><div class="line"><a name="l00023"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f"> 23</a></span> <span class="preprocessor">#define Round(a,b,c,d,e,f,g,h,k,w) do { \</span></div><div class="line"><a name="l00024"></a><span class="lineno"> 24</span> <span class="preprocessor"> uint32_t t1 = (h) + Sigma1(e) + Ch((e), (f), (g)) + (k) + (w); \</span></div><div class="line"><a name="l00025"></a><span class="lineno"> 25</span> <span class="preprocessor"> uint32_t t2 = Sigma0(a) + Maj((a), (b), (c)); \</span></div><div class="line"><a name="l00026"></a><span class="lineno"> 26</span> <span class="preprocessor"> (d) += t1; \</span></div><div class="line"><a name="l00027"></a><span class="lineno"> 27</span> <span class="preprocessor"> (h) = t1 + t2; \</span></div><div class="line"><a name="l00028"></a><span class="lineno"> 28</span> <span class="preprocessor">} while(0)</span></div><div class="line"><a name="l00029"></a><span class="lineno"> 29</span> </div><div class="line"><a name="l00030"></a><span class="lineno"> 30</span> <span class="preprocessor">#ifdef WORDS_BIGENDIAN</span></div><div class="line"><a name="l00031"></a><span class="lineno"> 31</span> <span class="preprocessor">#define BE32(x) (x)</span></div><div class="line"><a name="l00032"></a><span class="lineno"> 32</span> <span class="preprocessor">#else</span></div><div class="line"><a name="l00033"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e"> 33</a></span> <span class="preprocessor">#define BE32(p) ((((p) & 0xFF) << 24) | (((p) & 0xFF00) << 8) | (((p) & 0xFF0000) >> 8) | (((p) & 0xFF000000) >> 24))</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> </div><div class="line"><a name="l00036"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#abcb6a95ed605c2bfb19eda1ced4a8f7e"> 36</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#abcb6a95ed605c2bfb19eda1ced4a8f7e">secp256k1_sha256_initialize</a>(<a class="code" href="structsecp256k1__sha256__t.html">secp256k1_sha256_t</a> *hash) {</div><div class="line"><a name="l00037"></a><span class="lineno"> 37</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[0] = 0x6a09e667ul;</div><div class="line"><a name="l00038"></a><span class="lineno"> 38</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[1] = 0xbb67ae85ul;</div><div class="line"><a name="l00039"></a><span class="lineno"> 39</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[2] = 0x3c6ef372ul;</div><div class="line"><a name="l00040"></a><span class="lineno"> 40</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[3] = 0xa54ff53aul;</div><div class="line"><a name="l00041"></a><span class="lineno"> 41</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[4] = 0x510e527ful;</div><div class="line"><a name="l00042"></a><span class="lineno"> 42</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[5] = 0x9b05688cul;</div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[6] = 0x1f83d9abul;</div><div class="line"><a name="l00044"></a><span class="lineno"> 44</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[7] = 0x5be0cd19ul;</div><div class="line"><a name="l00045"></a><span class="lineno"> 45</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#aa427890685bc0a6db0e892d08b1918b8">bytes</a> = 0;</div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span> }</div><div class="line"><a name="l00047"></a><span class="lineno"> 47</span> </div><div class="line"><a name="l00049"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#aca0644b78a0554cae2f366702abf0b09"> 49</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#aca0644b78a0554cae2f366702abf0b09">secp256k1_sha256_transform</a>(uint32_t* s, <span class="keyword">const</span> uint32_t* chunk) {</div><div class="line"><a name="l00050"></a><span class="lineno"> 50</span>  uint32_t a = s[0], b = s[1], c = s[2], d = s[3], e = s[4], <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a> = s[5], g = s[6], h = s[7];</div><div class="line"><a name="l00051"></a><span class="lineno"> 51</span>  uint32_t w0, w1, w2, w3, w4, w5, w6, w7, w8, w9, w10, w11, w12, w13, w14, w15;</div><div class="line"><a name="l00052"></a><span class="lineno"> 52</span> </div><div class="line"><a name="l00053"></a><span class="lineno"> 53</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, 0x428a2f98, w0 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[0]));</div><div class="line"><a name="l00054"></a><span class="lineno"> 54</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, 0x71374491, w1 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[1]));</div><div class="line"><a name="l00055"></a><span class="lineno"> 55</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(g, h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, 0xb5c0fbcf, w2 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[2]));</div><div class="line"><a name="l00056"></a><span class="lineno"> 56</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(<a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, e, 0xe9b5dba5, w3 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[3]));</div><div class="line"><a name="l00057"></a><span class="lineno"> 57</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, 0x3956c25b, w4 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[4]));</div><div class="line"><a name="l00058"></a><span class="lineno"> 58</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, 0x59f111f1, w5 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[5]));</div><div class="line"><a name="l00059"></a><span class="lineno"> 59</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, 0x923f82a4, w6 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[6]));</div><div class="line"><a name="l00060"></a><span class="lineno"> 60</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, 0xab1c5ed5, w7 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[7]));</div><div class="line"><a name="l00061"></a><span class="lineno"> 61</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, 0xd807aa98, w8 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[8]));</div><div class="line"><a name="l00062"></a><span class="lineno"> 62</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, 0x12835b01, w9 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[9]));</div><div class="line"><a name="l00063"></a><span class="lineno"> 63</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(g, h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, 0x243185be, w10 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[10]));</div><div class="line"><a name="l00064"></a><span class="lineno"> 64</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(<a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, e, 0x550c7dc3, w11 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[11]));</div><div class="line"><a name="l00065"></a><span class="lineno"> 65</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, 0x72be5d74, w12 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[12]));</div><div class="line"><a name="l00066"></a><span class="lineno"> 66</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, 0x80deb1fe, w13 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[13]));</div><div class="line"><a name="l00067"></a><span class="lineno"> 67</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, 0x9bdc06a7, w14 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[14]));</div><div class="line"><a name="l00068"></a><span class="lineno"> 68</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, 0xc19bf174, w15 = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(chunk[15]));</div><div class="line"><a name="l00069"></a><span class="lineno"> 69</span> </div><div class="line"><a name="l00070"></a><span class="lineno"> 70</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, 0xe49b69c1, w0 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w14) + w9 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w1));</div><div class="line"><a name="l00071"></a><span class="lineno"> 71</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, 0xefbe4786, w1 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w15) + w10 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w2));</div><div class="line"><a name="l00072"></a><span class="lineno"> 72</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(g, h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, 0x0fc19dc6, w2 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w0) + w11 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w3));</div><div class="line"><a name="l00073"></a><span class="lineno"> 73</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(<a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, e, 0x240ca1cc, w3 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w1) + w12 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w4));</div><div class="line"><a name="l00074"></a><span class="lineno"> 74</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, 0x2de92c6f, w4 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w2) + w13 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w5));</div><div class="line"><a name="l00075"></a><span class="lineno"> 75</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, 0x4a7484aa, w5 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w3) + w14 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w6));</div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, 0x5cb0a9dc, w6 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w4) + w15 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w7));</div><div class="line"><a name="l00077"></a><span class="lineno"> 77</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, 0x76f988da, w7 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w5) + w0 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w8));</div><div class="line"><a name="l00078"></a><span class="lineno"> 78</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, 0x983e5152, w8 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w6) + w1 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w9));</div><div class="line"><a name="l00079"></a><span class="lineno"> 79</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, 0xa831c66d, w9 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w7) + w2 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w10));</div><div class="line"><a name="l00080"></a><span class="lineno"> 80</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(g, h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, 0xb00327c8, w10 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w8) + w3 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w11));</div><div class="line"><a name="l00081"></a><span class="lineno"> 81</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(<a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, e, 0xbf597fc7, w11 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w9) + w4 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w12));</div><div class="line"><a name="l00082"></a><span class="lineno"> 82</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, 0xc6e00bf3, w12 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w10) + w5 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w13));</div><div class="line"><a name="l00083"></a><span class="lineno"> 83</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, 0xd5a79147, w13 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w11) + w6 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w14));</div><div class="line"><a name="l00084"></a><span class="lineno"> 84</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, 0x06ca6351, w14 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w12) + w7 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w15));</div><div class="line"><a name="l00085"></a><span class="lineno"> 85</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, 0x14292967, w15 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w13) + w8 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w0));</div><div class="line"><a name="l00086"></a><span class="lineno"> 86</span> </div><div class="line"><a name="l00087"></a><span class="lineno"> 87</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, 0x27b70a85, w0 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w14) + w9 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w1));</div><div class="line"><a name="l00088"></a><span class="lineno"> 88</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, 0x2e1b2138, w1 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w15) + w10 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w2));</div><div class="line"><a name="l00089"></a><span class="lineno"> 89</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(g, h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, 0x4d2c6dfc, w2 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w0) + w11 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w3));</div><div class="line"><a name="l00090"></a><span class="lineno"> 90</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(<a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, e, 0x53380d13, w3 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w1) + w12 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w4));</div><div class="line"><a name="l00091"></a><span class="lineno"> 91</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, 0x650a7354, w4 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w2) + w13 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w5));</div><div class="line"><a name="l00092"></a><span class="lineno"> 92</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, 0x766a0abb, w5 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w3) + w14 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w6));</div><div class="line"><a name="l00093"></a><span class="lineno"> 93</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, 0x81c2c92e, w6 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w4) + w15 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w7));</div><div class="line"><a name="l00094"></a><span class="lineno"> 94</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, 0x92722c85, w7 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w5) + w0 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w8));</div><div class="line"><a name="l00095"></a><span class="lineno"> 95</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, 0xa2bfe8a1, w8 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w6) + w1 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w9));</div><div class="line"><a name="l00096"></a><span class="lineno"> 96</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, 0xa81a664b, w9 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w7) + w2 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w10));</div><div class="line"><a name="l00097"></a><span class="lineno"> 97</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(g, h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, 0xc24b8b70, w10 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w8) + w3 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w11));</div><div class="line"><a name="l00098"></a><span class="lineno"> 98</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(<a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, e, 0xc76c51a3, w11 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w9) + w4 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w12));</div><div class="line"><a name="l00099"></a><span class="lineno"> 99</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, 0xd192e819, w12 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w10) + w5 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w13));</div><div class="line"><a name="l00100"></a><span class="lineno"> 100</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, 0xd6990624, w13 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w11) + w6 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w14));</div><div class="line"><a name="l00101"></a><span class="lineno"> 101</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, 0xf40e3585, w14 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w12) + w7 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w15));</div><div class="line"><a name="l00102"></a><span class="lineno"> 102</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, 0x106aa070, w15 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w13) + w8 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w0));</div><div class="line"><a name="l00103"></a><span class="lineno"> 103</span> </div><div class="line"><a name="l00104"></a><span class="lineno"> 104</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, 0x19a4c116, w0 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w14) + w9 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w1));</div><div class="line"><a name="l00105"></a><span class="lineno"> 105</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, 0x1e376c08, w1 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w15) + w10 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w2));</div><div class="line"><a name="l00106"></a><span class="lineno"> 106</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(g, h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, 0x2748774c, w2 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w0) + w11 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w3));</div><div class="line"><a name="l00107"></a><span class="lineno"> 107</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(<a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, e, 0x34b0bcb5, w3 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w1) + w12 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w4));</div><div class="line"><a name="l00108"></a><span class="lineno"> 108</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, 0x391c0cb3, w4 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w2) + w13 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w5));</div><div class="line"><a name="l00109"></a><span class="lineno"> 109</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, 0x4ed8aa4a, w5 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w3) + w14 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w6));</div><div class="line"><a name="l00110"></a><span class="lineno"> 110</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, 0x5b9cca4f, w6 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w4) + w15 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w7));</div><div class="line"><a name="l00111"></a><span class="lineno"> 111</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, 0x682e6ff3, w7 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w5) + w0 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w8));</div><div class="line"><a name="l00112"></a><span class="lineno"> 112</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, 0x748f82ee, w8 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w6) + w1 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w9));</div><div class="line"><a name="l00113"></a><span class="lineno"> 113</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, 0x78a5636f, w9 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w7) + w2 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w10));</div><div class="line"><a name="l00114"></a><span class="lineno"> 114</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(g, h, a, b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, 0x84c87814, w10 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w8) + w3 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w11));</div><div class="line"><a name="l00115"></a><span class="lineno"> 115</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(<a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, e, 0x8cc70208, w11 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w9) + w4 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w12));</div><div class="line"><a name="l00116"></a><span class="lineno"> 116</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, d, 0x90befffa, w12 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w10) + w5 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w13));</div><div class="line"><a name="l00117"></a><span class="lineno"> 117</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, c, 0xa4506ceb, w13 += <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w11) + w6 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w14));</div><div class="line"><a name="l00118"></a><span class="lineno"> 118</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, b, 0xbef9a3f7, w14 + <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w12) + w7 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w15));</div><div class="line"><a name="l00119"></a><span class="lineno"> 119</span>  <a class="code" href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a>(b, c, d, e, <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>, g, h, a, 0xc67178f2, w15 + <a class="code" href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a>(w13) + w8 + <a class="code" href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a>(w0));</div><div class="line"><a name="l00120"></a><span class="lineno"> 120</span> </div><div class="line"><a name="l00121"></a><span class="lineno"> 121</span>  s[0] += a;</div><div class="line"><a name="l00122"></a><span class="lineno"> 122</span>  s[1] += b;</div><div class="line"><a name="l00123"></a><span class="lineno"> 123</span>  s[2] += c;</div><div class="line"><a name="l00124"></a><span class="lineno"> 124</span>  s[3] += d;</div><div class="line"><a name="l00125"></a><span class="lineno"> 125</span>  s[4] += e;</div><div class="line"><a name="l00126"></a><span class="lineno"> 126</span>  s[5] += <a class="code" href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">f</a>;</div><div class="line"><a name="l00127"></a><span class="lineno"> 127</span>  s[6] += g;</div><div class="line"><a name="l00128"></a><span class="lineno"> 128</span>  s[7] += h;</div><div class="line"><a name="l00129"></a><span class="lineno"> 129</span> }</div><div class="line"><a name="l00130"></a><span class="lineno"> 130</span> </div><div class="line"><a name="l00131"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be"> 131</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be">secp256k1_sha256_write</a>(<a class="code" href="structsecp256k1__sha256__t.html">secp256k1_sha256_t</a> *hash, <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *<a class="code" href="namespacegen__base58__test__vectors.html#a8d12b07536a476098e3d74b6a79dfc9a">data</a>, <span class="keywordtype">size_t</span> len) {</div><div class="line"><a name="l00132"></a><span class="lineno"> 132</span>  <span class="keywordtype">size_t</span> bufsize = hash-><a class="code" href="structsecp256k1__sha256__t.html#aa427890685bc0a6db0e892d08b1918b8">bytes</a> & 0x3F;</div><div class="line"><a name="l00133"></a><span class="lineno"> 133</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#aa427890685bc0a6db0e892d08b1918b8">bytes</a> += len;</div><div class="line"><a name="l00134"></a><span class="lineno"> 134</span>  <span class="keywordflow">while</span> (bufsize + len >= 64) {</div><div class="line"><a name="l00135"></a><span class="lineno"> 135</span>  <span class="comment">/* Fill the buffer, and process it. */</span></div><div class="line"><a name="l00136"></a><span class="lineno"> 136</span>  <a class="code" href="glibc__compat_8cpp.html#a0f46826ab0466591e136db24394923cf">memcpy</a>(((<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>*)hash-><a class="code" href="structsecp256k1__sha256__t.html#a95b02d7e4d8902c1998f8ebb598a9168">buf</a>) + bufsize, <a class="code" href="namespacegen__base58__test__vectors.html#a8d12b07536a476098e3d74b6a79dfc9a">data</a>, 64 - bufsize);</div><div class="line"><a name="l00137"></a><span class="lineno"> 137</span>  <a class="code" href="namespacegen__base58__test__vectors.html#a8d12b07536a476098e3d74b6a79dfc9a">data</a> += 64 - bufsize;</div><div class="line"><a name="l00138"></a><span class="lineno"> 138</span>  len -= 64 - bufsize;</div><div class="line"><a name="l00139"></a><span class="lineno"> 139</span>  <a class="code" href="hash__impl_8h.html#aca0644b78a0554cae2f366702abf0b09">secp256k1_sha256_transform</a>(hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>, hash-><a class="code" href="structsecp256k1__sha256__t.html#a95b02d7e4d8902c1998f8ebb598a9168">buf</a>);</div><div class="line"><a name="l00140"></a><span class="lineno"> 140</span>  bufsize = 0;</div><div class="line"><a name="l00141"></a><span class="lineno"> 141</span>  }</div><div class="line"><a name="l00142"></a><span class="lineno"> 142</span>  <span class="keywordflow">if</span> (len) {</div><div class="line"><a name="l00143"></a><span class="lineno"> 143</span>  <span class="comment">/* Fill the buffer with what remains. */</span></div><div class="line"><a name="l00144"></a><span class="lineno"> 144</span>  <a class="code" href="glibc__compat_8cpp.html#a0f46826ab0466591e136db24394923cf">memcpy</a>(((<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>*)hash-><a class="code" href="structsecp256k1__sha256__t.html#a95b02d7e4d8902c1998f8ebb598a9168">buf</a>) + bufsize, <a class="code" href="namespacegen__base58__test__vectors.html#a8d12b07536a476098e3d74b6a79dfc9a">data</a>, len);</div><div class="line"><a name="l00145"></a><span class="lineno"> 145</span>  }</div><div class="line"><a name="l00146"></a><span class="lineno"> 146</span> }</div><div class="line"><a name="l00147"></a><span class="lineno"> 147</span> </div><div class="line"><a name="l00148"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#ab88a555e2b13d6d06e20a6a459abae08"> 148</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#ab88a555e2b13d6d06e20a6a459abae08">secp256k1_sha256_finalize</a>(<a class="code" href="structsecp256k1__sha256__t.html">secp256k1_sha256_t</a> *hash, <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *out32) {</div><div class="line"><a name="l00149"></a><span class="lineno"> 149</span>  <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> pad[64] = {0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};</div><div class="line"><a name="l00150"></a><span class="lineno"> 150</span>  uint32_t sizedesc[2];</div><div class="line"><a name="l00151"></a><span class="lineno"> 151</span>  uint32_t <a class="code" href="namespaceextract__strings__qt.html#ab8166b91ad54a98ce8450593d2a3d827">out</a>[8];</div><div class="line"><a name="l00152"></a><span class="lineno"> 152</span>  <span class="keywordtype">int</span> i = 0;</div><div class="line"><a name="l00153"></a><span class="lineno"> 153</span>  sizedesc[0] = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(hash-><a class="code" href="structsecp256k1__sha256__t.html#aa427890685bc0a6db0e892d08b1918b8">bytes</a> >> 29);</div><div class="line"><a name="l00154"></a><span class="lineno"> 154</span>  sizedesc[1] = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(hash-><a class="code" href="structsecp256k1__sha256__t.html#aa427890685bc0a6db0e892d08b1918b8">bytes</a> << 3);</div><div class="line"><a name="l00155"></a><span class="lineno"> 155</span>  <a class="code" href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be">secp256k1_sha256_write</a>(hash, pad, 1 + ((119 - (hash-><a class="code" href="structsecp256k1__sha256__t.html#aa427890685bc0a6db0e892d08b1918b8">bytes</a> % 64)) % 64));</div><div class="line"><a name="l00156"></a><span class="lineno"> 156</span>  <a class="code" href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be">secp256k1_sha256_write</a>(hash, (<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>*)sizedesc, 8);</div><div class="line"><a name="l00157"></a><span class="lineno"> 157</span>  <span class="keywordflow">for</span> (i = 0; i < 8; i++) {</div><div class="line"><a name="l00158"></a><span class="lineno"> 158</span>  <a class="code" href="namespaceextract__strings__qt.html#ab8166b91ad54a98ce8450593d2a3d827">out</a>[i] = <a class="code" href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a>(hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[i]);</div><div class="line"><a name="l00159"></a><span class="lineno"> 159</span>  hash-><a class="code" href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">s</a>[i] = 0;</div><div class="line"><a name="l00160"></a><span class="lineno"> 160</span>  }</div><div class="line"><a name="l00161"></a><span class="lineno"> 161</span>  <a class="code" href="glibc__compat_8cpp.html#a0f46826ab0466591e136db24394923cf">memcpy</a>(out32, (<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>*)<a class="code" href="namespaceextract__strings__qt.html#ab8166b91ad54a98ce8450593d2a3d827">out</a>, 32);</div><div class="line"><a name="l00162"></a><span class="lineno"> 162</span> }</div><div class="line"><a name="l00163"></a><span class="lineno"> 163</span> </div><div class="line"><a name="l00164"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0"> 164</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0">secp256k1_hmac_sha256_initialize</a>(<a class="code" href="structsecp256k1__hmac__sha256__t.html">secp256k1_hmac_sha256_t</a> *hash, <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *<a class="code" href="namespaceextract__strings__qt.html#a1b7a78cde0039f63310f11692b713dca">key</a>, <span class="keywordtype">size_t</span> keylen) {</div><div class="line"><a name="l00165"></a><span class="lineno"> 165</span>  <span class="keywordtype">int</span> <a class="code" href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">n</a>;</div><div class="line"><a name="l00166"></a><span class="lineno"> 166</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> rkey[64];</div><div class="line"><a name="l00167"></a><span class="lineno"> 167</span>  <span class="keywordflow">if</span> (keylen <= 64) {</div><div class="line"><a name="l00168"></a><span class="lineno"> 168</span>  <a class="code" href="glibc__compat_8cpp.html#a0f46826ab0466591e136db24394923cf">memcpy</a>(rkey, <a class="code" href="namespaceextract__strings__qt.html#a1b7a78cde0039f63310f11692b713dca">key</a>, keylen);</div><div class="line"><a name="l00169"></a><span class="lineno"> 169</span>  memset(rkey + keylen, 0, 64 - keylen);</div><div class="line"><a name="l00170"></a><span class="lineno"> 170</span>  } <span class="keywordflow">else</span> {</div><div class="line"><a name="l00171"></a><span class="lineno"> 171</span>  <a class="code" href="structsecp256k1__sha256__t.html">secp256k1_sha256_t</a> <a class="code" href="namespacetest__framework_1_1mininode.html#adde6b9e7f98d83e9e54668f45f7732da">sha256</a>;</div><div class="line"><a name="l00172"></a><span class="lineno"> 172</span>  <a class="code" href="hash__impl_8h.html#abcb6a95ed605c2bfb19eda1ced4a8f7e">secp256k1_sha256_initialize</a>(&<a class="code" href="namespacesha256.html">sha256</a>);</div><div class="line"><a name="l00173"></a><span class="lineno"> 173</span>  <a class="code" href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be">secp256k1_sha256_write</a>(&<a class="code" href="namespacesha256.html">sha256</a>, <a class="code" href="namespaceextract__strings__qt.html#a1b7a78cde0039f63310f11692b713dca">key</a>, keylen);</div><div class="line"><a name="l00174"></a><span class="lineno"> 174</span>  <a class="code" href="hash__impl_8h.html#ab88a555e2b13d6d06e20a6a459abae08">secp256k1_sha256_finalize</a>(&<a class="code" href="namespacesha256.html">sha256</a>, rkey);</div><div class="line"><a name="l00175"></a><span class="lineno"> 175</span>  memset(rkey + 32, 0, 32);</div><div class="line"><a name="l00176"></a><span class="lineno"> 176</span>  }</div><div class="line"><a name="l00177"></a><span class="lineno"> 177</span> </div><div class="line"><a name="l00178"></a><span class="lineno"> 178</span>  <a class="code" href="hash__impl_8h.html#abcb6a95ed605c2bfb19eda1ced4a8f7e">secp256k1_sha256_initialize</a>(&hash-><a class="code" href="structsecp256k1__hmac__sha256__t.html#a3974e44471231d09a8d282ef62e0b77a">outer</a>);</div><div class="line"><a name="l00179"></a><span class="lineno"> 179</span>  <span class="keywordflow">for</span> (<a class="code" href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">n</a> = 0; <a class="code" href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">n</a> < 64; <a class="code" href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">n</a>++) {</div><div class="line"><a name="l00180"></a><span class="lineno"> 180</span>  rkey[<a class="code" href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">n</a>] ^= 0x5c;</div><div class="line"><a name="l00181"></a><span class="lineno"> 181</span>  }</div><div class="line"><a name="l00182"></a><span class="lineno"> 182</span>  <a class="code" href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be">secp256k1_sha256_write</a>(&hash-><a class="code" href="structsecp256k1__hmac__sha256__t.html#a3974e44471231d09a8d282ef62e0b77a">outer</a>, rkey, 64);</div><div class="line"><a name="l00183"></a><span class="lineno"> 183</span> </div><div class="line"><a name="l00184"></a><span class="lineno"> 184</span>  <a class="code" href="hash__impl_8h.html#abcb6a95ed605c2bfb19eda1ced4a8f7e">secp256k1_sha256_initialize</a>(&hash-><a class="code" href="structsecp256k1__hmac__sha256__t.html#afba1e789776f5c3cd2c1e6d9e718065f">inner</a>);</div><div class="line"><a name="l00185"></a><span class="lineno"> 185</span>  <span class="keywordflow">for</span> (<a class="code" href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">n</a> = 0; <a class="code" href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">n</a> < 64; <a class="code" href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">n</a>++) {</div><div class="line"><a name="l00186"></a><span class="lineno"> 186</span>  rkey[<a class="code" href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">n</a>] ^= 0x5c ^ 0x36;</div><div class="line"><a name="l00187"></a><span class="lineno"> 187</span>  }</div><div class="line"><a name="l00188"></a><span class="lineno"> 188</span>  <a class="code" href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be">secp256k1_sha256_write</a>(&hash-><a class="code" href="structsecp256k1__hmac__sha256__t.html#afba1e789776f5c3cd2c1e6d9e718065f">inner</a>, rkey, 64);</div><div class="line"><a name="l00189"></a><span class="lineno"> 189</span>  memset(rkey, 0, 64);</div><div class="line"><a name="l00190"></a><span class="lineno"> 190</span> }</div><div class="line"><a name="l00191"></a><span class="lineno"> 191</span> </div><div class="line"><a name="l00192"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f"> 192</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(<a class="code" href="structsecp256k1__hmac__sha256__t.html">secp256k1_hmac_sha256_t</a> *hash, <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *<a class="code" href="namespacegen__base58__test__vectors.html#a8d12b07536a476098e3d74b6a79dfc9a">data</a>, <span class="keywordtype">size_t</span> size) {</div><div class="line"><a name="l00193"></a><span class="lineno"> 193</span>  <a class="code" href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be">secp256k1_sha256_write</a>(&hash-><a class="code" href="structsecp256k1__hmac__sha256__t.html#afba1e789776f5c3cd2c1e6d9e718065f">inner</a>, <a class="code" href="namespacegen__base58__test__vectors.html#a8d12b07536a476098e3d74b6a79dfc9a">data</a>, size);</div><div class="line"><a name="l00194"></a><span class="lineno"> 194</span> }</div><div class="line"><a name="l00195"></a><span class="lineno"> 195</span> </div><div class="line"><a name="l00196"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16"> 196</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16">secp256k1_hmac_sha256_finalize</a>(<a class="code" href="structsecp256k1__hmac__sha256__t.html">secp256k1_hmac_sha256_t</a> *hash, <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *out32) {</div><div class="line"><a name="l00197"></a><span class="lineno"> 197</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> temp[32];</div><div class="line"><a name="l00198"></a><span class="lineno"> 198</span>  <a class="code" href="hash__impl_8h.html#ab88a555e2b13d6d06e20a6a459abae08">secp256k1_sha256_finalize</a>(&hash-><a class="code" href="structsecp256k1__hmac__sha256__t.html#afba1e789776f5c3cd2c1e6d9e718065f">inner</a>, temp);</div><div class="line"><a name="l00199"></a><span class="lineno"> 199</span>  <a class="code" href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be">secp256k1_sha256_write</a>(&hash-><a class="code" href="structsecp256k1__hmac__sha256__t.html#a3974e44471231d09a8d282ef62e0b77a">outer</a>, temp, 32);</div><div class="line"><a name="l00200"></a><span class="lineno"> 200</span>  memset(temp, 0, 32);</div><div class="line"><a name="l00201"></a><span class="lineno"> 201</span>  <a class="code" href="hash__impl_8h.html#ab88a555e2b13d6d06e20a6a459abae08">secp256k1_sha256_finalize</a>(&hash-><a class="code" href="structsecp256k1__hmac__sha256__t.html#a3974e44471231d09a8d282ef62e0b77a">outer</a>, out32);</div><div class="line"><a name="l00202"></a><span class="lineno"> 202</span> }</div><div class="line"><a name="l00203"></a><span class="lineno"> 203</span> </div><div class="line"><a name="l00204"></a><span class="lineno"> 204</span> </div><div class="line"><a name="l00205"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a9dd561651b3373fe94e80295dfdd43a7"> 205</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#a9dd561651b3373fe94e80295dfdd43a7">secp256k1_rfc6979_hmac_sha256_initialize</a>(<a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html">secp256k1_rfc6979_hmac_sha256_t</a> *rng, <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *<a class="code" href="namespaceextract__strings__qt.html#a1b7a78cde0039f63310f11692b713dca">key</a>, <span class="keywordtype">size_t</span> keylen) {</div><div class="line"><a name="l00206"></a><span class="lineno"> 206</span>  <a class="code" href="structsecp256k1__hmac__sha256__t.html">secp256k1_hmac_sha256_t</a> hmac;</div><div class="line"><a name="l00207"></a><span class="lineno"> 207</span>  <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> zero[1] = {0x00};</div><div class="line"><a name="l00208"></a><span class="lineno"> 208</span>  <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> one[1] = {0x01};</div><div class="line"><a name="l00209"></a><span class="lineno"> 209</span> </div><div class="line"><a name="l00210"></a><span class="lineno"> 210</span>  memset(rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, 0x01, 32); <span class="comment">/* RFC6979 3.2.b. */</span></div><div class="line"><a name="l00211"></a><span class="lineno"> 211</span>  memset(rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>, 0x00, 32); <span class="comment">/* RFC6979 3.2.c. */</span></div><div class="line"><a name="l00212"></a><span class="lineno"> 212</span> </div><div class="line"><a name="l00213"></a><span class="lineno"> 213</span>  <span class="comment">/* RFC6979 3.2.d. */</span></div><div class="line"><a name="l00214"></a><span class="lineno"> 214</span>  <a class="code" href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0">secp256k1_hmac_sha256_initialize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>, 32);</div><div class="line"><a name="l00215"></a><span class="lineno"> 215</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, 32);</div><div class="line"><a name="l00216"></a><span class="lineno"> 216</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, zero, 1);</div><div class="line"><a name="l00217"></a><span class="lineno"> 217</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, <a class="code" href="namespaceextract__strings__qt.html#a1b7a78cde0039f63310f11692b713dca">key</a>, keylen);</div><div class="line"><a name="l00218"></a><span class="lineno"> 218</span>  <a class="code" href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16">secp256k1_hmac_sha256_finalize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>);</div><div class="line"><a name="l00219"></a><span class="lineno"> 219</span>  <a class="code" href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0">secp256k1_hmac_sha256_initialize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>, 32);</div><div class="line"><a name="l00220"></a><span class="lineno"> 220</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, 32);</div><div class="line"><a name="l00221"></a><span class="lineno"> 221</span>  <a class="code" href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16">secp256k1_hmac_sha256_finalize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>);</div><div class="line"><a name="l00222"></a><span class="lineno"> 222</span> </div><div class="line"><a name="l00223"></a><span class="lineno"> 223</span>  <span class="comment">/* RFC6979 3.2.f. */</span></div><div class="line"><a name="l00224"></a><span class="lineno"> 224</span>  <a class="code" href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0">secp256k1_hmac_sha256_initialize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>, 32);</div><div class="line"><a name="l00225"></a><span class="lineno"> 225</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, 32);</div><div class="line"><a name="l00226"></a><span class="lineno"> 226</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, one, 1);</div><div class="line"><a name="l00227"></a><span class="lineno"> 227</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, <a class="code" href="namespaceextract__strings__qt.html#a1b7a78cde0039f63310f11692b713dca">key</a>, keylen);</div><div class="line"><a name="l00228"></a><span class="lineno"> 228</span>  <a class="code" href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16">secp256k1_hmac_sha256_finalize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>);</div><div class="line"><a name="l00229"></a><span class="lineno"> 229</span>  <a class="code" href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0">secp256k1_hmac_sha256_initialize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>, 32);</div><div class="line"><a name="l00230"></a><span class="lineno"> 230</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, 32);</div><div class="line"><a name="l00231"></a><span class="lineno"> 231</span>  <a class="code" href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16">secp256k1_hmac_sha256_finalize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>);</div><div class="line"><a name="l00232"></a><span class="lineno"> 232</span>  rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#a533be4a8cc6bf3112ca8c64cda3236a8">retry</a> = 0;</div><div class="line"><a name="l00233"></a><span class="lineno"> 233</span> }</div><div class="line"><a name="l00234"></a><span class="lineno"> 234</span> </div><div class="line"><a name="l00235"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a993c3261472ef00e4738e0fe7a99b7cb"> 235</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#a993c3261472ef00e4738e0fe7a99b7cb">secp256k1_rfc6979_hmac_sha256_generate</a>(<a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html">secp256k1_rfc6979_hmac_sha256_t</a> *rng, <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> *<a class="code" href="namespaceextract__strings__qt.html#ab8166b91ad54a98ce8450593d2a3d827">out</a>, <span class="keywordtype">size_t</span> outlen) {</div><div class="line"><a name="l00236"></a><span class="lineno"> 236</span>  <span class="comment">/* RFC6979 3.2.h. */</span></div><div class="line"><a name="l00237"></a><span class="lineno"> 237</span>  <span class="keyword">static</span> <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> zero[1] = {0x00};</div><div class="line"><a name="l00238"></a><span class="lineno"> 238</span>  <span class="keywordflow">if</span> (rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#a533be4a8cc6bf3112ca8c64cda3236a8">retry</a>) {</div><div class="line"><a name="l00239"></a><span class="lineno"> 239</span>  <a class="code" href="structsecp256k1__hmac__sha256__t.html">secp256k1_hmac_sha256_t</a> hmac;</div><div class="line"><a name="l00240"></a><span class="lineno"> 240</span>  <a class="code" href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0">secp256k1_hmac_sha256_initialize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>, 32);</div><div class="line"><a name="l00241"></a><span class="lineno"> 241</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, 32);</div><div class="line"><a name="l00242"></a><span class="lineno"> 242</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, zero, 1);</div><div class="line"><a name="l00243"></a><span class="lineno"> 243</span>  <a class="code" href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16">secp256k1_hmac_sha256_finalize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>);</div><div class="line"><a name="l00244"></a><span class="lineno"> 244</span>  <a class="code" href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0">secp256k1_hmac_sha256_initialize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>, 32);</div><div class="line"><a name="l00245"></a><span class="lineno"> 245</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, 32);</div><div class="line"><a name="l00246"></a><span class="lineno"> 246</span>  <a class="code" href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16">secp256k1_hmac_sha256_finalize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>);</div><div class="line"><a name="l00247"></a><span class="lineno"> 247</span>  }</div><div class="line"><a name="l00248"></a><span class="lineno"> 248</span> </div><div class="line"><a name="l00249"></a><span class="lineno"> 249</span>  <span class="keywordflow">while</span> (outlen > 0) {</div><div class="line"><a name="l00250"></a><span class="lineno"> 250</span>  <a class="code" href="structsecp256k1__hmac__sha256__t.html">secp256k1_hmac_sha256_t</a> hmac;</div><div class="line"><a name="l00251"></a><span class="lineno"> 251</span>  <span class="keywordtype">int</span> now = outlen;</div><div class="line"><a name="l00252"></a><span class="lineno"> 252</span>  <a class="code" href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0">secp256k1_hmac_sha256_initialize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>, 32);</div><div class="line"><a name="l00253"></a><span class="lineno"> 253</span>  <a class="code" href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, 32);</div><div class="line"><a name="l00254"></a><span class="lineno"> 254</span>  <a class="code" href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16">secp256k1_hmac_sha256_finalize</a>(&hmac, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>);</div><div class="line"><a name="l00255"></a><span class="lineno"> 255</span>  <span class="keywordflow">if</span> (now > 32) {</div><div class="line"><a name="l00256"></a><span class="lineno"> 256</span>  now = 32;</div><div class="line"><a name="l00257"></a><span class="lineno"> 257</span>  }</div><div class="line"><a name="l00258"></a><span class="lineno"> 258</span>  <a class="code" href="glibc__compat_8cpp.html#a0f46826ab0466591e136db24394923cf">memcpy</a>(<a class="code" href="namespaceextract__strings__qt.html#ab8166b91ad54a98ce8450593d2a3d827">out</a>, rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, now);</div><div class="line"><a name="l00259"></a><span class="lineno"> 259</span>  <a class="code" href="namespaceextract__strings__qt.html#ab8166b91ad54a98ce8450593d2a3d827">out</a> += now;</div><div class="line"><a name="l00260"></a><span class="lineno"> 260</span>  outlen -= now;</div><div class="line"><a name="l00261"></a><span class="lineno"> 261</span>  }</div><div class="line"><a name="l00262"></a><span class="lineno"> 262</span> </div><div class="line"><a name="l00263"></a><span class="lineno"> 263</span>  rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#a533be4a8cc6bf3112ca8c64cda3236a8">retry</a> = 1;</div><div class="line"><a name="l00264"></a><span class="lineno"> 264</span> }</div><div class="line"><a name="l00265"></a><span class="lineno"> 265</span> </div><div class="line"><a name="l00266"></a><span class="lineno"><a class="line" href="hash__impl_8h.html#a27832ea2666bbf9e5c7a18559660e9da"> 266</a></span> <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="hash__impl_8h.html#a27832ea2666bbf9e5c7a18559660e9da">secp256k1_rfc6979_hmac_sha256_finalize</a>(<a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html">secp256k1_rfc6979_hmac_sha256_t</a> *rng) {</div><div class="line"><a name="l00267"></a><span class="lineno"> 267</span>  memset(rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">k</a>, 0, 32);</div><div class="line"><a name="l00268"></a><span class="lineno"> 268</span>  memset(rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">v</a>, 0, 32);</div><div class="line"><a name="l00269"></a><span class="lineno"> 269</span>  rng-><a class="code" href="structsecp256k1__rfc6979__hmac__sha256__t.html#a533be4a8cc6bf3112ca8c64cda3236a8">retry</a> = 0;</div><div class="line"><a name="l00270"></a><span class="lineno"> 270</span> }</div><div class="line"><a name="l00271"></a><span class="lineno"> 271</span> </div><div class="line"><a name="l00272"></a><span class="lineno"> 272</span> </div><div class="line"><a name="l00273"></a><span class="lineno"> 273</span> <span class="preprocessor">#undef Round</span></div><div class="line"><a name="l00274"></a><span class="lineno"> 274</span> <span class="preprocessor">#undef sigma0</span></div><div class="line"><a name="l00275"></a><span class="lineno"> 275</span> <span class="preprocessor">#undef sigma1</span></div><div class="line"><a name="l00276"></a><span class="lineno"> 276</span> <span class="preprocessor">#undef Sigma0</span></div><div class="line"><a name="l00277"></a><span class="lineno"> 277</span> <span class="preprocessor">#undef Sigma1</span></div><div class="line"><a name="l00278"></a><span class="lineno"> 278</span> <span class="preprocessor">#undef Ch</span></div><div class="line"><a name="l00279"></a><span class="lineno"> 279</span> <span class="preprocessor">#undef Maj</span></div><div class="line"><a name="l00280"></a><span class="lineno"> 280</span> <span class="preprocessor">#undef ReadBE32</span></div><div class="line"><a name="l00281"></a><span class="lineno"> 281</span> <span class="preprocessor">#undef WriteBE32</span></div><div class="line"><a name="l00282"></a><span class="lineno"> 282</span> </div><div class="line"><a name="l00283"></a><span class="lineno"> 283</span> <span class="preprocessor">#endif</span></div><div class="ttc" id="structsecp256k1__hmac__sha256__t_html_a3974e44471231d09a8d282ef62e0b77a"><div class="ttname"><a href="structsecp256k1__hmac__sha256__t.html#a3974e44471231d09a8d282ef62e0b77a">secp256k1_hmac_sha256_t::outer</a></div><div class="ttdeci">secp256k1_sha256_t outer</div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00024">hash.h:24</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a078ac2e7574c2c3d1eb1ccc0950e84d0"><div class="ttname"><a href="hash__impl_8h.html#a078ac2e7574c2c3d1eb1ccc0950e84d0">secp256k1_hmac_sha256_initialize</a></div><div class="ttdeci">static void secp256k1_hmac_sha256_initialize(secp256k1_hmac_sha256_t *hash, const unsigned char *key, size_t keylen)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00164">hash_impl.h:164</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a4a6398f77b0cf603722649d4fd67260f"><div class="ttname"><a href="hash__impl_8h.html#a4a6398f77b0cf603722649d4fd67260f">Round</a></div><div class="ttdeci">#define Round(a, b, c, d, e, f, g, h, k, w)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00023">hash_impl.h:23</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__sha256__t_html_a95b02d7e4d8902c1998f8ebb598a9168"><div class="ttname"><a href="structsecp256k1__sha256__t.html#a95b02d7e4d8902c1998f8ebb598a9168">secp256k1_sha256_t::buf</a></div><div class="ttdeci">uint32_t buf[16]</div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00015">hash.h:15</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a1d0e2eaadc95216b3a3c775409a6093e"><div class="ttname"><a href="hash__impl_8h.html#a1d0e2eaadc95216b3a3c775409a6093e">BE32</a></div><div class="ttdeci">#define BE32(p)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00033">hash_impl.h:33</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_ada7b815d52a8a6f79bafe205983693be"><div class="ttname"><a href="hash__impl_8h.html#ada7b815d52a8a6f79bafe205983693be">secp256k1_sha256_write</a></div><div class="ttdeci">static void secp256k1_sha256_write(secp256k1_sha256_t *hash, const unsigned char *data, size_t len)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00131">hash_impl.h:131</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__rfc6979__hmac__sha256__t_html"><div class="ttname"><a href="structsecp256k1__rfc6979__hmac__sha256__t.html">secp256k1_rfc6979_hmac_sha256_t</a></div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00031">hash.h:31</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_ab88a555e2b13d6d06e20a6a459abae08"><div class="ttname"><a href="hash__impl_8h.html#ab88a555e2b13d6d06e20a6a459abae08">secp256k1_sha256_finalize</a></div><div class="ttdeci">static void secp256k1_sha256_finalize(secp256k1_sha256_t *hash, unsigned char *out32)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00148">hash_impl.h:148</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a0347251dc63b7abe5d4c500544c24a97"><div class="ttname"><a href="hash__impl_8h.html#a0347251dc63b7abe5d4c500544c24a97">sigma1</a></div><div class="ttdeci">#define sigma1(x)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00021">hash_impl.h:21</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a672bd39bdf2f6dc295a23ddd109175ff"><div class="ttname"><a href="hash__impl_8h.html#a672bd39bdf2f6dc295a23ddd109175ff">sigma0</a></div><div class="ttdeci">#define sigma0(x)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00020">hash_impl.h:20</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a6f85fe02b7546db62cc03adb03613d16"><div class="ttname"><a href="hash__impl_8h.html#a6f85fe02b7546db62cc03adb03613d16">secp256k1_hmac_sha256_finalize</a></div><div class="ttdeci">static void secp256k1_hmac_sha256_finalize(secp256k1_hmac_sha256_t *hash, unsigned char *out32)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00196">hash_impl.h:196</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__hmac__sha256__t_html_afba1e789776f5c3cd2c1e6d9e718065f"><div class="ttname"><a href="structsecp256k1__hmac__sha256__t.html#afba1e789776f5c3cd2c1e6d9e718065f">secp256k1_hmac_sha256_t::inner</a></div><div class="ttdeci">secp256k1_sha256_t inner</div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00024">hash.h:24</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a985f5f05c10dca7f592541d95c84081f"><div class="ttname"><a href="hash__impl_8h.html#a985f5f05c10dca7f592541d95c84081f">secp256k1_hmac_sha256_write</a></div><div class="ttdeci">static void secp256k1_hmac_sha256_write(secp256k1_hmac_sha256_t *hash, const unsigned char *data, size_t size)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00192">hash_impl.h:192</a></div></div>
|
|
<div class="ttc" id="namespacegen__base58__test__vectors_html_a8d12b07536a476098e3d74b6a79dfc9a"><div class="ttname"><a href="namespacegen__base58__test__vectors.html#a8d12b07536a476098e3d74b6a79dfc9a">gen_base58_test_vectors.data</a></div><div class="ttdeci">data</div><div class="ttdef"><b>Definition:</b> <a href="gen__base58__test__vectors_8py_source.html#l00123">gen_base58_test_vectors.py:123</a></div></div>
|
|
<div class="ttc" id="namespacelinearize-data_html_a7152f36cc709b89cef1e223d140137ab"><div class="ttname"><a href="namespacelinearize-data.html#a7152f36cc709b89cef1e223d140137ab">linearize-data.f</a></div><div class="ttdeci">f</div><div class="ttdef"><b>Definition:</b> <a href="linearize-data_8py_source.html#l00257">linearize-data.py:257</a></div></div>
|
|
<div class="ttc" id="namespacefix-copyright-headers_html_aed10e06fbf20b2e50f73ff2d61f59e45"><div class="ttname"><a href="namespacefix-copyright-headers.html#aed10e06fbf20b2e50f73ff2d61f59e45">fix-copyright-headers.n</a></div><div class="ttdeci">int n</div><div class="ttdef"><b>Definition:</b> <a href="fix-copyright-headers_8py_source.html#l00046">fix-copyright-headers.py:46</a></div></div>
|
|
<div class="ttc" id="namespacetest__framework_1_1mininode_html_adde6b9e7f98d83e9e54668f45f7732da"><div class="ttname"><a href="namespacetest__framework_1_1mininode.html#adde6b9e7f98d83e9e54668f45f7732da">test_framework.mininode.sha256</a></div><div class="ttdeci">def sha256(s)</div><div class="ttdef"><b>Definition:</b> <a href="mininode_8py_source.html#l00060">mininode.py:60</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a9dd561651b3373fe94e80295dfdd43a7"><div class="ttname"><a href="hash__impl_8h.html#a9dd561651b3373fe94e80295dfdd43a7">secp256k1_rfc6979_hmac_sha256_initialize</a></div><div class="ttdeci">static void secp256k1_rfc6979_hmac_sha256_initialize(secp256k1_rfc6979_hmac_sha256_t *rng, const unsigned char *key, size_t keylen)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00205">hash_impl.h:205</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_abcb6a95ed605c2bfb19eda1ced4a8f7e"><div class="ttname"><a href="hash__impl_8h.html#abcb6a95ed605c2bfb19eda1ced4a8f7e">secp256k1_sha256_initialize</a></div><div class="ttdeci">static void secp256k1_sha256_initialize(secp256k1_sha256_t *hash)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00036">hash_impl.h:36</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__rfc6979__hmac__sha256__t_html_acce53d5308c7d406245a07e5dde49e78"><div class="ttname"><a href="structsecp256k1__rfc6979__hmac__sha256__t.html#acce53d5308c7d406245a07e5dde49e78">secp256k1_rfc6979_hmac_sha256_t::v</a></div><div class="ttdeci">unsigned char v[32]</div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00032">hash.h:32</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__sha256__t_html"><div class="ttname"><a href="structsecp256k1__sha256__t.html">secp256k1_sha256_t</a></div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00013">hash.h:13</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_aca0644b78a0554cae2f366702abf0b09"><div class="ttname"><a href="hash__impl_8h.html#aca0644b78a0554cae2f366702abf0b09">secp256k1_sha256_transform</a></div><div class="ttdeci">static void secp256k1_sha256_transform(uint32_t *s, const uint32_t *chunk)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00049">hash_impl.h:49</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a27832ea2666bbf9e5c7a18559660e9da"><div class="ttname"><a href="hash__impl_8h.html#a27832ea2666bbf9e5c7a18559660e9da">secp256k1_rfc6979_hmac_sha256_finalize</a></div><div class="ttdeci">static void secp256k1_rfc6979_hmac_sha256_finalize(secp256k1_rfc6979_hmac_sha256_t *rng)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00266">hash_impl.h:266</a></div></div>
|
|
<div class="ttc" id="secp256k1_2src_2hash_8h_html"><div class="ttname"><a href="secp256k1_2src_2hash_8h.html">hash.h</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__sha256__t_html_aa427890685bc0a6db0e892d08b1918b8"><div class="ttname"><a href="structsecp256k1__sha256__t.html#aa427890685bc0a6db0e892d08b1918b8">secp256k1_sha256_t::bytes</a></div><div class="ttdeci">size_t bytes</div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00016">hash.h:16</a></div></div>
|
|
<div class="ttc" id="glibc__compat_8cpp_html_a0f46826ab0466591e136db24394923cf"><div class="ttname"><a href="glibc__compat_8cpp.html#a0f46826ab0466591e136db24394923cf">memcpy</a></div><div class="ttdeci">void * memcpy(void *a, const void *b, size_t c)</div><div class="ttdef"><b>Definition:</b> <a href="glibc__compat_8cpp_source.html#l00017">glibc_compat.cpp:17</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__hmac__sha256__t_html"><div class="ttname"><a href="structsecp256k1__hmac__sha256__t.html">secp256k1_hmac_sha256_t</a></div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00023">hash.h:23</a></div></div>
|
|
<div class="ttc" id="namespacesha256_html"><div class="ttname"><a href="namespacesha256.html">sha256</a></div><div class="ttdoc">Internal SHA-256 implementation. </div><div class="ttdef"><b>Definition:</b> <a href="sha256_8cpp_source.html#l00015">sha256.cpp:15</a></div></div>
|
|
<div class="ttc" id="hash__impl_8h_html_a993c3261472ef00e4738e0fe7a99b7cb"><div class="ttname"><a href="hash__impl_8h.html#a993c3261472ef00e4738e0fe7a99b7cb">secp256k1_rfc6979_hmac_sha256_generate</a></div><div class="ttdeci">static void secp256k1_rfc6979_hmac_sha256_generate(secp256k1_rfc6979_hmac_sha256_t *rng, unsigned char *out, size_t outlen)</div><div class="ttdef"><b>Definition:</b> <a href="hash__impl_8h_source.html#l00235">hash_impl.h:235</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__sha256__t_html_ae795b4d52e123353b971540e366ca9cd"><div class="ttname"><a href="structsecp256k1__sha256__t.html#ae795b4d52e123353b971540e366ca9cd">secp256k1_sha256_t::s</a></div><div class="ttdeci">uint32_t s[32]</div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00014">hash.h:14</a></div></div>
|
|
<div class="ttc" id="namespaceextract__strings__qt_html_ab8166b91ad54a98ce8450593d2a3d827"><div class="ttname"><a href="namespaceextract__strings__qt.html#ab8166b91ad54a98ce8450593d2a3d827">extract_strings_qt.out</a></div><div class="ttdeci">out</div><div class="ttdef"><b>Definition:</b> <a href="extract__strings__qt_8py_source.html#l00056">extract_strings_qt.py:56</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__rfc6979__hmac__sha256__t_html_a533be4a8cc6bf3112ca8c64cda3236a8"><div class="ttname"><a href="structsecp256k1__rfc6979__hmac__sha256__t.html#a533be4a8cc6bf3112ca8c64cda3236a8">secp256k1_rfc6979_hmac_sha256_t::retry</a></div><div class="ttdeci">int retry</div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00034">hash.h:34</a></div></div>
|
|
<div class="ttc" id="namespaceextract__strings__qt_html_a1b7a78cde0039f63310f11692b713dca"><div class="ttname"><a href="namespaceextract__strings__qt.html#a1b7a78cde0039f63310f11692b713dca">extract_strings_qt.key</a></div><div class="ttdeci">key</div><div class="ttdef"><b>Definition:</b> <a href="extract__strings__qt_8py_source.html#l00073">extract_strings_qt.py:73</a></div></div>
|
|
<div class="ttc" id="structsecp256k1__rfc6979__hmac__sha256__t_html_add18bee94ca2a67fb59f2188e505ad52"><div class="ttname"><a href="structsecp256k1__rfc6979__hmac__sha256__t.html#add18bee94ca2a67fb59f2188e505ad52">secp256k1_rfc6979_hmac_sha256_t::k</a></div><div class="ttdeci">unsigned char k[32]</div><div class="ttdef"><b>Definition:</b> <a href="secp256k1_2src_2hash_8h_source.html#l00033">hash.h:33</a></div></div>
|
|
</div><!-- fragment --></div><!-- contents -->
|
|
</div><!-- doc-content -->
|
|
<!-- start footer part -->
|
|
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
|
|
<ul>
|
|
<li class="navelem"><a class="el" href="dir_68267d1309a1af8e8297ef4c3efbcdba.html">src</a></li><li class="navelem"><a class="el" href="dir_44f34d1e62fda08bdb4ca69ab2d205ae.html">secp256k1</a></li><li class="navelem"><a class="el" href="dir_8db2ef784512d48b2a7d00369dfaac28.html">src</a></li><li class="navelem"><a class="el" href="hash__impl_8h.html">hash_impl.h</a></li>
|
|
<li class="footer">Generated on Thu Dec 14 2017 13:15:08 for Dash Core by
|
|
<a href="http://www.doxygen.org/index.html">
|
|
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.14 </li>
|
|
</ul>
|
|
</div>
|
|
</body>
|
|
</html>
|