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: include/hardware/riscv.h File Reference</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('riscv_8h.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="#define-members">Macros</a> |
107 <a href="#func-members">Functions</a> </div>
108 <div class="headertitle"><div class="title">riscv.h File Reference</div></div>
110 <div class="contents">
111 <div class="textblock"><code>#include "<a class="el" href="pico_8h_source.html">pico.h</a>"</code><br />
112 <code>#include "hardware/regs/rvcsr.h"</code><br />
113 </div><div class="textblock"><div class="dynheader">
114 Include dependency graph for riscv.h:</div>
115 <div class="dyncontent">
116 <div class="center"><img src="riscv_8h__incl.png" border="0" usemap="#ainclude_2hardware_2riscv_8h" alt=""/></div>
117 <map name="ainclude_2hardware_2riscv_8h" id="ainclude_2hardware_2riscv_8h">
118 <area shape="rect" title=" " alt="" coords="420,5,600,32"/>
119 <area shape="rect" href="pico_8h.html" title=" " alt="" coords="411,80,473,107"/>
120 <area shape="rect" title=" " alt="" coords="497,80,659,107"/>
121 <area shape="rect" href="common_2pico__base__headers_2include_2pico_2types_8h_source.html" title=" " alt="" coords="158,304,259,331"/>
122 <area shape="rect" title=" " alt="" coords="252,155,365,181"/>
123 <area shape="rect" href="common_2pico__base__headers_2include_2pico_2config_8h_source.html" title=" " alt="" coords="390,155,494,181"/>
124 <area shape="rect" href="platform_8h.html" title=" " alt="" coords="596,155,717,181"/>
125 <area shape="rect" href="error_8h_source.html" title=" " alt="" coords="741,155,836,181"/>
126 <area shape="rect" href="assert_8h_source.html" title=" " alt="" coords="5,379,111,405"/>
127 <area shape="rect" title=" " alt="" coords="74,453,157,480"/>
128 <area shape="rect" title=" " alt="" coords="211,379,281,405"/>
129 <area shape="rect" title=" " alt="" coords="306,379,381,405"/>
130 <area shape="rect" title=" " alt="" coords="173,229,337,256"/>
131 <area shape="rect" href="compiler_8h_source.html" title=" " alt="" coords="362,229,543,256"/>
132 <area shape="rect" href="sections_8h_source.html" title=" " alt="" coords="567,229,746,256"/>
133 <area shape="rect" href="panic_8h_source.html" title=" " alt="" coords="770,229,930,256"/>
134 <area shape="rect" title=" " alt="" coords="954,229,1165,256"/>
135 <area shape="rect" title=" " alt="" coords="1189,229,1340,256"/>
136 <area shape="rect" title=" " alt="" coords="357,304,548,331"/>
139 </div><div class="textblock"><div class="dynheader">
140 This graph shows which files directly or indirectly include this file:</div>
141 <div class="dyncontent">
142 <div class="center"><img src="riscv_8h__dep__incl.png" border="0" usemap="#ainclude_2hardware_2riscv_8hdep" alt=""/></div>
143 <map name="ainclude_2hardware_2riscv_8hdep" id="ainclude_2hardware_2riscv_8hdep">
144 <area shape="rect" title=" " alt="" coords="17,5,197,32"/>
145 <area shape="rect" href="hazard3_8h.html" title=" " alt="" coords="5,80,208,107"/>
149 <p><a href="riscv_8h_source.html">Go to the source code of this file.</a></p>
150 <table class="memberdecls">
151 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a>
152 Macros</h2></td></tr>
153 <tr class="memitem:a51acbcbe0db34c805da8b1c1d214bdf3"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="riscv_8h.html#a51acbcbe0db34c805da8b1c1d214bdf3">_riscv_read_csr</a>(csrname)</td></tr>
154 <tr class="separator:a51acbcbe0db34c805da8b1c1d214bdf3"><td class="memSeparator" colspan="2"> </td></tr>
155 <tr class="memitem:a0f03bee789588e757c1ae061f7641350"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="riscv_8h.html#a0f03bee789588e757c1ae061f7641350">_riscv_write_csr</a>(csrname, data)</td></tr>
156 <tr class="separator:a0f03bee789588e757c1ae061f7641350"><td class="memSeparator" colspan="2"> </td></tr>
157 <tr class="memitem:afd8797e274ffb62fbedd967aa2ade9c2"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="riscv_8h.html#afd8797e274ffb62fbedd967aa2ade9c2">_riscv_set_csr</a>(csrname, data)</td></tr>
158 <tr class="separator:afd8797e274ffb62fbedd967aa2ade9c2"><td class="memSeparator" colspan="2"> </td></tr>
159 <tr class="memitem:a32520a8d9472e5ba3c10ca2a4520600b"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="riscv_8h.html#a32520a8d9472e5ba3c10ca2a4520600b">_riscv_clear_csr</a>(csrname, data)</td></tr>
160 <tr class="separator:a32520a8d9472e5ba3c10ca2a4520600b"><td class="memSeparator" colspan="2"> </td></tr>
161 <tr class="memitem:a384ec39c17d53d2d6fab24c4d6c82423"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="riscv_8h.html#a384ec39c17d53d2d6fab24c4d6c82423">_riscv_read_write_csr</a>(csrname, data)</td></tr>
162 <tr class="separator:a384ec39c17d53d2d6fab24c4d6c82423"><td class="memSeparator" colspan="2"> </td></tr>
163 <tr class="memitem:a6acb08c9d4382cf54439d627a5a5feab"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="riscv_8h.html#a6acb08c9d4382cf54439d627a5a5feab">_riscv_read_set_csr</a>(csrname, data)</td></tr>
164 <tr class="separator:a6acb08c9d4382cf54439d627a5a5feab"><td class="memSeparator" colspan="2"> </td></tr>
165 <tr class="memitem:aa83f5980e9b9c3c709b8f488e6589ce0"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="riscv_8h.html#aa83f5980e9b9c3c709b8f488e6589ce0">_riscv_read_clear_csr</a>(csrname, data)</td></tr>
166 <tr class="separator:aa83f5980e9b9c3c709b8f488e6589ce0"><td class="memSeparator" colspan="2"> </td></tr>
167 <tr class="memitem:a8abe66587774e2025f08674b9a64e2f5"><td class="memItemLeft" align="right" valign="top"><a id="a8abe66587774e2025f08674b9a64e2f5" name="a8abe66587774e2025f08674b9a64e2f5"></a>
168 #define </td><td class="memItemRight" valign="bottom"><b>riscv_read_csr</b>(csrname)   _riscv_read_csr(csrname)</td></tr>
169 <tr class="separator:a8abe66587774e2025f08674b9a64e2f5"><td class="memSeparator" colspan="2"> </td></tr>
170 <tr class="memitem:aead558637cc118e4b067dc5602201c3e"><td class="memItemLeft" align="right" valign="top"><a id="aead558637cc118e4b067dc5602201c3e" name="aead558637cc118e4b067dc5602201c3e"></a>
171 #define </td><td class="memItemRight" valign="bottom"><b>riscv_write_csr</b>(csrname, data)   _riscv_write_csr(csrname, data)</td></tr>
172 <tr class="separator:aead558637cc118e4b067dc5602201c3e"><td class="memSeparator" colspan="2"> </td></tr>
173 <tr class="memitem:aa1f51dbee4752f6e4853020f9a162720"><td class="memItemLeft" align="right" valign="top"><a id="aa1f51dbee4752f6e4853020f9a162720" name="aa1f51dbee4752f6e4853020f9a162720"></a>
174 #define </td><td class="memItemRight" valign="bottom"><b>riscv_set_csr</b>(csrname, data)   _riscv_set_csr(csrname, data)</td></tr>
175 <tr class="separator:aa1f51dbee4752f6e4853020f9a162720"><td class="memSeparator" colspan="2"> </td></tr>
176 <tr class="memitem:ae83e38c84d0df6aec14cc7cb74dcd0ef"><td class="memItemLeft" align="right" valign="top"><a id="ae83e38c84d0df6aec14cc7cb74dcd0ef" name="ae83e38c84d0df6aec14cc7cb74dcd0ef"></a>
177 #define </td><td class="memItemRight" valign="bottom"><b>riscv_clear_csr</b>(csrname, data)   _riscv_clear_csr(csrname, data)</td></tr>
178 <tr class="separator:ae83e38c84d0df6aec14cc7cb74dcd0ef"><td class="memSeparator" colspan="2"> </td></tr>
179 <tr class="memitem:a96bf97bea44cd4d2c8cf37ffd1119ca1"><td class="memItemLeft" align="right" valign="top"><a id="a96bf97bea44cd4d2c8cf37ffd1119ca1" name="a96bf97bea44cd4d2c8cf37ffd1119ca1"></a>
180 #define </td><td class="memItemRight" valign="bottom"><b>riscv_read_write_csr</b>(csrname, data)   _riscv_read_write_csr(csrname, data)</td></tr>
181 <tr class="separator:a96bf97bea44cd4d2c8cf37ffd1119ca1"><td class="memSeparator" colspan="2"> </td></tr>
182 <tr class="memitem:aca91014d4ae82407f26eb46da91ed6fe"><td class="memItemLeft" align="right" valign="top"><a id="aca91014d4ae82407f26eb46da91ed6fe" name="aca91014d4ae82407f26eb46da91ed6fe"></a>
183 #define </td><td class="memItemRight" valign="bottom"><b>riscv_read_set_csr</b>(csrname, data)   _riscv_read_set_csr(csrname, data)</td></tr>
184 <tr class="separator:aca91014d4ae82407f26eb46da91ed6fe"><td class="memSeparator" colspan="2"> </td></tr>
185 <tr class="memitem:a89dfdbfc34df3e02e5d2db6fbf9d395f"><td class="memItemLeft" align="right" valign="top"><a id="a89dfdbfc34df3e02e5d2db6fbf9d395f" name="a89dfdbfc34df3e02e5d2db6fbf9d395f"></a>
186 #define </td><td class="memItemRight" valign="bottom"><b>riscv_read_clear_csr</b>(csrname, data)   _riscv_read_clear_csr(csrname, data)</td></tr>
187 <tr class="separator:a89dfdbfc34df3e02e5d2db6fbf9d395f"><td class="memSeparator" colspan="2"> </td></tr>
188 </table><table class="memberdecls">
189 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a>
190 Functions</h2></td></tr>
191 <tr class="memitem:a06efa338a556b959322ca608e7a486ab"><td class="memItemLeft" align="right" valign="top"><a id="a06efa338a556b959322ca608e7a486ab" name="a06efa338a556b959322ca608e7a486ab"></a>
192 static uint32_t </td><td class="memItemRight" valign="bottom"><b>riscv_encode_imm_u</b> (uint32_t x)</td></tr>
193 <tr class="separator:a06efa338a556b959322ca608e7a486ab"><td class="memSeparator" colspan="2"> </td></tr>
194 <tr class="memitem:a3dc5c5009a85d86dd00a4de398159057"><td class="memItemLeft" align="right" valign="top"><a id="a3dc5c5009a85d86dd00a4de398159057" name="a3dc5c5009a85d86dd00a4de398159057"></a>
195 static uint32_t </td><td class="memItemRight" valign="bottom"><b>riscv_encode_imm_i</b> (uint32_t x)</td></tr>
196 <tr class="separator:a3dc5c5009a85d86dd00a4de398159057"><td class="memSeparator" colspan="2"> </td></tr>
197 <tr class="memitem:a30fa4eb5161c9de64499001fca87dc24"><td class="memItemLeft" align="right" valign="top"><a id="a30fa4eb5161c9de64499001fca87dc24" name="a30fa4eb5161c9de64499001fca87dc24"></a>
198 static uint32_t </td><td class="memItemRight" valign="bottom"><b>riscv_encode_imm_u_hi</b> (uint32_t x)</td></tr>
199 <tr class="separator:a30fa4eb5161c9de64499001fca87dc24"><td class="memSeparator" colspan="2"> </td></tr>
200 <tr class="memitem:a5333b1a6fa33487fe94e93358dae11a5"><td class="memItemLeft" align="right" valign="top"><a id="a5333b1a6fa33487fe94e93358dae11a5" name="a5333b1a6fa33487fe94e93358dae11a5"></a>
201 static uint32_t </td><td class="memItemRight" valign="bottom"><b>riscv_encode_imm_b</b> (uint32_t x)</td></tr>
202 <tr class="separator:a5333b1a6fa33487fe94e93358dae11a5"><td class="memSeparator" colspan="2"> </td></tr>
203 <tr class="memitem:a9ea47a34407669502c909a96b422211b"><td class="memItemLeft" align="right" valign="top"><a id="a9ea47a34407669502c909a96b422211b" name="a9ea47a34407669502c909a96b422211b"></a>
204 static uint32_t </td><td class="memItemRight" valign="bottom"><b>riscv_encode_imm_s</b> (uint32_t x)</td></tr>
205 <tr class="separator:a9ea47a34407669502c909a96b422211b"><td class="memSeparator" colspan="2"> </td></tr>
206 <tr class="memitem:af713bf419496f600e28d218c11293f45"><td class="memItemLeft" align="right" valign="top"><a id="af713bf419496f600e28d218c11293f45" name="af713bf419496f600e28d218c11293f45"></a>
207 static uint32_t </td><td class="memItemRight" valign="bottom"><b>riscv_encode_imm_j</b> (uint32_t x)</td></tr>
208 <tr class="separator:af713bf419496f600e28d218c11293f45"><td class="memSeparator" colspan="2"> </td></tr>
209 <tr class="memitem:a81b21a267bebb8705e2145366c8ab0f7"><td class="memItemLeft" align="right" valign="top"><a id="a81b21a267bebb8705e2145366c8ab0f7" name="a81b21a267bebb8705e2145366c8ab0f7"></a>
210 static uint16_t </td><td class="memItemRight" valign="bottom"><b>riscv_encode_imm_cj</b> (uint32_t x)</td></tr>
211 <tr class="separator:a81b21a267bebb8705e2145366c8ab0f7"><td class="memSeparator" colspan="2"> </td></tr>
212 <tr class="memitem:a065d26607ce38eb22d145b05a9ac3dd0"><td class="memItemLeft" align="right" valign="top"><a id="a065d26607ce38eb22d145b05a9ac3dd0" name="a065d26607ce38eb22d145b05a9ac3dd0"></a>
213 static uint16_t </td><td class="memItemRight" valign="bottom"><b>riscv_encode_imm_cb</b> (uint32_t x)</td></tr>
214 <tr class="separator:a065d26607ce38eb22d145b05a9ac3dd0"><td class="memSeparator" colspan="2"> </td></tr>
215 <tr class="memitem:aae0eead09e287101d9d1a85aca370489"><td class="memItemLeft" align="right" valign="top"><a id="aae0eead09e287101d9d1a85aca370489" name="aae0eead09e287101d9d1a85aca370489"></a>
216 static uint16_t </td><td class="memItemRight" valign="bottom"><b>riscv_encode_imm_ci</b> (uint32_t x)</td></tr>
217 <tr class="separator:aae0eead09e287101d9d1a85aca370489"><td class="memSeparator" colspan="2"> </td></tr>
219 <h2 class="groupheader">Macro Definition Documentation</h2>
220 <a id="a32520a8d9472e5ba3c10ca2a4520600b" name="a32520a8d9472e5ba3c10ca2a4520600b"></a>
221 <h2 class="memtitle"><span class="permalink"><a href="#a32520a8d9472e5ba3c10ca2a4520600b">◆ </a></span>_riscv_clear_csr</h2>
223 <div class="memitem">
224 <div class="memproto">
225 <table class="memname">
227 <td class="memname">#define _riscv_clear_csr</td>
229 <td class="paramtype"> </td>
230 <td class="paramname">csrname, </td>
233 <td class="paramkey"></td>
235 <td class="paramtype"> </td>
236 <td class="paramname">data </td>
244 </div><div class="memdoc">
245 <b>Value:</b><div class="fragment"><div class="line"> ({ \</div>
246 <div class="line"> if (__builtin_constant_p(data) && !((data) & -32u)) { \</div>
247 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrci "</span> #csrname <span class="stringliteral">", %0"</span> : : <span class="stringliteral">"i"</span> (data)); \</div>
248 <div class="line"> } <span class="keywordflow">else</span> { \</div>
249 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrc "</span> #csrname <span class="stringliteral">", %0"</span> : : <span class="stringliteral">"r"</span> (data)); \</div>
250 <div class="line"> } \</div>
251 <div class="line">})</div>
252 </div><!-- fragment -->
255 <a id="aa83f5980e9b9c3c709b8f488e6589ce0" name="aa83f5980e9b9c3c709b8f488e6589ce0"></a>
256 <h2 class="memtitle"><span class="permalink"><a href="#aa83f5980e9b9c3c709b8f488e6589ce0">◆ </a></span>_riscv_read_clear_csr</h2>
258 <div class="memitem">
259 <div class="memproto">
260 <table class="memname">
262 <td class="memname">#define _riscv_read_clear_csr</td>
264 <td class="paramtype"> </td>
265 <td class="paramname">csrname, </td>
268 <td class="paramkey"></td>
270 <td class="paramtype"> </td>
271 <td class="paramname">data </td>
279 </div><div class="memdoc">
280 <b>Value:</b><div class="fragment"><div class="line"> ({ \</div>
281 <div class="line"> uint32_t __csr_tmp_u32; \</div>
282 <div class="line"> if (__builtin_constant_p(data) && !((data) & -32u)) { \</div>
283 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrrci %0, "</span> #csrname <span class="stringliteral">", %1"</span>: <span class="stringliteral">"=r"</span> (__csr_tmp_u32) : <span class="stringliteral">"i"</span> (data)); \</div>
284 <div class="line"> } <span class="keywordflow">else</span> { \</div>
285 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrrc %0, "</span> #csrname <span class="stringliteral">", %1"</span>: <span class="stringliteral">"=r"</span> (__csr_tmp_u32) : <span class="stringliteral">"r"</span> (data)); \</div>
286 <div class="line"> } \</div>
287 <div class="line"> __csr_tmp_u32; \</div>
288 <div class="line">})</div>
289 </div><!-- fragment -->
292 <a id="a51acbcbe0db34c805da8b1c1d214bdf3" name="a51acbcbe0db34c805da8b1c1d214bdf3"></a>
293 <h2 class="memtitle"><span class="permalink"><a href="#a51acbcbe0db34c805da8b1c1d214bdf3">◆ </a></span>_riscv_read_csr</h2>
295 <div class="memitem">
296 <div class="memproto">
297 <table class="memname">
299 <td class="memname">#define _riscv_read_csr</td>
301 <td class="paramtype"> </td>
302 <td class="paramname">csrname</td><td>)</td>
306 </div><div class="memdoc">
307 <b>Value:</b><div class="fragment"><div class="line"> ({ \</div>
308 <div class="line"> uint32_t __csr_tmp_u32; \</div>
309 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrr %0, "</span> #csrname : <span class="stringliteral">"=r"</span> (__csr_tmp_u32)); \</div>
310 <div class="line"> __csr_tmp_u32; \</div>
311 <div class="line">})</div>
312 </div><!-- fragment -->
315 <a id="a6acb08c9d4382cf54439d627a5a5feab" name="a6acb08c9d4382cf54439d627a5a5feab"></a>
316 <h2 class="memtitle"><span class="permalink"><a href="#a6acb08c9d4382cf54439d627a5a5feab">◆ </a></span>_riscv_read_set_csr</h2>
318 <div class="memitem">
319 <div class="memproto">
320 <table class="memname">
322 <td class="memname">#define _riscv_read_set_csr</td>
324 <td class="paramtype"> </td>
325 <td class="paramname">csrname, </td>
328 <td class="paramkey"></td>
330 <td class="paramtype"> </td>
331 <td class="paramname">data </td>
339 </div><div class="memdoc">
340 <b>Value:</b><div class="fragment"><div class="line"> ({ \</div>
341 <div class="line"> uint32_t __csr_tmp_u32; \</div>
342 <div class="line"> if (__builtin_constant_p(data) && !((data) & -32u)) { \</div>
343 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrrsi %0, "</span> #csrname <span class="stringliteral">", %1"</span>: <span class="stringliteral">"=r"</span> (__csr_tmp_u32) : <span class="stringliteral">"i"</span> (data)); \</div>
344 <div class="line"> } <span class="keywordflow">else</span> { \</div>
345 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrrs %0, "</span> #csrname <span class="stringliteral">", %1"</span>: <span class="stringliteral">"=r"</span> (__csr_tmp_u32) : <span class="stringliteral">"r"</span> (data)); \</div>
346 <div class="line"> } \</div>
347 <div class="line"> __csr_tmp_u32; \</div>
348 <div class="line">})</div>
349 </div><!-- fragment -->
352 <a id="a384ec39c17d53d2d6fab24c4d6c82423" name="a384ec39c17d53d2d6fab24c4d6c82423"></a>
353 <h2 class="memtitle"><span class="permalink"><a href="#a384ec39c17d53d2d6fab24c4d6c82423">◆ </a></span>_riscv_read_write_csr</h2>
355 <div class="memitem">
356 <div class="memproto">
357 <table class="memname">
359 <td class="memname">#define _riscv_read_write_csr</td>
361 <td class="paramtype"> </td>
362 <td class="paramname">csrname, </td>
365 <td class="paramkey"></td>
367 <td class="paramtype"> </td>
368 <td class="paramname">data </td>
376 </div><div class="memdoc">
377 <b>Value:</b><div class="fragment"><div class="line"> ({ \</div>
378 <div class="line"> uint32_t __csr_tmp_u32; \</div>
379 <div class="line"> if (__builtin_constant_p(data) && !((data) & -32u)) { \</div>
380 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrrwi %0, "</span> #csrname <span class="stringliteral">", %1"</span>: <span class="stringliteral">"=r"</span> (__csr_tmp_u32) : <span class="stringliteral">"i"</span> (data)); \</div>
381 <div class="line"> } <span class="keywordflow">else</span> { \</div>
382 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrrw %0, "</span> #csrname <span class="stringliteral">", %1"</span>: <span class="stringliteral">"=r"</span> (__csr_tmp_u32) : <span class="stringliteral">"r"</span> (data)); \</div>
383 <div class="line"> } \</div>
384 <div class="line"> __csr_tmp_u32; \</div>
385 <div class="line">})</div>
386 </div><!-- fragment -->
389 <a id="afd8797e274ffb62fbedd967aa2ade9c2" name="afd8797e274ffb62fbedd967aa2ade9c2"></a>
390 <h2 class="memtitle"><span class="permalink"><a href="#afd8797e274ffb62fbedd967aa2ade9c2">◆ </a></span>_riscv_set_csr</h2>
392 <div class="memitem">
393 <div class="memproto">
394 <table class="memname">
396 <td class="memname">#define _riscv_set_csr</td>
398 <td class="paramtype"> </td>
399 <td class="paramname">csrname, </td>
402 <td class="paramkey"></td>
404 <td class="paramtype"> </td>
405 <td class="paramname">data </td>
413 </div><div class="memdoc">
414 <b>Value:</b><div class="fragment"><div class="line"> ({ \</div>
415 <div class="line"> if (__builtin_constant_p(data) && !((data) & -32u)) { \</div>
416 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrsi "</span> #csrname <span class="stringliteral">", %0"</span> : : <span class="stringliteral">"i"</span> (data)); \</div>
417 <div class="line"> } <span class="keywordflow">else</span> { \</div>
418 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrs "</span> #csrname <span class="stringliteral">", %0"</span> : : <span class="stringliteral">"r"</span> (data)); \</div>
419 <div class="line"> } \</div>
420 <div class="line">})</div>
421 </div><!-- fragment -->
424 <a id="a0f03bee789588e757c1ae061f7641350" name="a0f03bee789588e757c1ae061f7641350"></a>
425 <h2 class="memtitle"><span class="permalink"><a href="#a0f03bee789588e757c1ae061f7641350">◆ </a></span>_riscv_write_csr</h2>
427 <div class="memitem">
428 <div class="memproto">
429 <table class="memname">
431 <td class="memname">#define _riscv_write_csr</td>
433 <td class="paramtype"> </td>
434 <td class="paramname">csrname, </td>
437 <td class="paramkey"></td>
439 <td class="paramtype"> </td>
440 <td class="paramname">data </td>
448 </div><div class="memdoc">
449 <b>Value:</b><div class="fragment"><div class="line"> ({ \</div>
450 <div class="line"> if (__builtin_constant_p(data) && !((data) & -32u)) { \</div>
451 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrwi "</span> #csrname <span class="stringliteral">", %0"</span> : : <span class="stringliteral">"i"</span> (data)); \</div>
452 <div class="line"> } <span class="keywordflow">else</span> { \</div>
453 <div class="line"> asm <span class="keyword">volatile</span> (<span class="stringliteral">"csrw "</span> #csrname <span class="stringliteral">", %0"</span> : : <span class="stringliteral">"r"</span> (data)); \</div>
454 <div class="line"> } \</div>
455 <div class="line">})</div>
456 </div><!-- fragment -->
459 </div><!-- contents -->
460 </div><!-- doc-content -->
462 <script src="main.js"></script>