-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathArchitecture_2Cil_8h_source.html
147 lines (147 loc) · 26.9 KB
/
Architecture_2Cil_8h_source.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
<!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>ROSE: Cil.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/search.js"></script>
<link rel="search" href="search_opensearch.php?v=opensearch.xml" type="application/opensearchdescription+xml" title="ROSE"/>
<link href="roseDoxygen.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">ROSE<span id="projectnumber"> 0.11.145.141</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&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&dn=expat.txt MIT */
$(function() {
initMenu('',true,true,'search.html','Search');
$(document).ready(function() {
if ($('.searchresults').length > 0) { searchBox.DOMSearchField().focus(); }
});
});
/* @license-end */
</script>
<div id="main-nav"></div>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
$(document).ready(function() { init_codefold(0); });
/* @license-end */
</script>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="dir_68267d1309a1af8e8297ef4c3efbcdba.html">src</a></li><li class="navelem"><a class="el" href="dir_9e62d0ec1b5e35066c963e582c20357f.html">Rose</a></li><li class="navelem"><a class="el" href="dir_b6b36e208517412b6f28695766cc080b.html">BinaryAnalysis</a></li><li class="navelem"><a class="el" href="dir_50722166c2968cfa944ac4f873427098.html">Architecture</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="headertitle"><div class="title">Architecture/Cil.h</div></div>
</div><!--header-->
<div class="contents">
<div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="preprocessor">#ifndef ROSE_BinaryAnalysis_Architecture_Cil_H</span></div>
<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="preprocessor">#define ROSE_BinaryAnalysis_Architecture_Cil_H</span></div>
<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="preprocessor">#include <featureTests.h></span></div>
<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="preprocessor">#ifdef ROSE_ENABLE_BINARY_ANALYSIS</span></div>
<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="preprocessor">#include <Rose/BinaryAnalysis/Architecture/Base.h></span></div>
<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span> </div>
<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="keyword">namespace </span><a class="code hl_namespace" href="namespaceRose.html">Rose</a> {</div>
<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="keyword">namespace </span>BinaryAnalysis {</div>
<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span><span class="keyword">namespace </span><a class="code hl_function" href="namespacestringify_1_1Rose_1_1BinaryAnalysis_1_1Disassembler_1_1Mips_1_1Decoder.html#a71cec98f7972bd8cd607558bcea2ffb2">Architecture</a> {</div>
<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span> </div>
<div class="foldopen" id="foldopen00022" data-start="{" data-end="};">
<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html"> 22</a></span><span class="keyword">class </span><a class="code hl_class" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html">Cil</a>: <span class="keyword">public</span> <a class="code hl_class" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html">Base</a> {</div>
<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span> <span class="keyword">using </span>Ptr = <a class="code hl_typedef" href="namespaceRose_1_1BinaryAnalysis_1_1Architecture.html#aab6ca938b286ac9af68ace46b0a9e89a">CilPtr</a>;</div>
<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span> </div>
<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="keyword">protected</span>:</div>
<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span> <a class="code hl_class" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html">Cil</a>(); <span class="comment">// use `instance` instead</span></div>
<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span> <a class="code hl_class" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html">~Cil</a>();</div>
<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span> </div>
<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a8f4ec86bbb9476978ee24c9870b79e73"> 33</a></span> <span class="keyword">static</span> Ptr <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a8f4ec86bbb9476978ee24c9870b79e73">instance</a>();</div>
<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span> </div>
<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a1c584d80e1b7145ba1fc8466f9a98ef6"> 36</a></span> <a class="code hl_class" href="classSawyer_1_1SharedPointer.html">RegisterDictionary::Ptr</a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a1c584d80e1b7145ba1fc8466f9a98ef6">registerDictionary</a>() <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a0ef4d037af74674a8eed9a4b77fa24ec"> 37</a></span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a0ef4d037af74674a8eed9a4b77fa24ec">matchesHeader</a>(<a class="code hl_class" href="classSgAsmGenericHeader.html">SgAsmGenericHeader</a>*) <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> </div>
<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a81f1702f6fa366a222fe1d72cd23dbb3"> 39</a></span> <a class="code hl_class" href="classSawyer_1_1Container_1_1Interval.html">Sawyer::Container::Interval<size_t></a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a81f1702f6fa366a222fe1d72cd23dbb3">bytesPerInstruction</a>() <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#ab5aaa5dfd05a3b3e3084a853a058a656"> 40</a></span> <a class="code hl_class" href="classRose_1_1BinaryAnalysis_1_1Alignment.html">Alignment</a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#ab5aaa5dfd05a3b3e3084a853a058a656">instructionAlignment</a>() <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a80f3cd80da6430bb398eda48c55292e9"> 41</a></span> std::string <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a80f3cd80da6430bb398eda48c55292e9">instructionMnemonic</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#aacc093994f54836601472229867b18a4"> 42</a></span> std::string <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#aacc093994f54836601472229867b18a4">instructionDescription</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a5a4edcee3d81d3f3337b21af0206779c"> 43</a></span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a5a4edcee3d81d3f3337b21af0206779c">isUnknown</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a8004e38713e51a8ac6531bc72d22a161"> 44</a></span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a8004e38713e51a8ac6531bc72d22a161">terminatesBasicBlock</a>(<a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a7711c049bdb1223255603031f776de4d"> 45</a></span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a7711c049bdb1223255603031f776de4d">isFunctionCallFast</a>(<span class="keyword">const</span> std::vector<SgAsmInstruction*>&, rose_addr_t *target, rose_addr_t *ret) <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a218fdc5287d307d5dd2c7fac7a915fbf"> 46</a></span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a218fdc5287d307d5dd2c7fac7a915fbf">isFunctionReturnFast</a>(<span class="keyword">const</span> std::vector<SgAsmInstruction*>&) <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a637fbb6ad3e6ddb32dc06ad9921ca9f7"> 47</a></span> <a class="code hl_class" href="classSawyer_1_1Optional.html">Sawyer::Optional<rose_addr_t></a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a637fbb6ad3e6ddb32dc06ad9921ca9f7">branchTarget</a>(<a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#aeb83bc0dc36289f0d6843f8d6d0c538a"> 48</a></span> <a class="code hl_class" href="classSawyer_1_1Container_1_1Set.html">AddressSet</a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#aeb83bc0dc36289f0d6843f8d6d0c538a">getSuccessors</a>(<a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*, <span class="keywordtype">bool</span> &complete) <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span> </div>
<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#aac1dfa16531bfcd0309aedbb03192a09"> 50</a></span> <a class="code hl_class" href="classSawyer_1_1SharedPointer.html">Disassembler::BasePtr</a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#aac1dfa16531bfcd0309aedbb03192a09">newInstructionDecoder</a>() <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a9f03c7eb098a0dfc12ef27d88db4095d"> 51</a></span> <a class="code hl_class" href="classSawyer_1_1SharedPointer.html">Unparser::BasePtr</a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a9f03c7eb098a0dfc12ef27d88db4095d">newUnparser</a>() <span class="keyword">const override</span>;</div>
<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span>};</div>
</div>
<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span> </div>
<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span>} <span class="comment">// namespace</span></div>
<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span>} <span class="comment">// namespace</span></div>
<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span>} <span class="comment">// namespace</span></div>
<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span> </div>
<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span><span class="preprocessor">#endif</span></div>
<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span><span class="preprocessor">#endif</span></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Alignment_html"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Alignment.html">Rose::BinaryAnalysis::Alignment</a></div><div class="ttdoc">Information about alignments.</div><div class="ttdef"><b>Definition</b> <a href="Alignment_8h_source.html#l00016">Alignment.h:16</a></div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html">Rose::BinaryAnalysis::Architecture::Base</a></div><div class="ttdoc">Base class for architecture definitions.</div><div class="ttdef"><b>Definition</b> <a href="Architecture_2Base_8h_source.html#l00022">Architecture/Base.h:22</a></div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html">Rose::BinaryAnalysis::Architecture::Cil</a></div><div class="ttdoc">Architecture-specific information for the Common Intermediate Language.</div><div class="ttdef"><b>Definition</b> <a href="Architecture_2Cil_8h_source.html#l00022">Architecture/Cil.h:22</a></div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a0ef4d037af74674a8eed9a4b77fa24ec"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a0ef4d037af74674a8eed9a4b77fa24ec">Rose::BinaryAnalysis::Architecture::Cil::matchesHeader</a></div><div class="ttdeci">bool matchesHeader(SgAsmGenericHeader *) const override</div><div class="ttdoc">Tests whether this architecture matches a file header.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a1c584d80e1b7145ba1fc8466f9a98ef6"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a1c584d80e1b7145ba1fc8466f9a98ef6">Rose::BinaryAnalysis::Architecture::Cil::registerDictionary</a></div><div class="ttdeci">RegisterDictionary::Ptr registerDictionary() const override</div><div class="ttdoc">Property: Register dictionary.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a218fdc5287d307d5dd2c7fac7a915fbf"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a218fdc5287d307d5dd2c7fac7a915fbf">Rose::BinaryAnalysis::Architecture::Cil::isFunctionReturnFast</a></div><div class="ttdeci">bool isFunctionReturnFast(const std::vector< SgAsmInstruction * > &) const override</div><div class="ttdoc">Returns true if the specified basic block looks like a function return.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a5a4edcee3d81d3f3337b21af0206779c"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a5a4edcee3d81d3f3337b21af0206779c">Rose::BinaryAnalysis::Architecture::Cil::isUnknown</a></div><div class="ttdeci">bool isUnknown(const SgAsmInstruction *) const override</div><div class="ttdoc">Returns true if the instruction is the special "unknown" instruction.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a637fbb6ad3e6ddb32dc06ad9921ca9f7"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a637fbb6ad3e6ddb32dc06ad9921ca9f7">Rose::BinaryAnalysis::Architecture::Cil::branchTarget</a></div><div class="ttdeci">Sawyer::Optional< rose_addr_t > branchTarget(SgAsmInstruction *) const override</div><div class="ttdoc">Obtains the virtual address for a branching instruction.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a7711c049bdb1223255603031f776de4d"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a7711c049bdb1223255603031f776de4d">Rose::BinaryAnalysis::Architecture::Cil::isFunctionCallFast</a></div><div class="ttdeci">bool isFunctionCallFast(const std::vector< SgAsmInstruction * > &, rose_addr_t *target, rose_addr_t *ret) const override</div><div class="ttdoc">Returns true if the specified basic block looks like a function call.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a8004e38713e51a8ac6531bc72d22a161"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a8004e38713e51a8ac6531bc72d22a161">Rose::BinaryAnalysis::Architecture::Cil::terminatesBasicBlock</a></div><div class="ttdeci">bool terminatesBasicBlock(SgAsmInstruction *) const override</div><div class="ttdoc">Determines whether the specified instruction normally terminates a basic block.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a80f3cd80da6430bb398eda48c55292e9"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a80f3cd80da6430bb398eda48c55292e9">Rose::BinaryAnalysis::Architecture::Cil::instructionMnemonic</a></div><div class="ttdeci">std::string instructionMnemonic(const SgAsmInstruction *) const override</div><div class="ttdoc">Mnemonic for an instruction.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a81f1702f6fa366a222fe1d72cd23dbb3"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a81f1702f6fa366a222fe1d72cd23dbb3">Rose::BinaryAnalysis::Architecture::Cil::bytesPerInstruction</a></div><div class="ttdeci">Sawyer::Container::Interval< size_t > bytesPerInstruction() const override</div><div class="ttdoc">Valid sizes for encoded machine instructions.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a8f4ec86bbb9476978ee24c9870b79e73"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a8f4ec86bbb9476978ee24c9870b79e73">Rose::BinaryAnalysis::Architecture::Cil::instance</a></div><div class="ttdeci">static Ptr instance()</div><div class="ttdoc">Allocating constructor.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_a9f03c7eb098a0dfc12ef27d88db4095d"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#a9f03c7eb098a0dfc12ef27d88db4095d">Rose::BinaryAnalysis::Architecture::Cil::newUnparser</a></div><div class="ttdeci">Unparser::BasePtr newUnparser() const override</div><div class="ttdoc">Construct and return a new instruction unparser.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_aac1dfa16531bfcd0309aedbb03192a09"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#aac1dfa16531bfcd0309aedbb03192a09">Rose::BinaryAnalysis::Architecture::Cil::newInstructionDecoder</a></div><div class="ttdeci">Disassembler::BasePtr newInstructionDecoder() const override</div><div class="ttdoc">Construct and return a new instruction decoder.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_aacc093994f54836601472229867b18a4"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#aacc093994f54836601472229867b18a4">Rose::BinaryAnalysis::Architecture::Cil::instructionDescription</a></div><div class="ttdeci">std::string instructionDescription(const SgAsmInstruction *) const override</div><div class="ttdoc">Description for an instruction.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_ab5aaa5dfd05a3b3e3084a853a058a656"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#ab5aaa5dfd05a3b3e3084a853a058a656">Rose::BinaryAnalysis::Architecture::Cil::instructionAlignment</a></div><div class="ttdeci">Alignment instructionAlignment() const override</div><div class="ttdoc">Alignment for encoded machine instructions.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil_html_aeb83bc0dc36289f0d6843f8d6d0c538a"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Cil.html#aeb83bc0dc36289f0d6843f8d6d0c538a">Rose::BinaryAnalysis::Architecture::Cil::getSuccessors</a></div><div class="ttdeci">AddressSet getSuccessors(SgAsmInstruction *, bool &complete) const override</div><div class="ttdoc">Control flow successors for a single instruction.</div></div>
<div class="ttc" id="aclassSawyer_1_1Container_1_1Interval_html"><div class="ttname"><a href="classSawyer_1_1Container_1_1Interval.html">Sawyer::Container::Interval</a></div><div class="ttdoc">Range of values delimited by endpoints.</div><div class="ttdef"><b>Definition</b> <a href="Interval_8h_source.html#l00031">Interval.h:31</a></div></div>
<div class="ttc" id="aclassSawyer_1_1Container_1_1Set_html"><div class="ttname"><a href="classSawyer_1_1Container_1_1Set.html">Sawyer::Container::Set< Address ></a></div></div>
<div class="ttc" id="aclassSawyer_1_1Optional_html"><div class="ttname"><a href="classSawyer_1_1Optional.html">Sawyer::Optional</a></div><div class="ttdoc">Holds a value or nothing.</div><div class="ttdef"><b>Definition</b> <a href="Optional_8h_source.html#l00056">Optional.h:56</a></div></div>
<div class="ttc" id="aclassSawyer_1_1SharedPointer_html"><div class="ttname"><a href="classSawyer_1_1SharedPointer.html">Sawyer::SharedPointer< RegisterDictionary ></a></div></div>
<div class="ttc" id="aclassSgAsmGenericHeader_html"><div class="ttname"><a href="classSgAsmGenericHeader.html">SgAsmGenericHeader</a></div><div class="ttdoc">Base class for container file headers.</div><div class="ttdef"><b>Definition</b> <a href="binaryInstruction_8C_source.html#l28618">binaryInstruction.C:28618</a></div></div>
<div class="ttc" id="aclassSgAsmInstruction_html"><div class="ttname"><a href="classSgAsmInstruction.html">SgAsmInstruction</a></div><div class="ttdoc">Base class for machine instructions.</div><div class="ttdef"><b>Definition</b> <a href="binaryInstruction_8C_source.html#l43208">binaryInstruction.C:43208</a></div></div>
<div class="ttc" id="anamespaceRose_1_1BinaryAnalysis_1_1Architecture_html_aab6ca938b286ac9af68ace46b0a9e89a"><div class="ttname"><a href="namespaceRose_1_1BinaryAnalysis_1_1Architecture.html#aab6ca938b286ac9af68ace46b0a9e89a">Rose::BinaryAnalysis::Architecture::CilPtr</a></div><div class="ttdeci">std::shared_ptr< Cil > CilPtr</div><div class="ttdoc">Reference counted pointer for Cil.</div><div class="ttdef"><b>Definition</b> <a href="Rose_2BinaryAnalysis_2Architecture_2BasicTypes_8h_source.html#l00044">Rose/BinaryAnalysis/Architecture/BasicTypes.h:44</a></div></div>
<div class="ttc" id="anamespaceRose_html"><div class="ttname"><a href="namespaceRose.html">Rose</a></div><div class="ttdoc">The ROSE library.</div><div class="ttdef"><b>Definition</b> <a href="BinaryTutorial_8dox_source.html#l00003">BinaryTutorial.dox:3</a></div></div>
<div class="ttc" id="anamespacestringify_1_1Rose_1_1BinaryAnalysis_1_1Disassembler_1_1Mips_1_1Decoder_html_a71cec98f7972bd8cd607558bcea2ffb2"><div class="ttname"><a href="namespacestringify_1_1Rose_1_1BinaryAnalysis_1_1Disassembler_1_1Mips_1_1Decoder.html#a71cec98f7972bd8cd607558bcea2ffb2">stringify::Rose::BinaryAnalysis::Disassembler::Mips::Decoder::Architecture</a></div><div class="ttdeci">const char * Architecture(int64_t)</div><div class="ttdoc">Convert Rose::BinaryAnalysis::Disassembler::Mips::Decoder::Architecture enum constant to a string.</div></div>
</div><!-- fragment --></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Wed Oct 2 2024 00:08:24 for ROSE by <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>