1 <!-- HTML header for doxygen 1.8.20-->
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml">
5 <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
6 <meta http-equiv="X-UA-Compatible" content="IE=9"/>
7 <meta name="generator" content="Doxygen 1.9.4"/>
8 <meta name="viewport" content="width=device-width, initial-scale=1"/>
9 <title>Raspberry Pi Pico SDK: hardware_sha256</title>
10 <!-- <link href="tabs.css" rel="stylesheet" type="text/css"/> -->
11 <script type="text/javascript" src="jquery.js"></script>
12 <script type="text/javascript" src="dynsections.js"></script>
13 <link href="navtree.css" rel="stylesheet" type="text/css"/>
14 <script type="text/javascript" src="resize.js"></script>
15 <script type="text/javascript" src="navtreedata.js"></script>
16 <script type="text/javascript" src="navtree.js"></script>
17 <link href="search/search.css" rel="stylesheet" type="text/css"/>
18 <script type="text/javascript" src="search/searchdata.js"></script>
19 <script type="text/javascript" src="search/search.js"></script>
20 <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500&display=swap" rel="stylesheet">
21 <link href="doxygen.css" rel="stylesheet" type="text/css" />
22 <link href="normalise.css" rel="stylesheet" type="text/css"/>
23 <link href="main.css" rel="stylesheet" type="text/css"/>
24 <link href="styles.css" rel="stylesheet" type="text/css"/>
27 <div class="navigation-mobile">
28 <div class="logo--mobile">
29 <a href="/"><img src="logo-mobile.svg" alt="Raspberry Pi"></a>
31 <div class="navigation-toggle">
32 <span class="line-1"></span>
36 <span class="line-3"></span>
39 <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
41 <a href="index.html"> <img src="logo.svg" alt="Raspberry Pi"></a>
42 <span style="display: inline-block; margin-top: 10px;">
46 <div class="navigation-footer">
47 <img src="logo-mobile.svg" alt="Raspberry Pi">
48 <a href="https://www.raspberrypi.com/" target="_blank">By Raspberry Pi Ltd</a>
50 <!-- <div class="search">
52 <input type="search" name="search" id="search" placeholder="Search">
53 <input type="submit" value="Search">
56 <!-- Generated by Doxygen 1.9.4 -->
57 <script type="text/javascript">
58 /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
59 var searchBox = new SearchBox("searchBox", "search",'Search','.html');
62 <script type="text/javascript" src="menudata.js"></script>
63 <script type="text/javascript" src="menu.js"></script>
64 <script type="text/javascript">
65 /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
67 initMenu('',true,false,'search.php','Search');
68 $(document).ready(function() { init_search(); });
72 <div id="main-nav"></div>
74 <div id="side-nav" class="ui-resizable side-nav-resizable">
76 <div id="nav-tree-contents">
77 <div id="nav-sync" class="sync"></div>
80 <div id="splitbar" style="-moz-user-select:none;"
81 class="ui-resizable-handle">
84 <script type="text/javascript">
85 /* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
86 $(document).ready(function(){initNavTree('group__hardware__sha256.html',''); initResizable(); });
89 <div id="doc-content">
90 <!-- window showing the filter options -->
91 <div id="MSearchSelectWindow"
92 onmouseover="return searchBox.OnSearchSelectShow()"
93 onmouseout="return searchBox.OnSearchSelectHide()"
94 onkeydown="return searchBox.OnSearchSelectKey(event)">
97 <!-- iframe showing the search results (closed by default) -->
98 <div id="MSearchResultsWindow">
99 <iframe src="javascript:void(0)" frameborder="0"
100 name="MSearchResults" id="MSearchResults">
105 <div class="summary">
106 <a href="#nested-classes">Data Structures</a> |
107 <a href="#define-members">Macros</a> |
108 <a href="#enum-members">Enumerations</a> |
109 <a href="#func-members">Functions</a> </div>
110 <div class="headertitle"><div class="title">hardware_sha256<div class="ingroups"><a class="el" href="group__hardware.html">Hardware APIs</a></div></div></div>
112 <div class="contents">
114 <p>Hardware SHA-256 Accelerator API.
115 <a href="#details">More...</a></p>
116 <table class="memberdecls">
117 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a>
118 Data Structures</h2></td></tr>
119 <tr class="memitem:"><td class="memItemLeft" align="right" valign="top">union  </td><td class="memItemRight" valign="bottom"><a class="el" href="unionsha256__result__t.html">sha256_result_t</a></td></tr>
120 <tr class="memdesc:"><td class="mdescLeft"> </td><td class="mdescRight">SHA-256 result generated by the API. <a href="unionsha256__result__t.html#details">More...</a><br /></td></tr>
121 <tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr>
122 </table><table class="memberdecls">
123 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a>
124 Macros</h2></td></tr>
125 <tr class="memitem:ga08a18381a4c5a7c9f7d0d1b6550621a3"><td class="memItemLeft" align="right" valign="top"><a id="ga08a18381a4c5a7c9f7d0d1b6550621a3" name="ga08a18381a4c5a7c9f7d0d1b6550621a3"></a>
126 #define </td><td class="memItemRight" valign="bottom"><b>SHA256_RESULT_BYTES</b>   32</td></tr>
127 <tr class="memdesc:ga08a18381a4c5a7c9f7d0d1b6550621a3"><td class="mdescLeft"> </td><td class="mdescRight">Size of a sha256 result in bytes. <br /></td></tr>
128 <tr class="separator:ga08a18381a4c5a7c9f7d0d1b6550621a3"><td class="memSeparator" colspan="2"> </td></tr>
129 </table><table class="memberdecls">
130 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="enum-members" name="enum-members"></a>
131 Enumerations</h2></td></tr>
132 <tr class="memitem:gaaf3089af3667088256de5d352973d5e6"><td class="memItemLeft" align="right" valign="top">enum  </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#gaaf3089af3667088256de5d352973d5e6">sha256_endianness</a> { <a class="el" href="group__hardware__sha256.html#ggaaf3089af3667088256de5d352973d5e6af7be52b37d04b7ffbd9ba69ba6cad8fd">SHA256_LITTLE_ENDIAN</a>
133 , <a class="el" href="group__hardware__sha256.html#ggaaf3089af3667088256de5d352973d5e6a9ed40fa208beaabfc2fc5b8edbd652c1">SHA256_BIG_ENDIAN</a>
135 <tr class="memdesc:gaaf3089af3667088256de5d352973d5e6"><td class="mdescLeft"> </td><td class="mdescRight">SHA-256 endianness definition used in the API. <a href="group__hardware__sha256.html#gaaf3089af3667088256de5d352973d5e6">More...</a><br /></td></tr>
136 <tr class="separator:gaaf3089af3667088256de5d352973d5e6"><td class="memSeparator" colspan="2"> </td></tr>
137 </table><table class="memberdecls">
138 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a>
139 Functions</h2></td></tr>
140 <tr class="memitem:ga4f35e6d85d8991216e9c1edd7e682cc7"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#ga4f35e6d85d8991216e9c1edd7e682cc7">sha256_set_dma_size</a> (uint size_in_bytes)</td></tr>
141 <tr class="memdesc:ga4f35e6d85d8991216e9c1edd7e682cc7"><td class="mdescLeft"> </td><td class="mdescRight">Configure the correct DMA data size. <a href="group__hardware__sha256.html#ga4f35e6d85d8991216e9c1edd7e682cc7">More...</a><br /></td></tr>
142 <tr class="separator:ga4f35e6d85d8991216e9c1edd7e682cc7"><td class="memSeparator" colspan="2"> </td></tr>
143 <tr class="memitem:ga21bca5a93ccad014cc890e734c9436eb"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#ga21bca5a93ccad014cc890e734c9436eb">sha256_set_bswap</a> (bool swap)</td></tr>
144 <tr class="memdesc:ga21bca5a93ccad014cc890e734c9436eb"><td class="mdescLeft"> </td><td class="mdescRight">Enable or disable byte swapping of 32-bit values. <a href="group__hardware__sha256.html#ga21bca5a93ccad014cc890e734c9436eb">More...</a><br /></td></tr>
145 <tr class="separator:ga21bca5a93ccad014cc890e734c9436eb"><td class="memSeparator" colspan="2"> </td></tr>
146 <tr class="memitem:ga327d4bf2af7a8291cc402c569392b4d7"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#ga327d4bf2af7a8291cc402c569392b4d7">sha256_start</a> (void)</td></tr>
147 <tr class="memdesc:ga327d4bf2af7a8291cc402c569392b4d7"><td class="mdescLeft"> </td><td class="mdescRight">Prepare the hardware for a new checksum. <a href="group__hardware__sha256.html#ga327d4bf2af7a8291cc402c569392b4d7">More...</a><br /></td></tr>
148 <tr class="separator:ga327d4bf2af7a8291cc402c569392b4d7"><td class="memSeparator" colspan="2"> </td></tr>
149 <tr class="memitem:ga7e4f6ab4a7738c38d094ecd4c5ee9839"><td class="memItemLeft" align="right" valign="top">static bool </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#ga7e4f6ab4a7738c38d094ecd4c5ee9839">sha256_is_sum_valid</a> (void)</td></tr>
150 <tr class="memdesc:ga7e4f6ab4a7738c38d094ecd4c5ee9839"><td class="mdescLeft"> </td><td class="mdescRight">Check if a valid checksum has been calculated. <a href="group__hardware__sha256.html#ga7e4f6ab4a7738c38d094ecd4c5ee9839">More...</a><br /></td></tr>
151 <tr class="separator:ga7e4f6ab4a7738c38d094ecd4c5ee9839"><td class="memSeparator" colspan="2"> </td></tr>
152 <tr class="memitem:ga586dc580abe393a0eb4af052da4f9050"><td class="memItemLeft" align="right" valign="top">static bool </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#ga586dc580abe393a0eb4af052da4f9050">sha256_is_ready</a> (void)</td></tr>
153 <tr class="memdesc:ga586dc580abe393a0eb4af052da4f9050"><td class="mdescLeft"> </td><td class="mdescRight">Check if a the hardware is ready to accept more data. <a href="group__hardware__sha256.html#ga586dc580abe393a0eb4af052da4f9050">More...</a><br /></td></tr>
154 <tr class="separator:ga586dc580abe393a0eb4af052da4f9050"><td class="memSeparator" colspan="2"> </td></tr>
155 <tr class="memitem:ga98114068a397971354cd24ae75d051a6"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#ga98114068a397971354cd24ae75d051a6">sha256_wait_valid_blocking</a> (void)</td></tr>
156 <tr class="memdesc:ga98114068a397971354cd24ae75d051a6"><td class="mdescLeft"> </td><td class="mdescRight">Wait until the checksum is valid. <a href="group__hardware__sha256.html#ga98114068a397971354cd24ae75d051a6">More...</a><br /></td></tr>
157 <tr class="separator:ga98114068a397971354cd24ae75d051a6"><td class="memSeparator" colspan="2"> </td></tr>
158 <tr class="memitem:gaab29e83e6d914d262e9aaf13ed34f06e"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#gaab29e83e6d914d262e9aaf13ed34f06e">sha256_wait_ready_blocking</a> (void)</td></tr>
159 <tr class="memdesc:gaab29e83e6d914d262e9aaf13ed34f06e"><td class="mdescLeft"> </td><td class="mdescRight">Wait until the hardware is ready to accept more data. <a href="group__hardware__sha256.html#gaab29e83e6d914d262e9aaf13ed34f06e">More...</a><br /></td></tr>
160 <tr class="separator:gaab29e83e6d914d262e9aaf13ed34f06e"><td class="memSeparator" colspan="2"> </td></tr>
161 <tr class="memitem:ga065f30a83c4d96ea85712a0e22f7a62e"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#ga065f30a83c4d96ea85712a0e22f7a62e">sha256_get_result</a> (<a class="el" href="unionsha256__result__t.html">sha256_result_t</a> *out, enum <a class="el" href="group__hardware__sha256.html#gaaf3089af3667088256de5d352973d5e6">sha256_endianness</a> endianness)</td></tr>
162 <tr class="memdesc:ga065f30a83c4d96ea85712a0e22f7a62e"><td class="mdescLeft"> </td><td class="mdescRight">Get the checksum result. <a href="group__hardware__sha256.html#ga065f30a83c4d96ea85712a0e22f7a62e">More...</a><br /></td></tr>
163 <tr class="separator:ga065f30a83c4d96ea85712a0e22f7a62e"><td class="memSeparator" colspan="2"> </td></tr>
164 <tr class="memitem:gab26b08aabc454e46859d38acdb9afb63"><td class="memItemLeft" align="right" valign="top">static bool </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#gab26b08aabc454e46859d38acdb9afb63">sha256_err_not_ready</a> (void)</td></tr>
165 <tr class="memdesc:gab26b08aabc454e46859d38acdb9afb63"><td class="mdescLeft"> </td><td class="mdescRight">Check if data was written before the hardware was ready. <a href="group__hardware__sha256.html#gab26b08aabc454e46859d38acdb9afb63">More...</a><br /></td></tr>
166 <tr class="separator:gab26b08aabc454e46859d38acdb9afb63"><td class="memSeparator" colspan="2"> </td></tr>
167 <tr class="memitem:gaccd81a57687cf83726d87b5da4e63551"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#gaccd81a57687cf83726d87b5da4e63551">sha256_err_not_ready_clear</a> (void)</td></tr>
168 <tr class="memdesc:gaccd81a57687cf83726d87b5da4e63551"><td class="mdescLeft"> </td><td class="mdescRight">Clear the "not ready" error condition. <a href="group__hardware__sha256.html#gaccd81a57687cf83726d87b5da4e63551">More...</a><br /></td></tr>
169 <tr class="separator:gaccd81a57687cf83726d87b5da4e63551"><td class="memSeparator" colspan="2"> </td></tr>
170 <tr class="memitem:gac7b585e60910cf0e1d927a0824cd0fe1"><td class="memItemLeft" align="right" valign="top">static volatile void * </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#gac7b585e60910cf0e1d927a0824cd0fe1">sha256_get_write_addr</a> (void)</td></tr>
171 <tr class="memdesc:gac7b585e60910cf0e1d927a0824cd0fe1"><td class="mdescLeft"> </td><td class="mdescRight">Address to write the data to be hashed. <a href="group__hardware__sha256.html#gac7b585e60910cf0e1d927a0824cd0fe1">More...</a><br /></td></tr>
172 <tr class="separator:gac7b585e60910cf0e1d927a0824cd0fe1"><td class="memSeparator" colspan="2"> </td></tr>
173 <tr class="memitem:ga7d391fa299a4e4f91c591c2e27c82295"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#ga7d391fa299a4e4f91c591c2e27c82295">sha256_put_word</a> (uint32_t word)</td></tr>
174 <tr class="memdesc:ga7d391fa299a4e4f91c591c2e27c82295"><td class="mdescLeft"> </td><td class="mdescRight">Write one 32bit word of data to the SHA-256 hardware. <a href="group__hardware__sha256.html#ga7d391fa299a4e4f91c591c2e27c82295">More...</a><br /></td></tr>
175 <tr class="separator:ga7d391fa299a4e4f91c591c2e27c82295"><td class="memSeparator" colspan="2"> </td></tr>
176 <tr class="memitem:gaa78f58e44c56c61c3e24c119923f28d4"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="group__hardware__sha256.html#gaa78f58e44c56c61c3e24c119923f28d4">sha256_put_byte</a> (uint8_t b)</td></tr>
177 <tr class="memdesc:gaa78f58e44c56c61c3e24c119923f28d4"><td class="mdescLeft"> </td><td class="mdescRight">Write one byte of data to the SHA-256 hardware. <a href="group__hardware__sha256.html#gaa78f58e44c56c61c3e24c119923f28d4">More...</a><br /></td></tr>
178 <tr class="separator:gaa78f58e44c56c61c3e24c119923f28d4"><td class="memSeparator" colspan="2"> </td></tr>
180 <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
181 <p >Hardware SHA-256 Accelerator API. </p>
182 <p >RP2350 is equipped with an implementation of the SHA-256 hash algorithm. The hardware should first be configured by calling the <a class="el" href="group__hardware__sha256.html#ga4f35e6d85d8991216e9c1edd7e682cc7">sha256_set_dma_size</a> and <a class="el" href="group__hardware__sha256.html#ga21bca5a93ccad014cc890e734c9436eb">sha256_set_bswap</a> functions. To generate a new hash the hardware should first be initialised by calling <a class="el" href="group__hardware__sha256.html#ga327d4bf2af7a8291cc402c569392b4d7">sha256_start</a>. The hardware is ready to accept data when <a class="el" href="group__hardware__sha256.html#ga586dc580abe393a0eb4af052da4f9050">sha256_is_ready</a> returns true, at which point the data to be hashed can be written to the address returned by <a class="el" href="group__hardware__sha256.html#gac7b585e60910cf0e1d927a0824cd0fe1">sha256_get_write_addr</a>. The hardware requires 64 bytes to be written in one go or else <a class="el" href="group__hardware__sha256.html#gab26b08aabc454e46859d38acdb9afb63">sha256_err_not_ready</a> will indicate an error and the hashing process must be restarted. <a class="el" href="group__hardware__sha256.html#ga7e4f6ab4a7738c38d094ecd4c5ee9839">sha256_is_sum_valid</a> will return true when there is a valid checksum result which can be retrieved by calling <a class="el" href="group__hardware__sha256.html#ga065f30a83c4d96ea85712a0e22f7a62e">sha256_get_result</a>. </p>
183 <h2 class="groupheader">Enumeration Type Documentation</h2>
184 <a id="gaaf3089af3667088256de5d352973d5e6" name="gaaf3089af3667088256de5d352973d5e6"></a>
185 <h2 class="memtitle"><span class="permalink"><a href="#gaaf3089af3667088256de5d352973d5e6">◆ </a></span>sha256_endianness</h2>
187 <div class="memitem">
188 <div class="memproto">
189 <table class="memname">
191 <td class="memname">enum <a class="el" href="group__hardware__sha256.html#gaaf3089af3667088256de5d352973d5e6">sha256_endianness</a></td>
194 </div><div class="memdoc">
196 <p>SHA-256 endianness definition used in the API. </p>
197 <table class="fieldtable">
198 <tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ggaaf3089af3667088256de5d352973d5e6af7be52b37d04b7ffbd9ba69ba6cad8fd" name="ggaaf3089af3667088256de5d352973d5e6af7be52b37d04b7ffbd9ba69ba6cad8fd"></a>SHA256_LITTLE_ENDIAN </td><td class="fielddoc"><p >Little Endian. </p>
200 <tr><td class="fieldname"><a id="ggaaf3089af3667088256de5d352973d5e6a9ed40fa208beaabfc2fc5b8edbd652c1" name="ggaaf3089af3667088256de5d352973d5e6a9ed40fa208beaabfc2fc5b8edbd652c1"></a>SHA256_BIG_ENDIAN </td><td class="fielddoc"><p >Big Endian. </p>
206 <h2 class="groupheader">Function Documentation</h2>
207 <a id="gab26b08aabc454e46859d38acdb9afb63" name="gab26b08aabc454e46859d38acdb9afb63"></a>
208 <h2 class="memtitle"><span class="permalink"><a href="#gab26b08aabc454e46859d38acdb9afb63">◆ </a></span>sha256_err_not_ready()</h2>
210 <div class="memitem">
211 <div class="memproto">
212 <table class="mlabels">
214 <td class="mlabels-left">
215 <table class="memname">
217 <td class="memname">static bool sha256_err_not_ready </td>
219 <td class="paramtype">void </td>
220 <td class="paramname"></td><td>)</td>
225 <td class="mlabels-right">
226 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
229 </div><div class="memdoc">
231 <p>Check if data was written before the hardware was ready. </p>
232 <p >Indicates if an error has occurred due to data being written when the hardware is not ready.</p>
233 <dl class="section return"><dt>Returns</dt><dd>True if data was written before the hardware was ready </dd></dl>
237 <a id="gaccd81a57687cf83726d87b5da4e63551" name="gaccd81a57687cf83726d87b5da4e63551"></a>
238 <h2 class="memtitle"><span class="permalink"><a href="#gaccd81a57687cf83726d87b5da4e63551">◆ </a></span>sha256_err_not_ready_clear()</h2>
240 <div class="memitem">
241 <div class="memproto">
242 <table class="mlabels">
244 <td class="mlabels-left">
245 <table class="memname">
247 <td class="memname">static void sha256_err_not_ready_clear </td>
249 <td class="paramtype">void </td>
250 <td class="paramname"></td><td>)</td>
255 <td class="mlabels-right">
256 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
259 </div><div class="memdoc">
261 <p>Clear the "not ready" error condition. </p>
262 <p >Resets the hardware if a "not ready" error condition is indicated. </p>
266 <a id="ga065f30a83c4d96ea85712a0e22f7a62e" name="ga065f30a83c4d96ea85712a0e22f7a62e"></a>
267 <h2 class="memtitle"><span class="permalink"><a href="#ga065f30a83c4d96ea85712a0e22f7a62e">◆ </a></span>sha256_get_result()</h2>
269 <div class="memitem">
270 <div class="memproto">
271 <table class="memname">
273 <td class="memname">void sha256_get_result </td>
275 <td class="paramtype"><a class="el" href="unionsha256__result__t.html">sha256_result_t</a> * </td>
276 <td class="paramname"><em>out</em>, </td>
279 <td class="paramkey"></td>
281 <td class="paramtype">enum <a class="el" href="group__hardware__sha256.html#gaaf3089af3667088256de5d352973d5e6">sha256_endianness</a> </td>
282 <td class="paramname"><em>endianness</em> </td>
290 </div><div class="memdoc">
292 <p>Get the checksum result. </p>
293 <p >Read the 32 byte result calculated by the hardware. Only valid if <a class="el" href="group__hardware__sha256.html#ga7e4f6ab4a7738c38d094ecd4c5ee9839">sha256_is_sum_valid</a> is True</p>
294 <dl class="params"><dt>Parameters</dt><dd>
295 <table class="params">
296 <tr><td class="paramname">out</td><td>The checksum result</td></tr>
300 <p>Copyright (c) 2024 Raspberry Pi (Trading) Ltd.</p>
301 <p >SPDX-License-Identifier: BSD-3-Clause </p>
305 <a id="gac7b585e60910cf0e1d927a0824cd0fe1" name="gac7b585e60910cf0e1d927a0824cd0fe1"></a>
306 <h2 class="memtitle"><span class="permalink"><a href="#gac7b585e60910cf0e1d927a0824cd0fe1">◆ </a></span>sha256_get_write_addr()</h2>
308 <div class="memitem">
309 <div class="memproto">
310 <table class="mlabels">
312 <td class="mlabels-left">
313 <table class="memname">
315 <td class="memname">static volatile void * sha256_get_write_addr </td>
317 <td class="paramtype">void </td>
318 <td class="paramname"></td><td>)</td>
323 <td class="mlabels-right">
324 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
327 </div><div class="memdoc">
329 <p>Address to write the data to be hashed. </p>
330 <p >Returns the hardware address where data to be hashed should be written</p>
331 <dl class="section return"><dt>Returns</dt><dd>Address to write data to be hashed </dd></dl>
335 <a id="ga586dc580abe393a0eb4af052da4f9050" name="ga586dc580abe393a0eb4af052da4f9050"></a>
336 <h2 class="memtitle"><span class="permalink"><a href="#ga586dc580abe393a0eb4af052da4f9050">◆ </a></span>sha256_is_ready()</h2>
338 <div class="memitem">
339 <div class="memproto">
340 <table class="mlabels">
342 <td class="mlabels-left">
343 <table class="memname">
345 <td class="memname">static bool sha256_is_ready </td>
347 <td class="paramtype">void </td>
348 <td class="paramname"></td><td>)</td>
353 <td class="mlabels-right">
354 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
357 </div><div class="memdoc">
359 <p>Check if a the hardware is ready to accept more data. </p>
360 <p >After writing 64 bytes of data to the hardware, it will be unable to accept more data for a time. Call this to check if the hardware is ready for more data to be written. </p><dl class="section see"><dt>See also</dt><dd><a class="el" href="group__hardware__sha256.html#gab26b08aabc454e46859d38acdb9afb63" title="Check if data was written before the hardware was ready.">sha256_err_not_ready</a></dd></dl>
361 <dl class="section return"><dt>Returns</dt><dd>True if the hardware is ready to receive more data </dd></dl>
365 <a id="ga7e4f6ab4a7738c38d094ecd4c5ee9839" name="ga7e4f6ab4a7738c38d094ecd4c5ee9839"></a>
366 <h2 class="memtitle"><span class="permalink"><a href="#ga7e4f6ab4a7738c38d094ecd4c5ee9839">◆ </a></span>sha256_is_sum_valid()</h2>
368 <div class="memitem">
369 <div class="memproto">
370 <table class="mlabels">
372 <td class="mlabels-left">
373 <table class="memname">
375 <td class="memname">static bool sha256_is_sum_valid </td>
377 <td class="paramtype">void </td>
378 <td class="paramname"></td><td>)</td>
383 <td class="mlabels-right">
384 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
387 </div><div class="memdoc">
389 <p>Check if a valid checksum has been calculated. </p>
390 <p >The checksum result will be invalid when data is first written to the hardware, and then once 64 bytes of data has been written it may take some time to complete the digest of the current block. This function can be used to determine when the checksum is valid.</p>
391 <dl class="section return"><dt>Returns</dt><dd>True if <a class="el" href="group__hardware__sha256.html#ga065f30a83c4d96ea85712a0e22f7a62e">sha256_get_result</a> would return a valid result </dd></dl>
395 <a id="gaa78f58e44c56c61c3e24c119923f28d4" name="gaa78f58e44c56c61c3e24c119923f28d4"></a>
396 <h2 class="memtitle"><span class="permalink"><a href="#gaa78f58e44c56c61c3e24c119923f28d4">◆ </a></span>sha256_put_byte()</h2>
398 <div class="memitem">
399 <div class="memproto">
400 <table class="mlabels">
402 <td class="mlabels-left">
403 <table class="memname">
405 <td class="memname">static void sha256_put_byte </td>
407 <td class="paramtype">uint8_t </td>
408 <td class="paramname"><em>b</em></td><td>)</td>
413 <td class="mlabels-right">
414 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
417 </div><div class="memdoc">
419 <p>Write one byte of data to the SHA-256 hardware. </p>
420 <dl class="params"><dt>Parameters</dt><dd>
421 <table class="params">
422 <tr><td class="paramname">b</td><td>data to write </td></tr>
429 <a id="ga7d391fa299a4e4f91c591c2e27c82295" name="ga7d391fa299a4e4f91c591c2e27c82295"></a>
430 <h2 class="memtitle"><span class="permalink"><a href="#ga7d391fa299a4e4f91c591c2e27c82295">◆ </a></span>sha256_put_word()</h2>
432 <div class="memitem">
433 <div class="memproto">
434 <table class="mlabels">
436 <td class="mlabels-left">
437 <table class="memname">
439 <td class="memname">static void sha256_put_word </td>
441 <td class="paramtype">uint32_t </td>
442 <td class="paramname"><em>word</em></td><td>)</td>
447 <td class="mlabels-right">
448 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
451 </div><div class="memdoc">
453 <p>Write one 32bit word of data to the SHA-256 hardware. </p>
454 <dl class="params"><dt>Parameters</dt><dd>
455 <table class="params">
456 <tr><td class="paramname">word</td><td>data to write </td></tr>
463 <a id="ga21bca5a93ccad014cc890e734c9436eb" name="ga21bca5a93ccad014cc890e734c9436eb"></a>
464 <h2 class="memtitle"><span class="permalink"><a href="#ga21bca5a93ccad014cc890e734c9436eb">◆ </a></span>sha256_set_bswap()</h2>
466 <div class="memitem">
467 <div class="memproto">
468 <table class="mlabels">
470 <td class="mlabels-left">
471 <table class="memname">
473 <td class="memname">static void sha256_set_bswap </td>
475 <td class="paramtype">bool </td>
476 <td class="paramname"><em>swap</em></td><td>)</td>
481 <td class="mlabels-right">
482 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
485 </div><div class="memdoc">
487 <p>Enable or disable byte swapping of 32-bit values. </p>
488 <p >The SHA256 algorithm expects bytes in big endian order, but the system bus deals with little endian data, so control is provided to convert little endian bus data to big endian internal data. This defaults to true</p>
489 <dl class="params"><dt>Parameters</dt><dd>
490 <table class="params">
491 <tr><td class="paramname">swap</td><td>false to disable byte swapping </td></tr>
498 <a id="ga4f35e6d85d8991216e9c1edd7e682cc7" name="ga4f35e6d85d8991216e9c1edd7e682cc7"></a>
499 <h2 class="memtitle"><span class="permalink"><a href="#ga4f35e6d85d8991216e9c1edd7e682cc7">◆ </a></span>sha256_set_dma_size()</h2>
501 <div class="memitem">
502 <div class="memproto">
503 <table class="mlabels">
505 <td class="mlabels-left">
506 <table class="memname">
508 <td class="memname">static void sha256_set_dma_size </td>
510 <td class="paramtype">uint </td>
511 <td class="paramname"><em>size_in_bytes</em></td><td>)</td>
516 <td class="mlabels-right">
517 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
520 </div><div class="memdoc">
522 <p>Configure the correct DMA data size. </p>
523 <p >This must be configured before the DMA channel is triggered and ensures the correct number of transfers is requested per block.</p>
524 <dl class="params"><dt>Parameters</dt><dd>
525 <table class="params">
526 <tr><td class="paramname">size_in_bytes</td><td>Size of DMA transfers, either 1, 2 or 4 bytes only. </td></tr>
533 <a id="ga327d4bf2af7a8291cc402c569392b4d7" name="ga327d4bf2af7a8291cc402c569392b4d7"></a>
534 <h2 class="memtitle"><span class="permalink"><a href="#ga327d4bf2af7a8291cc402c569392b4d7">◆ </a></span>sha256_start()</h2>
536 <div class="memitem">
537 <div class="memproto">
538 <table class="mlabels">
540 <td class="mlabels-left">
541 <table class="memname">
543 <td class="memname">static void sha256_start </td>
545 <td class="paramtype">void </td>
546 <td class="paramname"></td><td>)</td>
551 <td class="mlabels-right">
552 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
555 </div><div class="memdoc">
557 <p>Prepare the hardware for a new checksum. </p>
558 <p >Called to initialise the hardware before starting the checksum calculation </p>
562 <a id="gaab29e83e6d914d262e9aaf13ed34f06e" name="gaab29e83e6d914d262e9aaf13ed34f06e"></a>
563 <h2 class="memtitle"><span class="permalink"><a href="#gaab29e83e6d914d262e9aaf13ed34f06e">◆ </a></span>sha256_wait_ready_blocking()</h2>
565 <div class="memitem">
566 <div class="memproto">
567 <table class="mlabels">
569 <td class="mlabels-left">
570 <table class="memname">
572 <td class="memname">static void sha256_wait_ready_blocking </td>
574 <td class="paramtype">void </td>
575 <td class="paramname"></td><td>)</td>
580 <td class="mlabels-right">
581 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
584 </div><div class="memdoc">
586 <p>Wait until the hardware is ready to accept more data. </p>
587 <p >Before writing to the hardware, it's necessary to check it is ready to accept more data. This function waits until the hardware is ready to accept more data </p>
591 <a id="ga98114068a397971354cd24ae75d051a6" name="ga98114068a397971354cd24ae75d051a6"></a>
592 <h2 class="memtitle"><span class="permalink"><a href="#ga98114068a397971354cd24ae75d051a6">◆ </a></span>sha256_wait_valid_blocking()</h2>
594 <div class="memitem">
595 <div class="memproto">
596 <table class="mlabels">
598 <td class="mlabels-left">
599 <table class="memname">
601 <td class="memname">static void sha256_wait_valid_blocking </td>
603 <td class="paramtype">void </td>
604 <td class="paramname"></td><td>)</td>
609 <td class="mlabels-right">
610 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
613 </div><div class="memdoc">
615 <p>Wait until the checksum is valid. </p>
616 <p >When a multiple of 64 bytes of data has been written to the hardware, the checksum will be valid once the digest of the current block is complete. This function waits until when the checksum result is valid. </p>
620 </div><!-- contents -->
621 </div><!-- doc-content -->
623 <script src="main.js"></script>