libnx/thread__context_8h_source.html
2025-05-08 06:59:12 +00:00

293 lines
58 KiB
HTML

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=11"/>
<meta name="generator" content="Doxygen 1.9.8"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>libnx: include/switch/arm/thread_context.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="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 id="projectrow">
<td id="projectalign">
<div id="projectname">libnx<span id="projectnumber">&#160;v4.9.0</span>
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.9.8 -->
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
var searchBox = new SearchBox("searchBox", "search/",'.html');
/* @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:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function() {
initMenu('',true,false,'search.php','Search');
$(document).ready(function() { init_search(); });
});
/* @license-end */
</script>
<div id="main-nav"></div>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(document).ready(function() { init_codefold(0); });
/* @license-end */
</script>
<!-- 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">
<div id="MSearchResults">
<div class="SRPage">
<div id="SRIndex">
<div id="SRResults"></div>
<div class="SRStatus" id="Loading">Loading...</div>
<div class="SRStatus" id="Searching">Searching...</div>
<div class="SRStatus" id="NoMatches">No Matches</div>
</div>
</div>
</div>
</div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="dir_d44c64559bbebec7f509842c48db8b23.html">include</a></li><li class="navelem"><a class="el" href="dir_42bea3d40f1f1694e41a8f3166c98108.html">switch</a></li><li class="navelem"><a class="el" href="dir_f3bb171450ae8c98f5225c4eee2b68a5.html">arm</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="headertitle"><div class="title">thread_context.h</div></div>
</div><!--header-->
<div class="contents">
<a href="thread__context_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">/**</span></div>
<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment"> * @file thread_context.h</span></div>
<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment"> * @brief AArch64 register dump format and related definitions.</span></div>
<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment"> * @author TuxSH</span></div>
<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment"> * @copyright libnx Authors</span></div>
<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment"> */</span></div>
<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span> </div>
<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="preprocessor">#pragma once</span></div>
<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span><span class="preprocessor">#include &quot;../types.h&quot;</span></div>
<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span><span class="comment"></span> </div>
<div class="line"><a id="l00011" name="l00011"></a><span class="lineno"> 11</span><span class="comment">/// Armv8 CPU register.</span></div>
<div class="foldopen" id="foldopen00012" data-start="{" data-end="};">
<div class="line"><a id="l00012" name="l00012"></a><span class="lineno"><a class="line" href="unionCpuRegister.html"> 12</a></span><span class="comment"></span><span class="keyword">typedef</span> <span class="keyword">union </span>{</div>
<div class="line"><a id="l00013" name="l00013"></a><span class="lineno"><a class="line" href="unionCpuRegister.html#a2a2781558177ab7a6182d19d7caca25f"> 13</a></span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> <a class="code hl_variable" href="unionCpuRegister.html#a2a2781558177ab7a6182d19d7caca25f">x</a>; <span class="comment">///&lt; 64-bit AArch64 register view.</span></div>
<div class="line"><a id="l00014" name="l00014"></a><span class="lineno"><a class="line" href="unionCpuRegister.html#af05b333c76d2a64042d55f92abc8c751"> 14</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="unionCpuRegister.html#af05b333c76d2a64042d55f92abc8c751">w</a>; <span class="comment">///&lt; 32-bit AArch64 register view.</span></div>
<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"><a class="line" href="unionCpuRegister.html#a516e9cde4e2fc6262d7cc5d1444bf381"> 15</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="unionCpuRegister.html#a516e9cde4e2fc6262d7cc5d1444bf381">r</a>; <span class="comment">///&lt; AArch32 register view.</span></div>
<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span>} <a class="code hl_union" href="unionCpuRegister.html">CpuRegister</a>;</div>
</div>
<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="comment"></span> </div>
<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="comment">/// Armv8 NEON register.</span></div>
<div class="foldopen" id="foldopen00019" data-start="{" data-end="};">
<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"><a class="line" href="unionFpuRegister.html"> 19</a></span><span class="comment"></span><span class="keyword">typedef</span> <span class="keyword">union </span>{</div>
<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"><a class="line" href="unionFpuRegister.html#aabbc71629ce44403a50583e090e865d7"> 20</a></span> <a class="code hl_typedef" href="types_8h.html#a99f41a347e7d272c76fc2c4650268ec0">u128</a> <a class="code hl_variable" href="unionFpuRegister.html#aabbc71629ce44403a50583e090e865d7">v</a>; <span class="comment">///&lt; 128-bit vector view.</span></div>
<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"><a class="line" href="unionFpuRegister.html#a7a6e6f6ffff49f7ef4c0f7dee04f8155"> 21</a></span> <span class="keywordtype">double</span> <a class="code hl_variable" href="unionFpuRegister.html#a7a6e6f6ffff49f7ef4c0f7dee04f8155">d</a>; <span class="comment">///&lt; 64-bit double-precision view.</span></div>
<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"><a class="line" href="unionFpuRegister.html#af2b96071cba7acf6f4109d3e357ede8c"> 22</a></span> <span class="keywordtype">float</span> <a class="code hl_variable" href="unionFpuRegister.html#af2b96071cba7acf6f4109d3e357ede8c">s</a>; <span class="comment">///&lt; 32-bit single-precision view.</span></div>
<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span>} <a class="code hl_union" href="unionFpuRegister.html">FpuRegister</a>;</div>
</div>
<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment"></span> </div>
<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="comment">/// Armv8 register group. @ref svcGetThreadContext3 uses @ref RegisterGroup_All.</span></div>
<div class="foldopen" id="foldopen00026" data-start="{" data-end="};">
<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636a"> 26</a></span><span class="comment"></span><span class="keyword">typedef</span> <span class="keyword">enum</span> {</div>
<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa15404844a59df7039491bcf9819d5603"> 27</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa15404844a59df7039491bcf9819d5603">RegisterGroup_CpuGprs</a> = <a class="code hl_define" href="types_8h.html#a3a8ea58898cb58fc96013383d39f482c">BIT</a>(0), <span class="comment">///&lt; General-purpose CPU registers (x0..x28 or r0..r10,r12).</span></div>
<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aac7ecc63a81efdf1ba4ed58c65a2aa1e7"> 28</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aac7ecc63a81efdf1ba4ed58c65a2aa1e7">RegisterGroup_CpuSprs</a> = <a class="code hl_define" href="types_8h.html#a3a8ea58898cb58fc96013383d39f482c">BIT</a>(1), <span class="comment">///&lt; Special-purpose CPU registers (fp, lr, sp, pc, PSTATE or cpsr, TPIDR_EL0).</span></div>
<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa988483d98b8175fefa2551c20eb0e602"> 29</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa988483d98b8175fefa2551c20eb0e602">RegisterGroup_FpuGprs</a> = <a class="code hl_define" href="types_8h.html#a3a8ea58898cb58fc96013383d39f482c">BIT</a>(2), <span class="comment">///&lt; General-purpose NEON registers.</span></div>
<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa36017b14c7e25a069e42edffb2eb24a1"> 30</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa36017b14c7e25a069e42edffb2eb24a1">RegisterGroup_FpuSprs</a> = <a class="code hl_define" href="types_8h.html#a3a8ea58898cb58fc96013383d39f482c">BIT</a>(3), <span class="comment">///&lt; Special-purpose NEON registers.</span></div>
<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span> </div>
<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa720c5d29665dd9ce82292d7ade5b9f34"> 32</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa720c5d29665dd9ce82292d7ade5b9f34">RegisterGroup_CpuAll</a> = <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa15404844a59df7039491bcf9819d5603">RegisterGroup_CpuGprs</a> | <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aac7ecc63a81efdf1ba4ed58c65a2aa1e7">RegisterGroup_CpuSprs</a>, <span class="comment">///&lt; All CPU registers.</span></div>
<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa7877d5ab6034279921e314cf73ca5a9d"> 33</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa7877d5ab6034279921e314cf73ca5a9d">RegisterGroup_FpuAll</a> = <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa988483d98b8175fefa2551c20eb0e602">RegisterGroup_FpuGprs</a> | <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa36017b14c7e25a069e42edffb2eb24a1">RegisterGroup_FpuSprs</a>, <span class="comment">///&lt; All NEON registers.</span></div>
<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aaba4e842ea994c79cce926f3f65f92e64"> 34</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aaba4e842ea994c79cce926f3f65f92e64">RegisterGroup_All</a> = <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa720c5d29665dd9ce82292d7ade5b9f34">RegisterGroup_CpuAll</a> | <a class="code hl_enumvalue" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa7877d5ab6034279921e314cf73ca5a9d">RegisterGroup_FpuAll</a>, <span class="comment">///&lt; All registers.</span></div>
<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span>} <a class="code hl_enumeration" href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636a">RegisterGroup</a>;</div>
</div>
<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span><span class="comment"></span> </div>
<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span><span class="comment">/// This is for \ref ThreadExceptionDump error_desc.</span></div>
<div class="foldopen" id="foldopen00038" data-start="{" data-end="};">
<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2d"> 38</a></span><span class="comment"></span><span class="keyword">typedef</span> <span class="keyword">enum</span> {</div>
<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da2cbdb125e89ea569b90cf5ec8545e74e"> 39</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da2cbdb125e89ea569b90cf5ec8545e74e">ThreadExceptionDesc_InstructionAbort</a> = 0x100, <span class="comment">///&lt; Instruction abort</span></div>
<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da1913a980a6ef079c04a5c68e785cc70c"> 40</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da1913a980a6ef079c04a5c68e785cc70c">ThreadExceptionDesc_MisalignedPC</a> = 0x102, <span class="comment">///&lt; Misaligned PC</span></div>
<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da6719566dd18e10418448cc178ac2975f"> 41</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da6719566dd18e10418448cc178ac2975f">ThreadExceptionDesc_MisalignedSP</a> = 0x103, <span class="comment">///&lt; Misaligned SP</span></div>
<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da7cec9f65670a0b1f67de15540325ea38"> 42</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da7cec9f65670a0b1f67de15540325ea38">ThreadExceptionDesc_SError</a> = 0x106, <span class="comment">///&lt; SError [not in 1.0.0?]</span></div>
<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da36a528e6733770d00d4850e0554d0184"> 43</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da36a528e6733770d00d4850e0554d0184">ThreadExceptionDesc_BadSVC</a> = 0x301, <span class="comment">///&lt; Bad SVC</span></div>
<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da00dd477f7206359c48a18b6c2757afde"> 44</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da00dd477f7206359c48a18b6c2757afde">ThreadExceptionDesc_Trap</a> = 0x104, <span class="comment">///&lt; Uncategorized, CP15RTTrap, CP15RRTTrap, CP14RTTrap, CP14RRTTrap, IllegalState, SystemRegisterTrap</span></div>
<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da7f0e65579e6d7ef8535d20d620acb2e4"> 45</a></span> <a class="code hl_enumvalue" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da7f0e65579e6d7ef8535d20d620acb2e4">ThreadExceptionDesc_Other</a> = 0x101, <span class="comment">///&lt; None of the above, EC &lt;= 0x34 and not a breakpoint</span></div>
<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span>} <a class="code hl_enumeration" href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2d">ThreadExceptionDesc</a>;</div>
</div>
<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span><span class="comment"></span> </div>
<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="comment">/// Thread context structure (register dump)</span></div>
<div class="foldopen" id="foldopen00049" data-start="{" data-end="};">
<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="structThreadContext.html"> 49</a></span><span class="comment"></span><span class="keyword">typedef</span> <span class="keyword">struct </span>{</div>
<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="structThreadContext.html#ad82c03b56b9d81634b661ffe0604d056"> 50</a></span> <a class="code hl_union" href="unionCpuRegister.html">CpuRegister</a> cpu_gprs[29]; <span class="comment">///&lt; GPRs 0..28. Note: also contains AArch32 SPRs.</span></div>
<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="structThreadContext.html#ad2c6458d9ddfa3aa760cfb13a096f546"> 51</a></span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> <a class="code hl_variable" href="structThreadContext.html#ad2c6458d9ddfa3aa760cfb13a096f546">fp</a>; <span class="comment">///&lt; Frame pointer (x29) (AArch64). For AArch32, check r11.</span></div>
<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="structThreadContext.html#afcc39c3f1c13bc0b1fbf626255159204"> 52</a></span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> <a class="code hl_variable" href="structThreadContext.html#afcc39c3f1c13bc0b1fbf626255159204">lr</a>; <span class="comment">///&lt; Link register (x30) (AArch64). For AArch32, check r14.</span></div>
<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="structThreadContext.html#aef758ef63a99688218a34f83ffa11266"> 53</a></span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> <a class="code hl_variable" href="structThreadContext.html#aef758ef63a99688218a34f83ffa11266">sp</a>; <span class="comment">///&lt; Stack pointer (AArch64). For AArch32, check r13.</span></div>
<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="structThreadContext.html#a96595fe9fc720501f214e67efdb33510"> 54</a></span> <a class="code hl_union" href="unionCpuRegister.html">CpuRegister</a> <a class="code hl_variable" href="structThreadContext.html#a96595fe9fc720501f214e67efdb33510">pc</a>; <span class="comment">///&lt; Program counter.</span></div>
<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="structThreadContext.html#a57268e9f35a3e8a23fc1d572314bfb0a"> 55</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="structThreadContext.html#a57268e9f35a3e8a23fc1d572314bfb0a">psr</a>; <span class="comment">///&lt; PSTATE or cpsr.</span></div>
<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span> </div>
<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"><a class="line" href="structThreadContext.html#a0058cef147b3a3fa39ddfd5a2aab251d"> 57</a></span> <a class="code hl_union" href="unionFpuRegister.html">FpuRegister</a> fpu_gprs[32]; <span class="comment">///&lt; 32 general-purpose NEON registers.</span></div>
<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="structThreadContext.html#a3be3464ab2a24d792d47912421725e3e"> 58</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="structThreadContext.html#a3be3464ab2a24d792d47912421725e3e">fpcr</a>; <span class="comment">///&lt; Floating-point control register.</span></div>
<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="structThreadContext.html#a997bc7507afe8bcdec7004ddd5c13490"> 59</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="structThreadContext.html#a997bc7507afe8bcdec7004ddd5c13490">fpsr</a>; <span class="comment">///&lt; Floating-point status register.</span></div>
<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span> </div>
<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="structThreadContext.html#aad8e88aca367ff4562f2f4bed3c18d2d"> 61</a></span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> <a class="code hl_variable" href="structThreadContext.html#aad8e88aca367ff4562f2f4bed3c18d2d">tpidr</a>; <span class="comment">///&lt; EL0 Read/Write Software Thread ID Register.</span></div>
<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span>} <a class="code hl_struct" href="structThreadContext.html">ThreadContext</a>;</div>
</div>
<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span><span class="comment"></span> </div>
<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span><span class="comment">/// Thread exception dump structure.</span></div>
<div class="foldopen" id="foldopen00065" data-start="{" data-end="};">
<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html"> 65</a></span><span class="comment"></span><span class="keyword">typedef</span> <span class="keyword">struct </span>{</div>
<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html#a58097b3fc1a633e00e4676db395c69bb"> 66</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="structThreadExceptionDump.html#a58097b3fc1a633e00e4676db395c69bb">error_desc</a>; <span class="comment">///&lt; See \ref ThreadExceptionDesc.</span></div>
<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> pad[3];</div>
<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span> </div>
<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html#aba280bcde1885d6042a4326ba92f398b"> 69</a></span> <a class="code hl_union" href="unionCpuRegister.html">CpuRegister</a> cpu_gprs[29]; <span class="comment">///&lt; GPRs 0..28. Note: also contains AArch32 registers.</span></div>
<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html#a98b1bb09f9f2db6e7d8d5cdd4d3b7817"> 70</a></span> <a class="code hl_union" href="unionCpuRegister.html">CpuRegister</a> <a class="code hl_variable" href="structThreadExceptionDump.html#a98b1bb09f9f2db6e7d8d5cdd4d3b7817">fp</a>; <span class="comment">///&lt; Frame pointer.</span></div>
<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html#a94b1a9e21886dd107974ac1082896e52"> 71</a></span> <a class="code hl_union" href="unionCpuRegister.html">CpuRegister</a> <a class="code hl_variable" href="structThreadExceptionDump.html#a94b1a9e21886dd107974ac1082896e52">lr</a>; <span class="comment">///&lt; Link register.</span></div>
<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html#afb21e39e1c603738de137c9cf76e3d30"> 72</a></span> <a class="code hl_union" href="unionCpuRegister.html">CpuRegister</a> <a class="code hl_variable" href="structThreadExceptionDump.html#afb21e39e1c603738de137c9cf76e3d30">sp</a>; <span class="comment">///&lt; Stack pointer.</span></div>
<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html#a64658cc513a754261dcf38ae1abe6b15"> 73</a></span> <a class="code hl_union" href="unionCpuRegister.html">CpuRegister</a> <a class="code hl_variable" href="structThreadExceptionDump.html#a64658cc513a754261dcf38ae1abe6b15">pc</a>; <span class="comment">///&lt; Program counter (elr_el1).</span></div>
<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span> </div>
<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> padding;</div>
<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span> </div>
<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html#ae104b56b580cc0cd9e9b2c76785a405f"> 77</a></span> <a class="code hl_union" href="unionFpuRegister.html">FpuRegister</a> fpu_gprs[32]; <span class="comment">///&lt; 32 general-purpose NEON registers.</span></div>
<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span> </div>
<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html#a696f08aa1748db4b8ec7fdda98aeaf36"> 79</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="structThreadExceptionDump.html#a696f08aa1748db4b8ec7fdda98aeaf36">pstate</a>; <span class="comment">///&lt; pstate &amp; 0xFF0FFE20</span></div>
<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> afsr0;</div>
<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> afsr1;</div>
<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> esr;</div>
<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span> </div>
<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"><a class="line" href="structThreadExceptionDump.html#ac7524d20eaf854fe7d29d5c94c3c3a6d"> 84</a></span> <a class="code hl_union" href="unionCpuRegister.html">CpuRegister</a> <a class="code hl_variable" href="structThreadExceptionDump.html#ac7524d20eaf854fe7d29d5c94c3c3a6d">far</a>; <span class="comment">///&lt; Fault Address Register.</span></div>
<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span>} <a class="code hl_struct" href="structThreadExceptionDump.html">ThreadExceptionDump</a>;</div>
</div>
<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span> </div>
<div class="foldopen" id="foldopen00087" data-start="{" data-end="};">
<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"><a class="line" href="structThreadExceptionFrameA64.html"> 87</a></span><span class="keyword">typedef</span> <span class="keyword">struct </span>{</div>
<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"><a class="line" href="structThreadExceptionFrameA64.html#a327de2072d6c154ed74bd1ed187dfbb7"> 88</a></span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> cpu_gprs[9]; <span class="comment">///&lt; GPRs 0..8.</span></div>
<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> lr;</div>
<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> sp;</div>
<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> elr_el1;</div>
<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"><a class="line" href="structThreadExceptionFrameA64.html#a3bba97641512e4c746b20c8d32433198"> 92</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="structThreadExceptionFrameA64.html#a3bba97641512e4c746b20c8d32433198">pstate</a>; <span class="comment">///&lt; pstate &amp; 0xFF0FFE20</span></div>
<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> afsr0;</div>
<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> afsr1;</div>
<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> esr;</div>
<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span> <a class="code hl_typedef" href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a> far;</div>
<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span>} <a class="code hl_struct" href="structThreadExceptionFrameA64.html">ThreadExceptionFrameA64</a>;</div>
</div>
<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span> </div>
<div class="foldopen" id="foldopen00099" data-start="{" data-end="};">
<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"><a class="line" href="structThreadExceptionFrameA32.html"> 99</a></span><span class="keyword">typedef</span> <span class="keyword">struct </span>{</div>
<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"><a class="line" href="structThreadExceptionFrameA32.html#af2454d6aeb68e4f5b81891d99618e3a4"> 100</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> cpu_gprs[8]; <span class="comment">///&lt; GPRs 0..7.</span></div>
<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> sp;</div>
<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> lr;</div>
<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> elr_el1;</div>
<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"><a class="line" href="structThreadExceptionFrameA32.html#a1e405e3da2aeebff028b08f907520f8e"> 104</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="structThreadExceptionFrameA32.html#a1e405e3da2aeebff028b08f907520f8e">tpidr_el0</a>; <span class="comment">///&lt; tpidr_el0 = 1</span></div>
<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"><a class="line" href="structThreadExceptionFrameA32.html#ab46549a561d6caf1b1869701c2661dee"> 105</a></span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> <a class="code hl_variable" href="structThreadExceptionFrameA32.html#ab46549a561d6caf1b1869701c2661dee">cpsr</a>; <span class="comment">///&lt; cpsr &amp; 0xFF0FFE20</span></div>
<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> afsr0;</div>
<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> afsr1;</div>
<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> esr;</div>
<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span> <a class="code hl_typedef" href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a> far;</div>
<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span>} <a class="code hl_struct" href="structThreadExceptionFrameA32.html">ThreadExceptionFrameA32</a>;</div>
</div>
<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span><span class="comment"></span> </div>
<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"> 112</span><span class="comment">/**</span></div>
<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span><span class="comment"> * @brief Determines whether a thread context belong to an AArch64 process based on the PSR.</span></div>
<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"> 114</span><span class="comment"> * @param[in] ctx Thread context to which PSTATE/cspr has been dumped to.</span></div>
<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"> 115</span><span class="comment"> * @return true if and only if the thread context belongs to an AArch64 process.</span></div>
<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"> 116</span><span class="comment"> */</span></div>
<div class="foldopen" id="foldopen00117" data-start="{" data-end="}">
<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"><a class="line" href="thread__context_8h.html#abad1b1253b8b73c4ff5048371396dd6e"> 117</a></span><span class="keyword">static</span> <span class="keyword">inline</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="thread__context_8h.html#abad1b1253b8b73c4ff5048371396dd6e">threadContextIsAArch64</a>(<span class="keyword">const</span> <a class="code hl_struct" href="structThreadContext.html">ThreadContext</a> *ctx)</div>
<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"> 118</span>{</div>
<div class="line"><a id="l00119" name="l00119"></a><span class="lineno"> 119</span> <span class="keywordflow">return</span> (ctx-&gt;<a class="code hl_variable" href="structThreadContext.html#a57268e9f35a3e8a23fc1d572314bfb0a">psr</a> &amp; 0x10) == 0;</div>
<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"> 120</span>}</div>
</div>
<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"> 121</span><span class="comment"></span> </div>
<div class="line"><a id="l00122" name="l00122"></a><span class="lineno"> 122</span><span class="comment">/**</span></div>
<div class="line"><a id="l00123" name="l00123"></a><span class="lineno"> 123</span><span class="comment"> * @brief Determines whether a ThreadExceptionDump belongs to an AArch64 process based on the PSTATE.</span></div>
<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"> 124</span><span class="comment"> * @param[in] ctx ThreadExceptionDump.</span></div>
<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"> 125</span><span class="comment"> * @return true if and only if the ThreadExceptionDump belongs to an AArch64 process.</span></div>
<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"> 126</span><span class="comment"> */</span></div>
<div class="foldopen" id="foldopen00127" data-start="{" data-end="}">
<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"><a class="line" href="thread__context_8h.html#ad416e2a38aa130136c6c41b485b2de14"> 127</a></span><span class="keyword">static</span> <span class="keyword">inline</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="thread__context_8h.html#ad416e2a38aa130136c6c41b485b2de14">threadExceptionIsAArch64</a>(<span class="keyword">const</span> <a class="code hl_struct" href="structThreadExceptionDump.html">ThreadExceptionDump</a> *ctx)</div>
<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span>{</div>
<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"> 129</span> <span class="keywordflow">return</span> (ctx-&gt;<a class="code hl_variable" href="structThreadExceptionDump.html#a696f08aa1748db4b8ec7fdda98aeaf36">pstate</a> &amp; 0x10) == 0;</div>
<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span>}</div>
</div>
<div class="ttc" id="astructThreadContext_html"><div class="ttname"><a href="structThreadContext.html">ThreadContext</a></div><div class="ttdoc">Thread context structure (register dump)</div><div class="ttdef"><b>Definition</b> thread_context.h:49</div></div>
<div class="ttc" id="astructThreadContext_html_a3be3464ab2a24d792d47912421725e3e"><div class="ttname"><a href="structThreadContext.html#a3be3464ab2a24d792d47912421725e3e">ThreadContext::fpcr</a></div><div class="ttdeci">u32 fpcr</div><div class="ttdoc">Floating-point control register.</div><div class="ttdef"><b>Definition</b> thread_context.h:58</div></div>
<div class="ttc" id="astructThreadContext_html_a57268e9f35a3e8a23fc1d572314bfb0a"><div class="ttname"><a href="structThreadContext.html#a57268e9f35a3e8a23fc1d572314bfb0a">ThreadContext::psr</a></div><div class="ttdeci">u32 psr</div><div class="ttdoc">PSTATE or cpsr.</div><div class="ttdef"><b>Definition</b> thread_context.h:55</div></div>
<div class="ttc" id="astructThreadContext_html_a96595fe9fc720501f214e67efdb33510"><div class="ttname"><a href="structThreadContext.html#a96595fe9fc720501f214e67efdb33510">ThreadContext::pc</a></div><div class="ttdeci">CpuRegister pc</div><div class="ttdoc">Program counter.</div><div class="ttdef"><b>Definition</b> thread_context.h:54</div></div>
<div class="ttc" id="astructThreadContext_html_a997bc7507afe8bcdec7004ddd5c13490"><div class="ttname"><a href="structThreadContext.html#a997bc7507afe8bcdec7004ddd5c13490">ThreadContext::fpsr</a></div><div class="ttdeci">u32 fpsr</div><div class="ttdoc">Floating-point status register.</div><div class="ttdef"><b>Definition</b> thread_context.h:59</div></div>
<div class="ttc" id="astructThreadContext_html_aad8e88aca367ff4562f2f4bed3c18d2d"><div class="ttname"><a href="structThreadContext.html#aad8e88aca367ff4562f2f4bed3c18d2d">ThreadContext::tpidr</a></div><div class="ttdeci">u64 tpidr</div><div class="ttdoc">EL0 Read/Write Software Thread ID Register.</div><div class="ttdef"><b>Definition</b> thread_context.h:61</div></div>
<div class="ttc" id="astructThreadContext_html_ad2c6458d9ddfa3aa760cfb13a096f546"><div class="ttname"><a href="structThreadContext.html#ad2c6458d9ddfa3aa760cfb13a096f546">ThreadContext::fp</a></div><div class="ttdeci">u64 fp</div><div class="ttdoc">Frame pointer (x29) (AArch64). For AArch32, check r11.</div><div class="ttdef"><b>Definition</b> thread_context.h:51</div></div>
<div class="ttc" id="astructThreadContext_html_aef758ef63a99688218a34f83ffa11266"><div class="ttname"><a href="structThreadContext.html#aef758ef63a99688218a34f83ffa11266">ThreadContext::sp</a></div><div class="ttdeci">u64 sp</div><div class="ttdoc">Stack pointer (AArch64). For AArch32, check r13.</div><div class="ttdef"><b>Definition</b> thread_context.h:53</div></div>
<div class="ttc" id="astructThreadContext_html_afcc39c3f1c13bc0b1fbf626255159204"><div class="ttname"><a href="structThreadContext.html#afcc39c3f1c13bc0b1fbf626255159204">ThreadContext::lr</a></div><div class="ttdeci">u64 lr</div><div class="ttdoc">Link register (x30) (AArch64). For AArch32, check r14.</div><div class="ttdef"><b>Definition</b> thread_context.h:52</div></div>
<div class="ttc" id="astructThreadExceptionDump_html"><div class="ttname"><a href="structThreadExceptionDump.html">ThreadExceptionDump</a></div><div class="ttdoc">Thread exception dump structure.</div><div class="ttdef"><b>Definition</b> thread_context.h:65</div></div>
<div class="ttc" id="astructThreadExceptionDump_html_a58097b3fc1a633e00e4676db395c69bb"><div class="ttname"><a href="structThreadExceptionDump.html#a58097b3fc1a633e00e4676db395c69bb">ThreadExceptionDump::error_desc</a></div><div class="ttdeci">u32 error_desc</div><div class="ttdoc">See ThreadExceptionDesc.</div><div class="ttdef"><b>Definition</b> thread_context.h:66</div></div>
<div class="ttc" id="astructThreadExceptionDump_html_a64658cc513a754261dcf38ae1abe6b15"><div class="ttname"><a href="structThreadExceptionDump.html#a64658cc513a754261dcf38ae1abe6b15">ThreadExceptionDump::pc</a></div><div class="ttdeci">CpuRegister pc</div><div class="ttdoc">Program counter (elr_el1).</div><div class="ttdef"><b>Definition</b> thread_context.h:73</div></div>
<div class="ttc" id="astructThreadExceptionDump_html_a696f08aa1748db4b8ec7fdda98aeaf36"><div class="ttname"><a href="structThreadExceptionDump.html#a696f08aa1748db4b8ec7fdda98aeaf36">ThreadExceptionDump::pstate</a></div><div class="ttdeci">u32 pstate</div><div class="ttdoc">pstate &amp; 0xFF0FFE20</div><div class="ttdef"><b>Definition</b> thread_context.h:79</div></div>
<div class="ttc" id="astructThreadExceptionDump_html_a94b1a9e21886dd107974ac1082896e52"><div class="ttname"><a href="structThreadExceptionDump.html#a94b1a9e21886dd107974ac1082896e52">ThreadExceptionDump::lr</a></div><div class="ttdeci">CpuRegister lr</div><div class="ttdoc">Link register.</div><div class="ttdef"><b>Definition</b> thread_context.h:71</div></div>
<div class="ttc" id="astructThreadExceptionDump_html_a98b1bb09f9f2db6e7d8d5cdd4d3b7817"><div class="ttname"><a href="structThreadExceptionDump.html#a98b1bb09f9f2db6e7d8d5cdd4d3b7817">ThreadExceptionDump::fp</a></div><div class="ttdeci">CpuRegister fp</div><div class="ttdoc">Frame pointer.</div><div class="ttdef"><b>Definition</b> thread_context.h:70</div></div>
<div class="ttc" id="astructThreadExceptionDump_html_ac7524d20eaf854fe7d29d5c94c3c3a6d"><div class="ttname"><a href="structThreadExceptionDump.html#ac7524d20eaf854fe7d29d5c94c3c3a6d">ThreadExceptionDump::far</a></div><div class="ttdeci">CpuRegister far</div><div class="ttdoc">Fault Address Register.</div><div class="ttdef"><b>Definition</b> thread_context.h:84</div></div>
<div class="ttc" id="astructThreadExceptionDump_html_afb21e39e1c603738de137c9cf76e3d30"><div class="ttname"><a href="structThreadExceptionDump.html#afb21e39e1c603738de137c9cf76e3d30">ThreadExceptionDump::sp</a></div><div class="ttdeci">CpuRegister sp</div><div class="ttdoc">Stack pointer.</div><div class="ttdef"><b>Definition</b> thread_context.h:72</div></div>
<div class="ttc" id="astructThreadExceptionFrameA32_html"><div class="ttname"><a href="structThreadExceptionFrameA32.html">ThreadExceptionFrameA32</a></div><div class="ttdef"><b>Definition</b> thread_context.h:99</div></div>
<div class="ttc" id="astructThreadExceptionFrameA32_html_a1e405e3da2aeebff028b08f907520f8e"><div class="ttname"><a href="structThreadExceptionFrameA32.html#a1e405e3da2aeebff028b08f907520f8e">ThreadExceptionFrameA32::tpidr_el0</a></div><div class="ttdeci">u32 tpidr_el0</div><div class="ttdoc">tpidr_el0 = 1</div><div class="ttdef"><b>Definition</b> thread_context.h:104</div></div>
<div class="ttc" id="astructThreadExceptionFrameA32_html_ab46549a561d6caf1b1869701c2661dee"><div class="ttname"><a href="structThreadExceptionFrameA32.html#ab46549a561d6caf1b1869701c2661dee">ThreadExceptionFrameA32::cpsr</a></div><div class="ttdeci">u32 cpsr</div><div class="ttdoc">cpsr &amp; 0xFF0FFE20</div><div class="ttdef"><b>Definition</b> thread_context.h:105</div></div>
<div class="ttc" id="astructThreadExceptionFrameA64_html"><div class="ttname"><a href="structThreadExceptionFrameA64.html">ThreadExceptionFrameA64</a></div><div class="ttdef"><b>Definition</b> thread_context.h:87</div></div>
<div class="ttc" id="astructThreadExceptionFrameA64_html_a3bba97641512e4c746b20c8d32433198"><div class="ttname"><a href="structThreadExceptionFrameA64.html#a3bba97641512e4c746b20c8d32433198">ThreadExceptionFrameA64::pstate</a></div><div class="ttdeci">u32 pstate</div><div class="ttdoc">pstate &amp; 0xFF0FFE20</div><div class="ttdef"><b>Definition</b> thread_context.h:92</div></div>
<div class="ttc" id="athread__context_8h_html_a6d919411b9fa2a21a9287b77c195636a"><div class="ttname"><a href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636a">RegisterGroup</a></div><div class="ttdeci">RegisterGroup</div><div class="ttdoc">Armv8 register group. svcGetThreadContext3 uses RegisterGroup_All.</div><div class="ttdef"><b>Definition</b> thread_context.h:26</div></div>
<div class="ttc" id="athread__context_8h_html_a6d919411b9fa2a21a9287b77c195636aa15404844a59df7039491bcf9819d5603"><div class="ttname"><a href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa15404844a59df7039491bcf9819d5603">RegisterGroup_CpuGprs</a></div><div class="ttdeci">@ RegisterGroup_CpuGprs</div><div class="ttdoc">General-purpose CPU registers (x0..x28 or r0..r10,r12).</div><div class="ttdef"><b>Definition</b> thread_context.h:27</div></div>
<div class="ttc" id="athread__context_8h_html_a6d919411b9fa2a21a9287b77c195636aa36017b14c7e25a069e42edffb2eb24a1"><div class="ttname"><a href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa36017b14c7e25a069e42edffb2eb24a1">RegisterGroup_FpuSprs</a></div><div class="ttdeci">@ RegisterGroup_FpuSprs</div><div class="ttdoc">Special-purpose NEON registers.</div><div class="ttdef"><b>Definition</b> thread_context.h:30</div></div>
<div class="ttc" id="athread__context_8h_html_a6d919411b9fa2a21a9287b77c195636aa720c5d29665dd9ce82292d7ade5b9f34"><div class="ttname"><a href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa720c5d29665dd9ce82292d7ade5b9f34">RegisterGroup_CpuAll</a></div><div class="ttdeci">@ RegisterGroup_CpuAll</div><div class="ttdoc">All CPU registers.</div><div class="ttdef"><b>Definition</b> thread_context.h:32</div></div>
<div class="ttc" id="athread__context_8h_html_a6d919411b9fa2a21a9287b77c195636aa7877d5ab6034279921e314cf73ca5a9d"><div class="ttname"><a href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa7877d5ab6034279921e314cf73ca5a9d">RegisterGroup_FpuAll</a></div><div class="ttdeci">@ RegisterGroup_FpuAll</div><div class="ttdoc">All NEON registers.</div><div class="ttdef"><b>Definition</b> thread_context.h:33</div></div>
<div class="ttc" id="athread__context_8h_html_a6d919411b9fa2a21a9287b77c195636aa988483d98b8175fefa2551c20eb0e602"><div class="ttname"><a href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aa988483d98b8175fefa2551c20eb0e602">RegisterGroup_FpuGprs</a></div><div class="ttdeci">@ RegisterGroup_FpuGprs</div><div class="ttdoc">General-purpose NEON registers.</div><div class="ttdef"><b>Definition</b> thread_context.h:29</div></div>
<div class="ttc" id="athread__context_8h_html_a6d919411b9fa2a21a9287b77c195636aaba4e842ea994c79cce926f3f65f92e64"><div class="ttname"><a href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aaba4e842ea994c79cce926f3f65f92e64">RegisterGroup_All</a></div><div class="ttdeci">@ RegisterGroup_All</div><div class="ttdoc">All registers.</div><div class="ttdef"><b>Definition</b> thread_context.h:34</div></div>
<div class="ttc" id="athread__context_8h_html_a6d919411b9fa2a21a9287b77c195636aac7ecc63a81efdf1ba4ed58c65a2aa1e7"><div class="ttname"><a href="thread__context_8h.html#a6d919411b9fa2a21a9287b77c195636aac7ecc63a81efdf1ba4ed58c65a2aa1e7">RegisterGroup_CpuSprs</a></div><div class="ttdeci">@ RegisterGroup_CpuSprs</div><div class="ttdoc">Special-purpose CPU registers (fp, lr, sp, pc, PSTATE or cpsr, TPIDR_EL0).</div><div class="ttdef"><b>Definition</b> thread_context.h:28</div></div>
<div class="ttc" id="athread__context_8h_html_a9e76f9d7ea98dd7f94e4af6b4defab2d"><div class="ttname"><a href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2d">ThreadExceptionDesc</a></div><div class="ttdeci">ThreadExceptionDesc</div><div class="ttdoc">This is for ThreadExceptionDump error_desc.</div><div class="ttdef"><b>Definition</b> thread_context.h:38</div></div>
<div class="ttc" id="athread__context_8h_html_a9e76f9d7ea98dd7f94e4af6b4defab2da00dd477f7206359c48a18b6c2757afde"><div class="ttname"><a href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da00dd477f7206359c48a18b6c2757afde">ThreadExceptionDesc_Trap</a></div><div class="ttdeci">@ ThreadExceptionDesc_Trap</div><div class="ttdoc">Uncategorized, CP15RTTrap, CP15RRTTrap, CP14RTTrap, CP14RRTTrap, IllegalState, SystemRegisterTrap.</div><div class="ttdef"><b>Definition</b> thread_context.h:44</div></div>
<div class="ttc" id="athread__context_8h_html_a9e76f9d7ea98dd7f94e4af6b4defab2da1913a980a6ef079c04a5c68e785cc70c"><div class="ttname"><a href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da1913a980a6ef079c04a5c68e785cc70c">ThreadExceptionDesc_MisalignedPC</a></div><div class="ttdeci">@ ThreadExceptionDesc_MisalignedPC</div><div class="ttdoc">Misaligned PC.</div><div class="ttdef"><b>Definition</b> thread_context.h:40</div></div>
<div class="ttc" id="athread__context_8h_html_a9e76f9d7ea98dd7f94e4af6b4defab2da2cbdb125e89ea569b90cf5ec8545e74e"><div class="ttname"><a href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da2cbdb125e89ea569b90cf5ec8545e74e">ThreadExceptionDesc_InstructionAbort</a></div><div class="ttdeci">@ ThreadExceptionDesc_InstructionAbort</div><div class="ttdoc">Instruction abort.</div><div class="ttdef"><b>Definition</b> thread_context.h:39</div></div>
<div class="ttc" id="athread__context_8h_html_a9e76f9d7ea98dd7f94e4af6b4defab2da36a528e6733770d00d4850e0554d0184"><div class="ttname"><a href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da36a528e6733770d00d4850e0554d0184">ThreadExceptionDesc_BadSVC</a></div><div class="ttdeci">@ ThreadExceptionDesc_BadSVC</div><div class="ttdoc">Bad SVC.</div><div class="ttdef"><b>Definition</b> thread_context.h:43</div></div>
<div class="ttc" id="athread__context_8h_html_a9e76f9d7ea98dd7f94e4af6b4defab2da6719566dd18e10418448cc178ac2975f"><div class="ttname"><a href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da6719566dd18e10418448cc178ac2975f">ThreadExceptionDesc_MisalignedSP</a></div><div class="ttdeci">@ ThreadExceptionDesc_MisalignedSP</div><div class="ttdoc">Misaligned SP.</div><div class="ttdef"><b>Definition</b> thread_context.h:41</div></div>
<div class="ttc" id="athread__context_8h_html_a9e76f9d7ea98dd7f94e4af6b4defab2da7cec9f65670a0b1f67de15540325ea38"><div class="ttname"><a href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da7cec9f65670a0b1f67de15540325ea38">ThreadExceptionDesc_SError</a></div><div class="ttdeci">@ ThreadExceptionDesc_SError</div><div class="ttdoc">SError [not in 1.0.0?].</div><div class="ttdef"><b>Definition</b> thread_context.h:42</div></div>
<div class="ttc" id="athread__context_8h_html_a9e76f9d7ea98dd7f94e4af6b4defab2da7f0e65579e6d7ef8535d20d620acb2e4"><div class="ttname"><a href="thread__context_8h.html#a9e76f9d7ea98dd7f94e4af6b4defab2da7f0e65579e6d7ef8535d20d620acb2e4">ThreadExceptionDesc_Other</a></div><div class="ttdeci">@ ThreadExceptionDesc_Other</div><div class="ttdoc">None of the above, EC &lt;= 0x34 and not a breakpoint.</div><div class="ttdef"><b>Definition</b> thread_context.h:45</div></div>
<div class="ttc" id="athread__context_8h_html_abad1b1253b8b73c4ff5048371396dd6e"><div class="ttname"><a href="thread__context_8h.html#abad1b1253b8b73c4ff5048371396dd6e">threadContextIsAArch64</a></div><div class="ttdeci">static bool threadContextIsAArch64(const ThreadContext *ctx)</div><div class="ttdoc">Determines whether a thread context belong to an AArch64 process based on the PSR.</div><div class="ttdef"><b>Definition</b> thread_context.h:117</div></div>
<div class="ttc" id="athread__context_8h_html_ad416e2a38aa130136c6c41b485b2de14"><div class="ttname"><a href="thread__context_8h.html#ad416e2a38aa130136c6c41b485b2de14">threadExceptionIsAArch64</a></div><div class="ttdeci">static bool threadExceptionIsAArch64(const ThreadExceptionDump *ctx)</div><div class="ttdoc">Determines whether a ThreadExceptionDump belongs to an AArch64 process based on the PSTATE.</div><div class="ttdef"><b>Definition</b> thread_context.h:127</div></div>
<div class="ttc" id="atypes_8h_html_a3a8ea58898cb58fc96013383d39f482c"><div class="ttname"><a href="types_8h.html#a3a8ea58898cb58fc96013383d39f482c">BIT</a></div><div class="ttdeci">#define BIT(n)</div><div class="ttdoc">Creates a bitmask from a bit number.</div><div class="ttdef"><b>Definition</b> types.h:54</div></div>
<div class="ttc" id="atypes_8h_html_a3f7e2bcbb0b4c338f3c4f6c937cd4234"><div class="ttname"><a href="types_8h.html#a3f7e2bcbb0b4c338f3c4f6c937cd4234">u64</a></div><div class="ttdeci">uint64_t u64</div><div class="ttdoc">64-bit unsigned integer.</div><div class="ttdef"><b>Definition</b> types.h:22</div></div>
<div class="ttc" id="atypes_8h_html_a99f41a347e7d272c76fc2c4650268ec0"><div class="ttname"><a href="types_8h.html#a99f41a347e7d272c76fc2c4650268ec0">u128</a></div><div class="ttdeci">__uint128_t u128</div><div class="ttdoc">128-bit unsigned integer.</div><div class="ttdef"><b>Definition</b> types.h:23</div></div>
<div class="ttc" id="atypes_8h_html_afaa62991928fb9fb18ff0db62a040aba"><div class="ttname"><a href="types_8h.html#afaa62991928fb9fb18ff0db62a040aba">u32</a></div><div class="ttdeci">uint32_t u32</div><div class="ttdoc">32-bit unsigned integer.</div><div class="ttdef"><b>Definition</b> types.h:21</div></div>
<div class="ttc" id="aunionCpuRegister_html"><div class="ttname"><a href="unionCpuRegister.html">CpuRegister</a></div><div class="ttdoc">Armv8 CPU register.</div><div class="ttdef"><b>Definition</b> thread_context.h:12</div></div>
<div class="ttc" id="aunionCpuRegister_html_a2a2781558177ab7a6182d19d7caca25f"><div class="ttname"><a href="unionCpuRegister.html#a2a2781558177ab7a6182d19d7caca25f">CpuRegister::x</a></div><div class="ttdeci">u64 x</div><div class="ttdoc">64-bit AArch64 register view.</div><div class="ttdef"><b>Definition</b> thread_context.h:13</div></div>
<div class="ttc" id="aunionCpuRegister_html_a516e9cde4e2fc6262d7cc5d1444bf381"><div class="ttname"><a href="unionCpuRegister.html#a516e9cde4e2fc6262d7cc5d1444bf381">CpuRegister::r</a></div><div class="ttdeci">u32 r</div><div class="ttdoc">AArch32 register view.</div><div class="ttdef"><b>Definition</b> thread_context.h:15</div></div>
<div class="ttc" id="aunionCpuRegister_html_af05b333c76d2a64042d55f92abc8c751"><div class="ttname"><a href="unionCpuRegister.html#af05b333c76d2a64042d55f92abc8c751">CpuRegister::w</a></div><div class="ttdeci">u32 w</div><div class="ttdoc">32-bit AArch64 register view.</div><div class="ttdef"><b>Definition</b> thread_context.h:14</div></div>
<div class="ttc" id="aunionFpuRegister_html"><div class="ttname"><a href="unionFpuRegister.html">FpuRegister</a></div><div class="ttdoc">Armv8 NEON register.</div><div class="ttdef"><b>Definition</b> thread_context.h:19</div></div>
<div class="ttc" id="aunionFpuRegister_html_a7a6e6f6ffff49f7ef4c0f7dee04f8155"><div class="ttname"><a href="unionFpuRegister.html#a7a6e6f6ffff49f7ef4c0f7dee04f8155">FpuRegister::d</a></div><div class="ttdeci">double d</div><div class="ttdoc">64-bit double-precision view.</div><div class="ttdef"><b>Definition</b> thread_context.h:21</div></div>
<div class="ttc" id="aunionFpuRegister_html_aabbc71629ce44403a50583e090e865d7"><div class="ttname"><a href="unionFpuRegister.html#aabbc71629ce44403a50583e090e865d7">FpuRegister::v</a></div><div class="ttdeci">u128 v</div><div class="ttdoc">128-bit vector view.</div><div class="ttdef"><b>Definition</b> thread_context.h:20</div></div>
<div class="ttc" id="aunionFpuRegister_html_af2b96071cba7acf6f4109d3e357ede8c"><div class="ttname"><a href="unionFpuRegister.html#af2b96071cba7acf6f4109d3e357ede8c">FpuRegister::s</a></div><div class="ttdeci">float s</div><div class="ttdoc">32-bit single-precision view.</div><div class="ttdef"><b>Definition</b> thread_context.h:22</div></div>
</div><!-- fragment --></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.9.8
</small></address>
</body>
</html>