LIEF: Library to Instrument Executable Formats Version 0.15.0
Loading...
Searching...
No Matches
instructions.hpp
1/* Copyright 2017 - 2024 R. Thomas
2 * Copyright 2017 - 2024 Quarkslab
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#ifndef LIEF_DEX_INSTRUCTIONS_H
17#define LIEF_DEX_INSTRUCTIONS_H
18#include "LIEF/visibility.h"
19#include "LIEF/types.hpp"
20#include <cstddef>
21
22namespace LIEF {
23namespace DEX {
24
25enum SWITCH_ARRAY_IDENT : uint16_t {
26 IDENT_PACKED_SWITCH = 0x0100,
27 IDENT_SPARSE_SWITCH = 0x0200,
28 IDENT_FILL_ARRAY = 0x0300,
29};
30
32enum OPCODES : uint8_t {
33 OP_NOP = 0x00,
34 OP_MOVE = 0x01,
35 OP_MOVE_FROM_16 = 0x02,
36 OP_MOVE_16 = 0x03,
37 OP_MOVE_WIDE = 0x04,
38 OP_MOVE_WIDE_FROM_16 = 0x05,
39 OP_MOVE_WIDE_16 = 0x06,
40 OP_MOVE_OBJECT = 0x07,
41 OP_MOVE_OBJECT_FROM_16 = 0x08,
42 OP_MOVE_OBJECT_16 = 0x09,
43 OP_MOVE_RESULT = 0x0a,
44 OP_MOVE_RESULT_WIDE = 0x0b,
45 OP_MOVE_RESULT_OBJECT = 0x0c,
46 OP_MOVE_EXCEPTION = 0x0d,
47 OP_RETURN_VOID = 0x0e,
48 OP_RETURN = 0x0f,
49 OP_RETURN_WIDE = 0x10,
50 OP_RETURN_OBJECT = 0x11,
51 OP_CONST_4 = 0x12,
52 OP_CONST_16 = 0x13,
53 OP_CONST = 0x14,
54 OP_CONST_HIGH_16 = 0x15,
55 OP_CONST_WIDE_16 = 0x16,
56 OP_CONST_WIDE_32 = 0x17,
57 OP_CONST_WIDE = 0x18,
58 OP_CONST_WIDE_HIGH_16 = 0x19,
59 OP_CONST_STRING = 0x1a,
60 OP_CONST_STRING_JUMBO = 0x1b,
61 OP_CONST_CLASS = 0x1c,
62 OP_MONITOR_ENTER = 0x1d,
63 OP_MONITOR_EXIT = 0x1e,
64 OP_CHECK_CAST = 0x1f,
65 OP_INSTANCE_OF = 0x20,
66 OP_ARRAY_LENGTH = 0x21,
67 OP_NEW_INSTANCE = 0x22,
68 OP_NEW_ARRAY = 0x23,
69 OP_FILLED_NEW_ARRAY = 0x24,
70 OP_FILLED_NEW_ARRAY_RANGE = 0x25,
71 OP_FILL_ARRAY_DATA = 0x26,
72 OP_THROW = 0x27,
73 OP_GOTO = 0x28,
74 OP_GOTO_16 = 0x29,
75 OP_GOTO_32 = 0x2a,
76 OP_PACKED_SWITCH = 0x2b,
77 OP_SPARSE_SWITCH = 0x2c,
78 OP_CMPL_FLOAT = 0x2d,
79 OP_CMPG_FLOAT = 0x2e,
80 OP_CMPL_DOUBLE = 0x2f,
81 OP_CMPG_DOUBLE = 0x30,
82 OP_CMP_LONG = 0x31,
83 OP_IF_EQ = 0x32,
84 OP_IF_NE = 0x33,
85 OP_IF_LT = 0x34,
86 OP_IF_GE = 0x35,
87 OP_IF_GT = 0x36,
88 OP_IF_LE = 0x37,
89 OP_IF_EQZ = 0x38,
90 OP_IF_NEZ = 0x39,
91 OP_IF_LTZ = 0x3a,
92 OP_IF_GEZ = 0x3b,
93 OP_IF_GTZ = 0x3c,
94 OP_IF_LEZ = 0x3d,
95 OP_AGET = 0x44,
96 OP_AGET_WIDE = 0x45,
97 OP_AGET_OBJECT = 0x46,
98 OP_AGET_BOOLEAN = 0x47,
99 OP_AGET_BYTE = 0x48,
100 OP_AGET_CHAR = 0x49,
101 OP_AGET_SHORT = 0x4a,
102 OP_APUT = 0x4b,
103 OP_APUT_WIDE = 0x4c,
104 OP_APUT_OBJECT = 0x4d,
105 OP_APUT_BOOLEAN = 0x4e,
106 OP_APUT_BYTE = 0x4f,
107 OP_APUT_CHAR = 0x50,
108 OP_APUT_SHORT = 0x51,
109 OP_IGET = 0x52,
110 OP_IGET_WIDE = 0x53,
111 OP_IGET_OBJECT = 0x54,
112 OP_IGET_BOOLEAN = 0x55,
113 OP_IGET_BYTE = 0x56,
114 OP_IGET_CHAR = 0x57,
115 OP_IGET_SHORT = 0x58,
116 OP_IPUT = 0x59,
117 OP_IPUT_WIDE = 0x5a,
118 OP_IPUT_OBJECT = 0x5b,
119 OP_IPUT_BOOLEAN = 0x5c,
120 OP_IPUT_BYTE = 0x5d,
121 OP_IPUT_CHAR = 0x5e,
122 OP_IPUT_SHORT = 0x5f,
123 OP_SGET = 0x60,
124 OP_SGET_WIDE = 0x61,
125 OP_SGET_OBJECT = 0x62,
126 OP_SGET_BOOLEAN = 0x63,
127 OP_SGET_BYTE = 0x64,
128 OP_SGET_CHAR = 0x65,
129 OP_SGET_SHORT = 0x66,
130 OP_SPUT = 0x67,
131 OP_SPUT_WIDE = 0x68,
132 OP_SPUT_OBJECT = 0x69,
133 OP_SPUT_BOOLEAN = 0x6a,
134 OP_SPUT_BYTE = 0x6b,
135 OP_SPUT_CHAR = 0x6c,
136 OP_SPUT_SHORT = 0x6d,
137 OP_INVOKE_VIRTUAL = 0x6e,
138 OP_INVOKE_SUPER = 0x6f,
139 OP_INVOKE_DIRECT = 0x70,
140 OP_INVOKE_STATIC = 0x71,
141 OP_INVOKE_INTERFACE = 0x72,
142 OP_RETURN_VOID_NO_BARRIER = 0x73,
143 OP_INVOKE_VIRTUAL_RANGE = 0x74,
144 OP_INVOKE_SUPER_RANGE = 0x75,
145 OP_INVOKE_DIRECT_RANGE = 0x76,
146 OP_INVOKE_STATIC_RANGE = 0x77,
147 OP_INVOKE_INTERFACE_RANGE = 0x78,
148 OP_NEG_INT = 0x7b,
149 OP_NOT_INT = 0x7c,
150 OP_NEG_LONG = 0x7d,
151 OP_NOT_LONG = 0x7e,
152 OP_NEG_FLOAT = 0x7f,
153 OP_NEG_DOUBLE = 0x80,
154 OP_INT_TO_LONG = 0x81,
155 OP_INT_TO_FLOAT = 0x82,
156 OP_INT_TO_DOUBLE = 0x83,
157 OP_LONG_TO_INT = 0x84,
158 OP_LONG_TO_FLOAT = 0x85,
159 OP_LONG_TO_DOUBLE = 0x86,
160 OP_FLOAT_TO_INT = 0x87,
161 OP_FLOAT_TO_LONG = 0x88,
162 OP_FLOAT_TO_DOUBLE = 0x89,
163 OP_DOUBLE_TO_INT = 0x8a,
164 OP_DOUBLE_TO_LONG = 0x8b,
165 OP_DOUBLE_TO_FLOAT = 0x8c,
166 OP_INT_TO_BYTE = 0x8d,
167 OP_INT_TO_CHAR = 0x8e,
168 OP_INT_TO_SHORT = 0x8f,
169 OP_ADD_INT = 0x90,
170 OP_SUB_INT = 0x91,
171 OP_MUL_INT = 0x92,
172 OP_DIV_INT = 0x93,
173 OP_REM_INT = 0x94,
174 OP_AND_INT = 0x95,
175 OP_OR_INT = 0x96,
176 OP_XOR_INT = 0x97,
177 OP_SHL_INT = 0x98,
178 OP_SHR_INT = 0x99,
179 OP_USHR_INT = 0x9a,
180 OP_ADD_LONG = 0x9b,
181 OP_SUB_LONG = 0x9c,
182 OP_MUL_LONG = 0x9d,
183 OP_DIV_LONG = 0x9e,
184 OP_REM_LONG = 0x9f,
185 OP_AND_LONG = 0xa0,
186 OP_OR_LONG = 0xa1,
187 OP_XOR_LONG = 0xa2,
188 OP_SHL_LONG = 0xa3,
189 OP_SHR_LONG = 0xa4,
190 OP_USHR_LONG = 0xa5,
191 OP_ADD_FLOAT = 0xa6,
192 OP_SUB_FLOAT = 0xa7,
193 OP_MUL_FLOAT = 0xa8,
194 OP_DIV_FLOAT = 0xa9,
195 OP_REM_FLOAT = 0xaa,
196 OP_ADD_DOUBLE = 0xab,
197 OP_SUB_DOUBLE = 0xac,
198 OP_MUL_DOUBLE = 0xad,
199 OP_DIV_DOUBLE = 0xae,
200 OP_REM_DOUBLE = 0xaf,
201 OP_ADD_INT_2_ADDR = 0xb0,
202 OP_SUB_INT_2_ADDR = 0xb1,
203 OP_MUL_INT_2_ADDR = 0xb2,
204 OP_DIV_INT_2_ADDR = 0xb3,
205 OP_REM_INT_2_ADDR = 0xb4,
206 OP_AND_INT_2_ADDR = 0xb5,
207 OP_OR_INT_2_ADDR = 0xb6,
208 OP_XOR_INT_2_ADDR = 0xb7,
209 OP_SHL_INT_2_ADDR = 0xb8,
210 OP_SHR_INT_2_ADDR = 0xb9,
211 OP_USHR_INT_2_ADDR = 0xba,
212 OP_ADD_LONG_2_ADDR = 0xbb,
213 OP_SUB_LONG_2_ADDR = 0xbc,
214 OP_MUL_LONG_2_ADDR = 0xbd,
215 OP_DIV_LONG_2_ADDR = 0xbe,
216 OP_REM_LONG_2_ADDR = 0xbf,
217 OP_AND_LONG_2_ADDR = 0xc0,
218 OP_OR_LONG_2_ADDR = 0xc1,
219 OP_XOR_LONG_2_ADDR = 0xc2,
220 OP_SHL_LONG_2_ADDR = 0xc3,
221 OP_SHR_LONG_2_ADDR = 0xc4,
222 OP_USHR_LONG_2_ADDR = 0xc5,
223 OP_ADD_FLOAT_2_ADDR = 0xc6,
224 OP_SUB_FLOAT_2_ADDR = 0xc7,
225 OP_MUL_FLOAT_2_ADDR = 0xc8,
226 OP_DIV_FLOAT_2_ADDR = 0xc9,
227 OP_REM_FLOAT_2_ADDR = 0xca,
228 OP_ADD_DOUBLE_2_ADDR = 0xcb,
229 OP_SUB_DOUBLE_2_ADDR = 0xcc,
230 OP_MUL_DOUBLE_2_ADDR = 0xcd,
231 OP_DIV_DOUBLE_2_ADDR = 0xce,
232 OP_REM_DOUBLE_2_ADDR = 0xcf,
233 OP_ADD_INT_LIT_16 = 0xd0,
234 OP_RSUB_INT = 0xd1,
235 OP_MUL_INT_LIT_16 = 0xd2,
236 OP_DIV_INT_LIT_16 = 0xd3,
237 OP_REM_INT_LIT_16 = 0xd4,
238 OP_AND_INT_LIT_16 = 0xd5,
239 OP_OR_INT_LIT_16 = 0xd6,
240 OP_XOR_INT_LIT_16 = 0xd7,
241 OP_ADD_INT_LIT_8 = 0xd8,
242 OP_RSUB_INT_LIT_8 = 0xd9,
243 OP_MUL_INT_LIT_8 = 0xda,
244 OP_DIV_INT_LIT_8 = 0xdb,
245 OP_REM_INT_LIT_8 = 0xdc,
246 OP_AND_INT_LIT_8 = 0xdd,
247 OP_OR_INT_LIT_8 = 0xde,
248 OP_XOR_INT_LIT_8 = 0xdf,
249 OP_SHL_INT_LIT_8 = 0xe0,
250 OP_SHR_INT_LIT_8 = 0xe1,
251 OP_USHR_INT_LIT_8 = 0xe2,
252
253 // ODEX
254 OP_IGET_QUICK = 0xe3,
255 OP_IGET_WIDE_QUICK = 0xe4,
256 OP_IGET_OBJECT_QUICK = 0xe5,
257 OP_IPUT_QUICK = 0xe6,
258 OP_IPUT_WIDE_QUICK = 0xe7,
259 OP_IPUT_OBJECT_QUICK = 0xe8,
260 OP_INVOKE_VIRTUAL_QUICK = 0xe9,
261 OP_INVOKE_VIRTUAL_RANGE_QUICK = 0xea,
262 OP_IPUT_BOOLEAN_QUICK = 0xeb,
263 OP_IPUT_BYTE_QUICK = 0xec,
264 OP_IPUT_CHAR_QUICK = 0xed,
265 OP_IPUT_SHORT_QUICK = 0xee,
266 OP_IGET_BOOLEAN_QUICK = 0xef,
267 OP_IGET_BYTE_QUICK = 0xf0,
268 OP_IGET_CHAR_QUICK = 0xf1,
269 OP_IGET_SHORT_QUICK = 0xf2,
270
271 // From DEX 38
272 OP_INVOKE_POLYMORPHIC = 0xfa,
273 OP_INVOKE_POLYMORPHIC_RANGE = 0xfb,
274 OP_INVOKE_CUSTOM = 0xfc,
275 OP_INVOKE_CUSTOM_RANGE = 0xfd,
276
277 // From DEX 39
278 OP_CONST_METHOD_HANDLE = 0xfe,
279 OP_CONST_METHOD_TYPE = 0xff,
280};
281
282enum INST_FORMATS : uint8_t {
283 F_00x = 0,
284 F_10x,
285 F_12x,
286 F_11n,
287 F_11x,
288 F_10t,
289 F_20t,
290 F_20bc,
291 F_22x,
292 F_21t,
293 F_21s,
294 F_21h,
295 F_21c,
296 F_23x,
297 F_22b,
298 F_22t,
299 F_22s,
300 F_22c,
301 F_22cs,
302 F_30t,
303 F_32x,
304 F_31i,
305 F_31t,
306 F_31c,
307 F_35c,
308 F_35ms,
309 F_35mi,
310 F_3rc,
311 F_3rms,
312 F_3rmi,
313 F_51l,
314
315 // Since DEX 38
316 F_45cc,
317 F_4rcc,
318};
319
321 uint16_t ident; // 0x0100
322 uint16_t size;
323 uint32_t first_key;
324 // uint32_t targets[size]
325};
326
327
329 uint16_t ident; // 0x0200
330 uint16_t size;
331 // uint32_t targets[size]
332};
333
335 uint16_t ident;
336 uint16_t element_width;
337 uint32_t size;
338 //uint8_t data[size];
339};
340
341
343LIEF_API INST_FORMATS inst_format_from_opcode(OPCODES op);
344
345LIEF_API size_t inst_size_from_format(INST_FORMATS fmt);
346LIEF_API size_t inst_size_from_opcode(OPCODES op);
347
348LIEF_API bool is_switch_array(const uint8_t* ptr, const uint8_t* end);
349
350LIEF_API size_t switch_array_size(const uint8_t* ptr, const uint8_t* end);
351
352} // Namespace LIEF
353} // Namespace DEX
354
355#endif
356
LIEF namespace.
Definition Abstract/Binary.hpp:32
Definition instructions.hpp:334
Definition instructions.hpp:320
Definition instructions.hpp:328