-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathArchitecture_2Base_8h_source.html
248 lines (248 loc) · 59.8 KB
/
Architecture_2Base_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
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
<!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: Base.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/Base.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_Base_H</span></div>
<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="preprocessor">#define ROSE_BinaryAnalysis_Architecture_Base_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> </div>
<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="preprocessor">#include <Rose/BinaryAnalysis/Alignment.h></span></div>
<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="preprocessor">#include <Rose/BinaryAnalysis/Architecture/BasicTypes.h></span></div>
<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="preprocessor">#include <Rose/BinaryAnalysis/ByteOrder.h></span></div>
<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span><span class="preprocessor">#include <Rose/BinaryAnalysis/CallingConvention/BasicTypes.h></span></div>
<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span><span class="preprocessor">#include <Rose/BinaryAnalysis/Disassembler/BasicTypes.h></span></div>
<div class="line"><a id="l00011" name="l00011"></a><span class="lineno"> 11</span><span class="preprocessor">#include <Rose/BinaryAnalysis/InstructionSemantics/BaseSemantics/BasicTypes.h></span></div>
<div class="line"><a id="l00012" name="l00012"></a><span class="lineno"> 12</span><span class="preprocessor">#include <Rose/BinaryAnalysis/Unparser/Base.h></span></div>
<div class="line"><a id="l00013" name="l00013"></a><span class="lineno"> 13</span> </div>
<div class="line"><a id="l00014" name="l00014"></a><span class="lineno"> 14</span><span class="preprocessor">#include <Sawyer/Interval.h></span></div>
<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"> 15</span><span class="preprocessor">#include <Sawyer/Optional.h></span></div>
<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span> </div>
<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="keyword">namespace </span><a class="code hl_namespace" href="namespaceRose.html">Rose</a> {</div>
<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="keyword">namespace </span>BinaryAnalysis {</div>
<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</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="l00020" name="l00020"></a><span class="lineno"> 20</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_1Base.html"> 22</a></span><span class="keyword">class </span><a class="code hl_class" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html">Base</a>: <span class="keyword">public</span> std::enable_shared_from_this<Base> {</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="l00025" name="l00025"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ac32fb431b1823b94185281598a6c2c03"> 25</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ac32fb431b1823b94185281598a6c2c03">Ptr</a> = <a class="code hl_typedef" href="namespaceRose_1_1BinaryAnalysis_1_1Architecture.html#a025b1c1e4df943f851e04a421f9efe27">BasePtr</a>;</div>
<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span> </div>
<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a5bc2ec9662e6ae405e8db81bf555f79f"> 28</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a5bc2ec9662e6ae405e8db81bf555f79f">ConstPtr</a> = <a class="code hl_typedef" href="namespaceRose_1_1BinaryAnalysis_1_1Architecture.html#aa711fd8ae3f4eb3297e6c8cfacdf952d">BaseConstPtr</a>;</div>
<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span> </div>
<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="keyword">private</span>:</div>
<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span> std::string name_; <span class="comment">// name of architecture</span></div>
<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span> <a class="code hl_class" href="classSawyer_1_1Optional.html">Sawyer::Optional<size_t></a> registrationId_; <span class="comment">// registration identification number</span></div>
<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> <span class="keywordtype">size_t</span> bytesPerWord_ = 0;</div>
<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span> <a class="code hl_enumeration" href="namespaceRose_1_1BinaryAnalysis_1_1ByteOrder.html#a936870e39bbf2fe6afa377992b9eea58">ByteOrder::Endianness</a> byteOrder_ = <a class="code hl_enumvalue" href="namespaceRose_1_1BinaryAnalysis_1_1ByteOrder.html#a936870e39bbf2fe6afa377992b9eea58a8459548c6f70379963bc23ac28ae09af">ByteOrder::ORDER_UNSPECIFIED</a>;</div>
<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div>
<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span><span class="keyword">protected</span>:</div>
<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span> <a class="code hl_class" href="classSawyer_1_1Cached.html">Sawyer::Cached<RegisterDictionaryPtr></a> registerDictionary_;</div>
<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> <a class="code hl_class" href="classSawyer_1_1Cached.html">Sawyer::Cached<RegisterDictionaryPtr></a> interruptDictionary_;</div>
<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span> <a class="code hl_class" href="classSawyer_1_1Cached.html">Sawyer::Cached<CallingConvention::Dictionary></a> callingConventions_;</div>
<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span> <a class="code hl_class" href="classSawyer_1_1Cached.html">Sawyer::Cached<Unparser::Base::Ptr></a> insnToString_, insnToStringNoAddr_;</div>
<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span> </div>
<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span><span class="keyword">protected</span>:</div>
<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span> <a class="code hl_class" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html">Base</a>(<span class="keyword">const</span> std::string &<a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a7758dd9b3ef45fe3bbacde31f25e0510">name</a>, <span class="keywordtype">size_t</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a73b51aa09fc1b1a71c7f66346359d28b">bytesPerWord</a>, <a class="code hl_enumeration" href="namespaceRose_1_1BinaryAnalysis_1_1ByteOrder.html#a936870e39bbf2fe6afa377992b9eea58">ByteOrder::Endianness</a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a02fb30e615b5afd19f867e66768b7688">byteOrder</a>);</div>
<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span> <span class="keyword">virtual</span> <a class="code hl_class" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html">~Base</a>();</div>
<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span> </div>
<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span> <span class="comment">// Properties</span></div>
<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a7758dd9b3ef45fe3bbacde31f25e0510"> 62</a></span> <span class="keyword">const</span> std::string& <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a7758dd9b3ef45fe3bbacde31f25e0510">name</a>() <span class="keyword">const</span>;</div>
<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span> </div>
<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a5f3e45432a5fb2e8a109c0d6118a0d62"> 70</a></span> <span class="keyword">const</span> <a class="code hl_class" href="classSawyer_1_1Optional.html">Sawyer::Optional<size_t></a>& <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a5f3e45432a5fb2e8a109c0d6118a0d62">registrationId</a>() <span class="keyword">const</span>;</div>
<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#abc31f520eac844e49767d0afe1ccf1fe"> 71</a></span> <span class="keywordtype">void</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#abc31f520eac844e49767d0afe1ccf1fe">registrationId</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSawyer_1_1Optional.html">Sawyer::Optional<size_t></a>&);</div>
<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a73b51aa09fc1b1a71c7f66346359d28b"> 81</a></span> <span class="keywordtype">size_t</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a73b51aa09fc1b1a71c7f66346359d28b">bytesPerWord</a>() <span class="keyword">const</span>;</div>
<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a1ee891ea7b9a61214b14496e263bb948"> 82</a></span> <span class="keywordtype">size_t</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a1ee891ea7b9a61214b14496e263bb948">bitsPerWord</a>() <span class="keyword">const</span>;</div>
<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a02fb30e615b5afd19f867e66768b7688"> 92</a></span> <a class="code hl_enumeration" href="namespaceRose_1_1BinaryAnalysis_1_1ByteOrder.html#a936870e39bbf2fe6afa377992b9eea58">ByteOrder::Endianness</a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a02fb30e615b5afd19f867e66768b7688">byteOrder</a>() <span class="keyword">const</span>;</div>
<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span> </div>
<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a06a80559e394e92b20bbaf76951d5900"> 103</a></span> <span class="keyword">virtual</span> <a class="code hl_class" href="classSawyer_1_1SharedPointer.html">RegisterDictionaryPtr</a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a06a80559e394e92b20bbaf76951d5900">registerDictionary</a>() <span class="keyword">const</span> = 0;</div>
<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span> </div>
<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ab47215e1c00810f5afb82f4bc04af5e4"> 116</a></span> <span class="keyword">virtual</span> <a class="code hl_class" href="classSawyer_1_1SharedPointer.html">RegisterDictionaryPtr</a> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ab47215e1c00810f5afb82f4bc04af5e4">interruptDictionary</a>() <span class="keyword">const</span>;</div>
<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"> 117</span> </div>
<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a000e445cbf23f56532f1bc5c7609dbac"> 127</a></span> <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="code hl_typedef" href="namespaceRose_1_1BinaryAnalysis_1_1CallingConvention.html#af24c0b3f801def1eda31a124049b5e08">CallingConvention::Dictionary</a>& <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a000e445cbf23f56532f1bc5c7609dbac">callingConventions</a>() <span class="keyword">const</span>;</div>
<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span> </div>
<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span> <span class="comment">// Lookup functions</span></div>
<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"> 132</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a08f7c3793592de8dfe7108c76245850c"> 138</a></span> <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a08f7c3793592de8dfe7108c76245850c">matchesName</a>(<span class="keyword">const</span> std::string&) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00139" name="l00139"></a><span class="lineno"> 139</span> </div>
<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#adc3611147dd3024b6d0de51ce006740f"> 145</a></span> <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#adc3611147dd3024b6d0de51ce006740f">matchesHeader</a>(<a class="code hl_class" href="classSgAsmGenericHeader.html">SgAsmGenericHeader</a>*) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"> 146</span> </div>
<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"> 148</span> <span class="comment">// Factories</span></div>
<div class="line"><a id="l00150" name="l00150"></a><span class="lineno"> 150</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00156" name="l00156"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a3e848a4594e882ab63f9a68cdb68c170"> 156</a></span> <span class="keyword">virtual</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_1Base.html#a3e848a4594e882ab63f9a68cdb68c170">newInstructionDecoder</a>() <span class="keyword">const</span> = 0;</div>
<div class="line"><a id="l00157" name="l00157"></a><span class="lineno"> 157</span> </div>
<div class="line"><a id="l00163" name="l00163"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a59df18db2baae88452946dc47fa28a66"> 163</a></span> <span class="keyword">virtual</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_1Base.html#a59df18db2baae88452946dc47fa28a66">newUnparser</a>() <span class="keyword">const</span> = 0;</div>
<div class="line"><a id="l00164" name="l00164"></a><span class="lineno"> 164</span> </div>
<div class="line"><a id="l00174" name="l00174"></a><span class="lineno"> 174</span> <span class="keyword">virtual</span> <a class="code hl_typedef" href="namespaceRose_1_1BinaryAnalysis_1_1InstructionSemantics_1_1BaseSemantics.html#a75ee406f19167965f5217e58fe9dc707">InstructionSemantics::BaseSemantics::DispatcherPtr</a></div>
<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ac9f7bc3595c3d4258ba834ae991008d2"> 175</a></span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ac9f7bc3595c3d4258ba834ae991008d2">newInstructionDispatcher</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="namespaceRose_1_1BinaryAnalysis_1_1InstructionSemantics_1_1BaseSemantics.html#a0c0106c0f124bfd48cf9c198e6bd7d4b">InstructionSemantics::BaseSemantics::RiscOperatorsPtr</a>&) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"> 176</span> </div>
<div class="line"><a id="l00178" name="l00178"></a><span class="lineno"> 178</span> <span class="comment">// Instruction characteristics</span></div>
<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"> 180</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00185" name="l00185"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a7166b2e3ad595362e876ccda9ce2dd57"> 185</a></span> <span class="keyword">virtual</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_1Base.html#a7166b2e3ad595362e876ccda9ce2dd57">bytesPerInstruction</a>() <span class="keyword">const</span> = 0;</div>
<div class="line"><a id="l00186" name="l00186"></a><span class="lineno"> 186</span> </div>
<div class="line"><a id="l00188" name="l00188"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a8ac610db2e1ce4866facad301b677e48"> 188</a></span> <span class="keyword">virtual</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_1Base.html#a8ac610db2e1ce4866facad301b677e48">instructionAlignment</a>() <span class="keyword">const</span> = 0;</div>
<div class="line"><a id="l00189" name="l00189"></a><span class="lineno"> 189</span> </div>
<div class="line"><a id="l00194" name="l00194"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ad73177355070eeb5741e5bcbc9fc56f1"> 194</a></span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ad73177355070eeb5741e5bcbc9fc56f1">instructionsCanOverlap</a>() <span class="keyword">const</span>;</div>
<div class="line"><a id="l00195" name="l00195"></a><span class="lineno"> 195</span> </div>
<div class="line"><a id="l00204" name="l00204"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a9a80fb8df16e13c9333b0227620c90a2"> 204</a></span> <span class="keyword">virtual</span> std::string <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a9a80fb8df16e13c9333b0227620c90a2">toString</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00205" name="l00205"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#aab7b2dad38bc3c6ca9fbb23096479292"> 205</a></span> <span class="keyword">virtual</span> std::string <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#aab7b2dad38bc3c6ca9fbb23096479292">toStringNoAddr</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00213" name="l00213"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a3a56b4c385168bcf6804478700cc54ae"> 213</a></span> <span class="keyword">virtual</span> std::string <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a3a56b4c385168bcf6804478700cc54ae">instructionMnemonic</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const</span> = 0;</div>
<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"> 214</span> </div>
<div class="line"><a id="l00225" name="l00225"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a08e2b8bd1499cc492f7e844f188ae970"> 225</a></span> <span class="keyword">virtual</span> std::string <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a08e2b8bd1499cc492f7e844f188ae970">instructionDescription</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00226" name="l00226"></a><span class="lineno"> 226</span> </div>
<div class="line"><a id="l00234" name="l00234"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a76e44136d49e87a71ca1ffaa468439fb"> 234</a></span> <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a76e44136d49e87a71ca1ffaa468439fb">isUnknown</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const</span> = 0;</div>
<div class="line"><a id="l00235" name="l00235"></a><span class="lineno"> 235</span> </div>
<div class="line"><a id="l00243" name="l00243"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a1fcbce03aea244dc9e5d9ac60554f000"> 243</a></span> <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a1fcbce03aea244dc9e5d9ac60554f000">terminatesBasicBlock</a>(<a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const</span> = 0;</div>
<div class="line"><a id="l00244" name="l00244"></a><span class="lineno"> 244</span> </div>
<div class="line"><a id="l00261" name="l00261"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ab7752a2ed38493ccb13a369c78d23988"> 261</a></span> <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ab7752a2ed38493ccb13a369c78d23988">isFunctionCallFast</a>(<span class="keyword">const</span> std::vector<SgAsmInstruction*>&, rose_addr_t *target, rose_addr_t *ret) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00262" name="l00262"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a3e8d8c8b916e00cefa0f1b7634c1d839"> 262</a></span> <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a3e8d8c8b916e00cefa0f1b7634c1d839">isFunctionCallSlow</a>(<span class="keyword">const</span> std::vector<SgAsmInstruction*>&, rose_addr_t *target, rose_addr_t *ret) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00276" name="l00276"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#abea57c49d0420f037021ff7b7afecd16"> 276</a></span> <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#abea57c49d0420f037021ff7b7afecd16">isFunctionReturnFast</a>(<span class="keyword">const</span> std::vector<SgAsmInstruction*>&) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00277" name="l00277"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a8abf86e9095b6f586e06c65b99a14d44"> 277</a></span> <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a8abf86e9095b6f586e06c65b99a14d44">isFunctionReturnSlow</a>(<span class="keyword">const</span> std::vector<SgAsmInstruction*>&) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00288" name="l00288"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a743b63088a626a602c6e9bcc3a054797"> 288</a></span> <span class="keyword">virtual</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_1Base.html#a743b63088a626a602c6e9bcc3a054797">branchTarget</a>(<a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00289" name="l00289"></a><span class="lineno"> 289</span> </div>
<div class="line"><a id="l00299" name="l00299"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#aa57d491fecd502be6b814fcbf0be6d58"> 299</a></span> <span class="keyword">virtual</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_1Base.html#aa57d491fecd502be6b814fcbf0be6d58">getSuccessors</a>(<a class="code hl_class" href="classSgAsmInstruction.html">SgAsmInstruction</a>*, <span class="keywordtype">bool</span> &complete) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00300" name="l00300"></a><span class="lineno"> 300</span> </div>
<div class="line"><a id="l00315" name="l00315"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a0e39bd2d1ac89476495a77ba0ea1dbca"> 315</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_1Base.html#a0e39bd2d1ac89476495a77ba0ea1dbca">getSuccessors</a>(<span class="keyword">const</span> std::vector<SgAsmInstruction*> &basicBlock, <span class="keywordtype">bool</span> &complete) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00316" name="l00316"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a584a12a9280fadaea065516e3c0cb88b"> 316</a></span> <span class="keyword">virtual</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_1Base.html#a584a12a9280fadaea065516e3c0cb88b">getSuccessors</a>(<span class="keyword">const</span> std::vector<SgAsmInstruction*> &basicBlock, <span class="keywordtype">bool</span> &complete,</div>
<div class="line"><a id="l00317" name="l00317"></a><span class="lineno"> 317</span> <span class="keyword">const</span> <a class="code hl_class" href="classSawyer_1_1SharedPointer.html">MemoryMapPtr</a> &initial_memory) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00321" name="l00321"></a><span class="lineno"> 321</span> <span class="comment">// Architecture-specific stuff for a partitioning engine.</span></div>
<div class="line"><a id="l00323" name="l00323"></a><span class="lineno"> 323</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00330" name="l00330"></a><span class="lineno"> 330</span> <span class="keyword">virtual</span> std::vector<Partitioner2::FunctionPrologueMatcherPtr></div>
<div class="line"><a id="l00331" name="l00331"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a9c963c4b3bb04cd747f9c84de49a48d2"> 331</a></span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a9c963c4b3bb04cd747f9c84de49a48d2">functionPrologueMatchers</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSawyer_1_1SharedPointer.html">Partitioner2::EnginePtr</a>&) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00332" name="l00332"></a><span class="lineno"> 332</span> </div>
<div class="line"><a id="l00338" name="l00338"></a><span class="lineno"> 338</span> <span class="keyword">virtual</span> std::vector<Partitioner2::BasicBlockCallbackPtr></div>
<div class="line"><a id="l00339" name="l00339"></a><span class="lineno"><a class="line" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a30db9046dabe9c47b53219f28941a082"> 339</a></span> <a class="code hl_function" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a30db9046dabe9c47b53219f28941a082">basicBlockCreationHooks</a>(<span class="keyword">const</span> <a class="code hl_class" href="classSawyer_1_1SharedPointer.html">Partitioner2::EnginePtr</a>&) <span class="keyword">const</span>;</div>
<div class="line"><a id="l00340" name="l00340"></a><span class="lineno"> 340</span> </div>
<div class="line"><a id="l00342" name="l00342"></a><span class="lineno"> 342</span> <span class="comment">// Miscellaneous</span></div>
<div class="line"><a id="l00344" name="l00344"></a><span class="lineno"> 344</span><span class="keyword">protected</span>:</div>
<div class="line"><a id="l00345" name="l00345"></a><span class="lineno"> 345</span> <a class="code hl_typedef" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ac32fb431b1823b94185281598a6c2c03">Ptr</a> ptr();</div>
<div class="line"><a id="l00346" name="l00346"></a><span class="lineno"> 346</span> <a class="code hl_typedef" href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a5bc2ec9662e6ae405e8db81bf555f79f">ConstPtr</a> constPtr() <span class="keyword">const</span>;</div>
<div class="line"><a id="l00347" name="l00347"></a><span class="lineno"> 347</span>};</div>
</div>
<div class="line"><a id="l00348" name="l00348"></a><span class="lineno"> 348</span> </div>
<div class="line"><a id="l00349" name="l00349"></a><span class="lineno"> 349</span>} <span class="comment">// namespace</span></div>
<div class="line"><a id="l00350" name="l00350"></a><span class="lineno"> 350</span>} <span class="comment">// namespace</span></div>
<div class="line"><a id="l00351" name="l00351"></a><span class="lineno"> 351</span>} <span class="comment">// namespace</span></div>
<div class="line"><a id="l00352" name="l00352"></a><span class="lineno"> 352</span> </div>
<div class="line"><a id="l00353" name="l00353"></a><span class="lineno"> 353</span><span class="preprocessor">#endif</span></div>
<div class="line"><a id="l00354" name="l00354"></a><span class="lineno"> 354</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_1Base_html_a000e445cbf23f56532f1bc5c7609dbac"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a000e445cbf23f56532f1bc5c7609dbac">Rose::BinaryAnalysis::Architecture::Base::callingConventions</a></div><div class="ttdeci">virtual const CallingConvention::Dictionary & callingConventions() const</div><div class="ttdoc">Property: Calling convention definitions.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a02fb30e615b5afd19f867e66768b7688"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a02fb30e615b5afd19f867e66768b7688">Rose::BinaryAnalysis::Architecture::Base::byteOrder</a></div><div class="ttdeci">ByteOrder::Endianness byteOrder() const</div><div class="ttdoc">Property: Byte order for memory.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a06a80559e394e92b20bbaf76951d5900"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a06a80559e394e92b20bbaf76951d5900">Rose::BinaryAnalysis::Architecture::Base::registerDictionary</a></div><div class="ttdeci">virtual RegisterDictionaryPtr registerDictionary() const =0</div><div class="ttdoc">Property: Register dictionary.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a08e2b8bd1499cc492f7e844f188ae970"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a08e2b8bd1499cc492f7e844f188ae970">Rose::BinaryAnalysis::Architecture::Base::instructionDescription</a></div><div class="ttdeci">virtual std::string instructionDescription(const SgAsmInstruction *) const</div><div class="ttdoc">Description for an instruction.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a08f7c3793592de8dfe7108c76245850c"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a08f7c3793592de8dfe7108c76245850c">Rose::BinaryAnalysis::Architecture::Base::matchesName</a></div><div class="ttdeci">virtual bool matchesName(const std::string &) const</div><div class="ttdoc">Tests whether this architecture matches a name.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a0e39bd2d1ac89476495a77ba0ea1dbca"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a0e39bd2d1ac89476495a77ba0ea1dbca">Rose::BinaryAnalysis::Architecture::Base::getSuccessors</a></div><div class="ttdeci">AddressSet getSuccessors(const std::vector< SgAsmInstruction * > &basicBlock, bool &complete) const</div><div class="ttdoc">Control flow successors for a basic block.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a1ee891ea7b9a61214b14496e263bb948"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a1ee891ea7b9a61214b14496e263bb948">Rose::BinaryAnalysis::Architecture::Base::bitsPerWord</a></div><div class="ttdeci">size_t bitsPerWord() const</div><div class="ttdoc">Property: Word size.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a1fcbce03aea244dc9e5d9ac60554f000"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a1fcbce03aea244dc9e5d9ac60554f000">Rose::BinaryAnalysis::Architecture::Base::terminatesBasicBlock</a></div><div class="ttdeci">virtual bool terminatesBasicBlock(SgAsmInstruction *) const =0</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_1Base_html_a30db9046dabe9c47b53219f28941a082"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a30db9046dabe9c47b53219f28941a082">Rose::BinaryAnalysis::Architecture::Base::basicBlockCreationHooks</a></div><div class="ttdeci">virtual std::vector< Partitioner2::BasicBlockCallbackPtr > basicBlockCreationHooks(const Partitioner2::EnginePtr &) const</div><div class="ttdoc">Architecture-specific basic block callbacks for partitioning.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a3a56b4c385168bcf6804478700cc54ae"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a3a56b4c385168bcf6804478700cc54ae">Rose::BinaryAnalysis::Architecture::Base::instructionMnemonic</a></div><div class="ttdeci">virtual std::string instructionMnemonic(const SgAsmInstruction *) const =0</div><div class="ttdoc">Mnemonic for an instruction.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a3e848a4594e882ab63f9a68cdb68c170"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a3e848a4594e882ab63f9a68cdb68c170">Rose::BinaryAnalysis::Architecture::Base::newInstructionDecoder</a></div><div class="ttdeci">virtual Disassembler::BasePtr newInstructionDecoder() const =0</div><div class="ttdoc">Construct and return a new instruction decoder.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a3e8d8c8b916e00cefa0f1b7634c1d839"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a3e8d8c8b916e00cefa0f1b7634c1d839">Rose::BinaryAnalysis::Architecture::Base::isFunctionCallSlow</a></div><div class="ttdeci">virtual bool isFunctionCallSlow(const std::vector< SgAsmInstruction * > &, rose_addr_t *target, rose_addr_t *ret) const</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_1Base_html_a584a12a9280fadaea065516e3c0cb88b"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a584a12a9280fadaea065516e3c0cb88b">Rose::BinaryAnalysis::Architecture::Base::getSuccessors</a></div><div class="ttdeci">virtual AddressSet getSuccessors(const std::vector< SgAsmInstruction * > &basicBlock, bool &complete, const MemoryMapPtr &initial_memory) const</div><div class="ttdoc">Control flow successors for a basic block.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a59df18db2baae88452946dc47fa28a66"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a59df18db2baae88452946dc47fa28a66">Rose::BinaryAnalysis::Architecture::Base::newUnparser</a></div><div class="ttdeci">virtual Unparser::BasePtr newUnparser() const =0</div><div class="ttdoc">Construct and return a new instruction unparser.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a5bc2ec9662e6ae405e8db81bf555f79f"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a5bc2ec9662e6ae405e8db81bf555f79f">Rose::BinaryAnalysis::Architecture::Base::ConstPtr</a></div><div class="ttdeci">BaseConstPtr ConstPtr</div><div class="ttdoc">Reference counting pointer to const object.</div><div class="ttdef"><b>Definition</b> <a href="Architecture_2Base_8h_source.html#l00028">Architecture/Base.h:28</a></div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a5f3e45432a5fb2e8a109c0d6118a0d62"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a5f3e45432a5fb2e8a109c0d6118a0d62">Rose::BinaryAnalysis::Architecture::Base::registrationId</a></div><div class="ttdeci">const Sawyer::Optional< size_t > & registrationId() const</div><div class="ttdoc">Property: Registration identification number.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a7166b2e3ad595362e876ccda9ce2dd57"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a7166b2e3ad595362e876ccda9ce2dd57">Rose::BinaryAnalysis::Architecture::Base::bytesPerInstruction</a></div><div class="ttdeci">virtual Sawyer::Container::Interval< size_t > bytesPerInstruction() const =0</div><div class="ttdoc">Valid sizes for encoded machine instructions.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a73b51aa09fc1b1a71c7f66346359d28b"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a73b51aa09fc1b1a71c7f66346359d28b">Rose::BinaryAnalysis::Architecture::Base::bytesPerWord</a></div><div class="ttdeci">size_t bytesPerWord() const</div><div class="ttdoc">Property: Word size.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a743b63088a626a602c6e9bcc3a054797"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a743b63088a626a602c6e9bcc3a054797">Rose::BinaryAnalysis::Architecture::Base::branchTarget</a></div><div class="ttdeci">virtual Sawyer::Optional< rose_addr_t > branchTarget(SgAsmInstruction *) const</div><div class="ttdoc">Obtains the virtual address for a branching instruction.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a76e44136d49e87a71ca1ffaa468439fb"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a76e44136d49e87a71ca1ffaa468439fb">Rose::BinaryAnalysis::Architecture::Base::isUnknown</a></div><div class="ttdeci">virtual bool isUnknown(const SgAsmInstruction *) const =0</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_1Base_html_a7758dd9b3ef45fe3bbacde31f25e0510"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a7758dd9b3ef45fe3bbacde31f25e0510">Rose::BinaryAnalysis::Architecture::Base::name</a></div><div class="ttdeci">const std::string & name() const</div><div class="ttdoc">Property: Architecture definition name.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a8abf86e9095b6f586e06c65b99a14d44"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a8abf86e9095b6f586e06c65b99a14d44">Rose::BinaryAnalysis::Architecture::Base::isFunctionReturnSlow</a></div><div class="ttdeci">virtual bool isFunctionReturnSlow(const std::vector< SgAsmInstruction * > &) const</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_1Base_html_a8ac610db2e1ce4866facad301b677e48"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a8ac610db2e1ce4866facad301b677e48">Rose::BinaryAnalysis::Architecture::Base::instructionAlignment</a></div><div class="ttdeci">virtual Alignment instructionAlignment() const =0</div><div class="ttdoc">Alignment for encoded machine instructions.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a9a80fb8df16e13c9333b0227620c90a2"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a9a80fb8df16e13c9333b0227620c90a2">Rose::BinaryAnalysis::Architecture::Base::toString</a></div><div class="ttdeci">virtual std::string toString(const SgAsmInstruction *) const</div><div class="ttdoc">Unparse an instruction to a string.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_a9c963c4b3bb04cd747f9c84de49a48d2"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#a9c963c4b3bb04cd747f9c84de49a48d2">Rose::BinaryAnalysis::Architecture::Base::functionPrologueMatchers</a></div><div class="ttdeci">virtual std::vector< Partitioner2::FunctionPrologueMatcherPtr > functionPrologueMatchers(const Partitioner2::EnginePtr &) const</div><div class="ttdoc">Instruction patterns matching function prologues.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_aa57d491fecd502be6b814fcbf0be6d58"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#aa57d491fecd502be6b814fcbf0be6d58">Rose::BinaryAnalysis::Architecture::Base::getSuccessors</a></div><div class="ttdeci">virtual AddressSet getSuccessors(SgAsmInstruction *, bool &complete) const</div><div class="ttdoc">Control flow successors for a single instruction.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_aab7b2dad38bc3c6ca9fbb23096479292"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#aab7b2dad38bc3c6ca9fbb23096479292">Rose::BinaryAnalysis::Architecture::Base::toStringNoAddr</a></div><div class="ttdeci">virtual std::string toStringNoAddr(const SgAsmInstruction *) const</div><div class="ttdoc">Unparse an instruction to a string.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_ab47215e1c00810f5afb82f4bc04af5e4"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ab47215e1c00810f5afb82f4bc04af5e4">Rose::BinaryAnalysis::Architecture::Base::interruptDictionary</a></div><div class="ttdeci">virtual RegisterDictionaryPtr interruptDictionary() const</div><div class="ttdoc">Property: Interrupt dictionary.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_ab7752a2ed38493ccb13a369c78d23988"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ab7752a2ed38493ccb13a369c78d23988">Rose::BinaryAnalysis::Architecture::Base::isFunctionCallFast</a></div><div class="ttdeci">virtual bool isFunctionCallFast(const std::vector< SgAsmInstruction * > &, rose_addr_t *target, rose_addr_t *ret) const</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_1Base_html_abc31f520eac844e49767d0afe1ccf1fe"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#abc31f520eac844e49767d0afe1ccf1fe">Rose::BinaryAnalysis::Architecture::Base::registrationId</a></div><div class="ttdeci">void registrationId(const Sawyer::Optional< size_t > &)</div><div class="ttdoc">Property: Registration identification number.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_abea57c49d0420f037021ff7b7afecd16"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#abea57c49d0420f037021ff7b7afecd16">Rose::BinaryAnalysis::Architecture::Base::isFunctionReturnFast</a></div><div class="ttdeci">virtual bool isFunctionReturnFast(const std::vector< SgAsmInstruction * > &) const</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_1Base_html_ac32fb431b1823b94185281598a6c2c03"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ac32fb431b1823b94185281598a6c2c03">Rose::BinaryAnalysis::Architecture::Base::Ptr</a></div><div class="ttdeci">BasePtr Ptr</div><div class="ttdoc">Reference counting pointer.</div><div class="ttdef"><b>Definition</b> <a href="Architecture_2Base_8h_source.html#l00025">Architecture/Base.h:25</a></div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_ac9f7bc3595c3d4258ba834ae991008d2"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ac9f7bc3595c3d4258ba834ae991008d2">Rose::BinaryAnalysis::Architecture::Base::newInstructionDispatcher</a></div><div class="ttdeci">virtual InstructionSemantics::BaseSemantics::DispatcherPtr newInstructionDispatcher(const InstructionSemantics::BaseSemantics::RiscOperatorsPtr &) const</div><div class="ttdoc">Construct and return a new instruction dispatcher.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_ad73177355070eeb5741e5bcbc9fc56f1"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#ad73177355070eeb5741e5bcbc9fc56f1">Rose::BinaryAnalysis::Architecture::Base::instructionsCanOverlap</a></div><div class="ttdeci">bool instructionsCanOverlap() const</div><div class="ttdoc">Whether instructions can overlap in memory.</div></div>
<div class="ttc" id="aclassRose_1_1BinaryAnalysis_1_1Architecture_1_1Base_html_adc3611147dd3024b6d0de51ce006740f"><div class="ttname"><a href="classRose_1_1BinaryAnalysis_1_1Architecture_1_1Base.html#adc3611147dd3024b6d0de51ce006740f">Rose::BinaryAnalysis::Architecture::Base::matchesHeader</a></div><div class="ttdeci">virtual bool matchesHeader(SgAsmGenericHeader *) const</div><div class="ttdoc">Tests whether this architecture matches a file header.</div></div>
<div class="ttc" id="aclassSawyer_1_1Cached_html"><div class="ttname"><a href="classSawyer_1_1Cached.html">Sawyer::Cached</a></div><div class="ttdoc">Implements cache data members.</div><div class="ttdef"><b>Definition</b> <a href="Cached_8h_source.html#l00040">Cached.h:40</a></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_a025b1c1e4df943f851e04a421f9efe27"><div class="ttname"><a href="namespaceRose_1_1BinaryAnalysis_1_1Architecture.html#a025b1c1e4df943f851e04a421f9efe27">Rose::BinaryAnalysis::Architecture::BasePtr</a></div><div class="ttdeci">std::shared_ptr< Base > BasePtr</div><div class="ttdoc">Reference counted pointer for Architecture::Base.</div><div class="ttdef"><b>Definition</b> <a href="Rose_2BinaryAnalysis_2Architecture_2BasicTypes_8h_source.html#l00040">Rose/BinaryAnalysis/Architecture/BasicTypes.h:40</a></div></div>
<div class="ttc" id="anamespaceRose_1_1BinaryAnalysis_1_1Architecture_html_aa711fd8ae3f4eb3297e6c8cfacdf952d"><div class="ttname"><a href="namespaceRose_1_1BinaryAnalysis_1_1Architecture.html#aa711fd8ae3f4eb3297e6c8cfacdf952d">Rose::BinaryAnalysis::Architecture::BaseConstPtr</a></div><div class="ttdeci">std::shared_ptr< const Base > BaseConstPtr</div><div class="ttdoc">Reference counted pointer for Architecture::Base.</div><div class="ttdef"><b>Definition</b> <a href="Rose_2BinaryAnalysis_2Architecture_2BasicTypes_8h_source.html#l00041">Rose/BinaryAnalysis/Architecture/BasicTypes.h:41</a></div></div>
<div class="ttc" id="anamespaceRose_1_1BinaryAnalysis_1_1ByteOrder_html_a936870e39bbf2fe6afa377992b9eea58"><div class="ttname"><a href="namespaceRose_1_1BinaryAnalysis_1_1ByteOrder.html#a936870e39bbf2fe6afa377992b9eea58">Rose::BinaryAnalysis::ByteOrder::Endianness</a></div><div class="ttdeci">Endianness</div><div class="ttdoc">Byte order.</div><div class="ttdef"><b>Definition</b> <a href="ByteOrder_8h_source.html#l00019">ByteOrder.h:19</a></div></div>
<div class="ttc" id="anamespaceRose_1_1BinaryAnalysis_1_1ByteOrder_html_a936870e39bbf2fe6afa377992b9eea58a8459548c6f70379963bc23ac28ae09af"><div class="ttname"><a href="namespaceRose_1_1BinaryAnalysis_1_1ByteOrder.html#a936870e39bbf2fe6afa377992b9eea58a8459548c6f70379963bc23ac28ae09af">Rose::BinaryAnalysis::ByteOrder::ORDER_UNSPECIFIED</a></div><div class="ttdeci">@ ORDER_UNSPECIFIED</div><div class="ttdoc">Endianness is unspecified and unknown.</div><div class="ttdef"><b>Definition</b> <a href="ByteOrder_8h_source.html#l00021">ByteOrder.h:21</a></div></div>
<div class="ttc" id="anamespaceRose_1_1BinaryAnalysis_1_1CallingConvention_html_af24c0b3f801def1eda31a124049b5e08"><div class="ttname"><a href="namespaceRose_1_1BinaryAnalysis_1_1CallingConvention.html#af24c0b3f801def1eda31a124049b5e08">Rose::BinaryAnalysis::CallingConvention::Dictionary</a></div><div class="ttdeci">std::vector< DefinitionPtr > Dictionary</div><div class="ttdoc">An ordered collection of calling convention definitions.</div><div class="ttdef"><b>Definition</b> <a href="Rose_2BinaryAnalysis_2CallingConvention_2BasicTypes_8h_source.html#l00071">Rose/BinaryAnalysis/CallingConvention/BasicTypes.h:71</a></div></div>
<div class="ttc" id="anamespaceRose_1_1BinaryAnalysis_1_1InstructionSemantics_1_1BaseSemantics_html_a0c0106c0f124bfd48cf9c198e6bd7d4b"><div class="ttname"><a href="namespaceRose_1_1BinaryAnalysis_1_1InstructionSemantics_1_1BaseSemantics.html#a0c0106c0f124bfd48cf9c198e6bd7d4b">Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::RiscOperatorsPtr</a></div><div class="ttdeci">boost::shared_ptr< RiscOperators > RiscOperatorsPtr</div><div class="ttdoc">Shared-ownership pointer to a RISC operators object.</div><div class="ttdef"><b>Definition</b> <a href="Rose_2BinaryAnalysis_2InstructionSemantics_2BaseSemantics_2BasicTypes_8h_source.html#l00066">Rose/BinaryAnalysis/InstructionSemantics/BaseSemantics/BasicTypes.h:66</a></div></div>
<div class="ttc" id="anamespaceRose_1_1BinaryAnalysis_1_1InstructionSemantics_1_1BaseSemantics_html_a75ee406f19167965f5217e58fe9dc707"><div class="ttname"><a href="namespaceRose_1_1BinaryAnalysis_1_1InstructionSemantics_1_1BaseSemantics.html#a75ee406f19167965f5217e58fe9dc707">Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::DispatcherPtr</a></div><div class="ttdeci">boost::shared_ptr< Dispatcher > DispatcherPtr</div><div class="ttdoc">Shared-ownership pointer to a semantics instruction dispatcher.</div><div class="ttdef"><b>Definition</b> <a href="Rose_2BinaryAnalysis_2InstructionSemantics_2BaseSemantics_2BasicTypes_8h_source.html#l00069">Rose/BinaryAnalysis/InstructionSemantics/BaseSemantics/BasicTypes.h:69</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:23 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>