00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00019 #ifndef __DXCUT_DALVIK_H
00020 #define __DXCUT_DALVIK_H
00021 #include <dxcut/dex.h>
00022 #ifdef __cplusplus
00023 extern "C" {
00024 #endif
00025
00032 typedef enum DexOpCode {
00033 OP_PSUEDO = 0x00,
00034 OP_NOP = 0x00,
00035 OP_MOVE = 0x01,
00036 OP_MOVE_FROM16 = 0x02,
00037 OP_MOVE_16 = 0x03,
00038 OP_MOVE_WIDE = 0x04,
00039 OP_MOVE_WIDE_FROM16 = 0x05,
00040 OP_MOVE_WIDE_16 = 0x06,
00041 OP_MOVE_OBJECT = 0x07,
00042 OP_MOVE_OBJECT_FROM16 = 0x08,
00043 OP_MOVE_OBJECT_16 = 0x09,
00044 OP_MOVE_RESULT = 0x0a,
00045 OP_MOVE_RESULT_WIDE = 0x0b,
00046 OP_MOVE_RESULT_OBJECT = 0x0c,
00047 OP_MOVE_EXCEPTION = 0x0d,
00048 OP_RETURN_VOID = 0x0e,
00049 OP_RETURN = 0x0f,
00050 OP_RETURN_WIDE = 0x10,
00051 OP_RETURN_OBJECT = 0x11,
00052 OP_CONST_4 = 0x12,
00053 OP_CONST_16 = 0x13,
00054 OP_CONST = 0x14,
00055 OP_CONST_HIGH16 = 0x15,
00056 OP_CONST_WIDE_16 = 0x16,
00057 OP_CONST_WIDE_32 = 0x17,
00058 OP_CONST_WIDE = 0x18,
00059 OP_CONST_WIDE_HIGH16 = 0x19,
00060 OP_CONST_STRING = 0x1a,
00061 OP_CONST_STRING_JUMBO = 0x1b,
00062 OP_CONST_CLASS = 0x1c,
00063 OP_MONITOR_ENTER = 0x1d,
00064 OP_MONITOR_EXIT = 0x1e,
00065 OP_CHECK_CAST = 0x1f,
00066 OP_INSTANCE_OF = 0x20,
00067 OP_ARRAY_LENGTH = 0x21,
00068 OP_NEW_INSTANCE = 0x22,
00069 OP_NEW_ARRAY = 0x23,
00070 OP_FILLED_NEW_ARRAY = 0x24,
00071 OP_FILLED_NEW_ARRAY_RANGE = 0x25,
00072 OP_FILL_ARRAY_DATA = 0x26,
00073 OP_THROW = 0x27,
00074 OP_GOTO = 0x28,
00075 OP_GOTO_16 = 0x29,
00076 OP_GOTO_32 = 0x2a,
00077 OP_PACKED_SWITCH = 0x2b,
00078 OP_SPARSE_SWITCH = 0x2c,
00079 OP_CMPL_FLOAT = 0x2d,
00080 OP_CMPG_FLOAT = 0x2e,
00081 OP_CMPL_DOUBLE = 0x2f,
00082 OP_CMPG_DOUBLE = 0x30,
00083 OP_CMP_LONG = 0x31,
00084 OP_IF_EQ = 0x32,
00085 OP_IF_NE = 0x33,
00086 OP_IF_LT = 0x34,
00087 OP_IF_GE = 0x35,
00088 OP_IF_GT = 0x36,
00089 OP_IF_LE = 0x37,
00090 OP_IF_EQZ = 0x38,
00091 OP_IF_NEZ = 0x39,
00092 OP_IF_LTZ = 0x3a,
00093 OP_IF_GEZ = 0x3b,
00094 OP_IF_GTZ = 0x3c,
00095 OP_IF_LEZ = 0x3d,
00096 OP_UNUSED_3E = 0x3e,
00097 OP_UNUSED_3F = 0x3f,
00098 OP_UNUSED_40 = 0x40,
00099 OP_UNUSED_41 = 0x41,
00100 OP_UNUSED_42 = 0x42,
00101 OP_UNUSED_43 = 0x43,
00102 OP_AGET = 0x44,
00103 OP_AGET_WIDE = 0x45,
00104 OP_AGET_OBJECT = 0x46,
00105 OP_AGET_BOOLEAN = 0x47,
00106 OP_AGET_BYTE = 0x48,
00107 OP_AGET_CHAR = 0x49,
00108 OP_AGET_SHORT = 0x4a,
00109 OP_APUT = 0x4b,
00110 OP_APUT_WIDE = 0x4c,
00111 OP_APUT_OBJECT = 0x4d,
00112 OP_APUT_BOOLEAN = 0x4e,
00113 OP_APUT_BYTE = 0x4f,
00114 OP_APUT_CHAR = 0x50,
00115 OP_APUT_SHORT = 0x51,
00116 OP_IGET = 0x52,
00117 OP_IGET_WIDE = 0x53,
00118 OP_IGET_OBJECT = 0x54,
00119 OP_IGET_BOOLEAN = 0x55,
00120 OP_IGET_BYTE = 0x56,
00121 OP_IGET_CHAR = 0x57,
00122 OP_IGET_SHORT = 0x58,
00123 OP_IPUT = 0x59,
00124 OP_IPUT_WIDE = 0x5a,
00125 OP_IPUT_OBJECT = 0x5b,
00126 OP_IPUT_BOOLEAN = 0x5c,
00127 OP_IPUT_BYTE = 0x5d,
00128 OP_IPUT_CHAR = 0x5e,
00129 OP_IPUT_SHORT = 0x5f,
00130 OP_SGET = 0x60,
00131 OP_SGET_WIDE = 0x61,
00132 OP_SGET_OBJECT = 0x62,
00133 OP_SGET_BOOLEAN = 0x63,
00134 OP_SGET_BYTE = 0x64,
00135 OP_SGET_CHAR = 0x65,
00136 OP_SGET_SHORT = 0x66,
00137 OP_SPUT = 0x67,
00138 OP_SPUT_WIDE = 0x68,
00139 OP_SPUT_OBJECT = 0x69,
00140 OP_SPUT_BOOLEAN = 0x6a,
00141 OP_SPUT_BYTE = 0x6b,
00142 OP_SPUT_CHAR = 0x6c,
00143 OP_SPUT_SHORT = 0x6d,
00144 OP_INVOKE_VIRTUAL = 0x6e,
00145 OP_INVOKE_SUPER = 0x6f,
00146 OP_INVOKE_DIRECT = 0x70,
00147 OP_INVOKE_STATIC = 0x71,
00148 OP_INVOKE_INTERFACE = 0x72,
00149 OP_UNUSED_73 = 0x73,
00150 OP_INVOKE_VIRTUAL_RANGE = 0x74,
00151 OP_INVOKE_SUPER_RANGE = 0x75,
00152 OP_INVOKE_DIRECT_RANGE = 0x76,
00153 OP_INVOKE_STATIC_RANGE = 0x77,
00154 OP_INVOKE_INTERFACE_RANGE = 0x78,
00155 OP_UNUSED_79 = 0x79,
00156 OP_UNUSED_7A = 0x7a,
00157 OP_NEG_INT = 0x7b,
00158 OP_NOT_INT = 0x7c,
00159 OP_NEG_LONG = 0x7d,
00160 OP_NOT_LONG = 0x7e,
00161 OP_NEG_FLOAT = 0x7f,
00162 OP_NEG_DOUBLE = 0x80,
00163 OP_INT_TO_LONG = 0x81,
00164 OP_INT_TO_FLOAT = 0x82,
00165 OP_INT_TO_DOUBLE = 0x83,
00166 OP_LONG_TO_INT = 0x84,
00167 OP_LONG_TO_FLOAT = 0x85,
00168 OP_LONG_TO_DOUBLE = 0x86,
00169 OP_FLOAT_TO_INT = 0x87,
00170 OP_FLOAT_TO_LONG = 0x88,
00171 OP_FLOAT_TO_DOUBLE = 0x89,
00172 OP_DOUBLE_TO_INT = 0x8a,
00173 OP_DOUBLE_TO_LONG = 0x8b,
00174 OP_DOUBLE_TO_FLOAT = 0x8c,
00175 OP_INT_TO_BYTE = 0x8d,
00176 OP_INT_TO_CHAR = 0x8e,
00177 OP_INT_TO_SHORT = 0x8f,
00178 OP_ADD_INT = 0x90,
00179 OP_SUB_INT = 0x91,
00180 OP_MUL_INT = 0x92,
00181 OP_DIV_INT = 0x93,
00182 OP_REM_INT = 0x94,
00183 OP_AND_INT = 0x95,
00184 OP_OR_INT = 0x96,
00185 OP_XOR_INT = 0x97,
00186 OP_SHL_INT = 0x98,
00187 OP_SHR_INT = 0x99,
00188 OP_USHR_INT = 0x9a,
00189 OP_ADD_LONG = 0x9b,
00190 OP_SUB_LONG = 0x9c,
00191 OP_MUL_LONG = 0x9d,
00192 OP_DIV_LONG = 0x9e,
00193 OP_REM_LONG = 0x9f,
00194 OP_AND_LONG = 0xa0,
00195 OP_OR_LONG = 0xa1,
00196 OP_XOR_LONG = 0xa2,
00197 OP_SHL_LONG = 0xa3,
00198 OP_SHR_LONG = 0xa4,
00199 OP_USHR_LONG = 0xa5,
00200 OP_ADD_FLOAT = 0xa6,
00201 OP_SUB_FLOAT = 0xa7,
00202 OP_MUL_FLOAT = 0xa8,
00203 OP_DIV_FLOAT = 0xa9,
00204 OP_REM_FLOAT = 0xaa,
00205 OP_ADD_DOUBLE = 0xab,
00206 OP_SUB_DOUBLE = 0xac,
00207 OP_MUL_DOUBLE = 0xad,
00208 OP_DIV_DOUBLE = 0xae,
00209 OP_REM_DOUBLE = 0xaf,
00210 OP_ADD_INT_2ADDR = 0xb0,
00211 OP_SUB_INT_2ADDR = 0xb1,
00212 OP_MUL_INT_2ADDR = 0xb2,
00213 OP_DIV_INT_2ADDR = 0xb3,
00214 OP_REM_INT_2ADDR = 0xb4,
00215 OP_AND_INT_2ADDR = 0xb5,
00216 OP_OR_INT_2ADDR = 0xb6,
00217 OP_XOR_INT_2ADDR = 0xb7,
00218 OP_SHL_INT_2ADDR = 0xb8,
00219 OP_SHR_INT_2ADDR = 0xb9,
00220 OP_USHR_INT_2ADDR = 0xba,
00221 OP_ADD_LONG_2ADDR = 0xbb,
00222 OP_SUB_LONG_2ADDR = 0xbc,
00223 OP_MUL_LONG_2ADDR = 0xbd,
00224 OP_DIV_LONG_2ADDR = 0xbe,
00225 OP_REM_LONG_2ADDR = 0xbf,
00226 OP_AND_LONG_2ADDR = 0xc0,
00227 OP_OR_LONG_2ADDR = 0xc1,
00228 OP_XOR_LONG_2ADDR = 0xc2,
00229 OP_SHL_LONG_2ADDR = 0xc3,
00230 OP_SHR_LONG_2ADDR = 0xc4,
00231 OP_USHR_LONG_2ADDR = 0xc5,
00232 OP_ADD_FLOAT_2ADDR = 0xc6,
00233 OP_SUB_FLOAT_2ADDR = 0xc7,
00234 OP_MUL_FLOAT_2ADDR = 0xc8,
00235 OP_DIV_FLOAT_2ADDR = 0xc9,
00236 OP_REM_FLOAT_2ADDR = 0xca,
00237 OP_ADD_DOUBLE_2ADDR = 0xcb,
00238 OP_SUB_DOUBLE_2ADDR = 0xcc,
00239 OP_MUL_DOUBLE_2ADDR = 0xcd,
00240 OP_DIV_DOUBLE_2ADDR = 0xce,
00241 OP_REM_DOUBLE_2ADDR = 0xcf,
00242 OP_ADD_INT_LIT16 = 0xd0,
00243 OP_RSUB_INT = 0xd1,
00244 OP_MUL_INT_LIT16 = 0xd2,
00245 OP_DIV_INT_LIT16 = 0xd3,
00246 OP_REM_INT_LIT16 = 0xd4,
00247 OP_AND_INT_LIT16 = 0xd5,
00248 OP_OR_INT_LIT16 = 0xd6,
00249 OP_XOR_INT_LIT16 = 0xd7,
00250 OP_ADD_INT_LIT8 = 0xd8,
00251 OP_RSUB_INT_LIT8 = 0xd9,
00252 OP_MUL_INT_LIT8 = 0xda,
00253 OP_DIV_INT_LIT8 = 0xdb,
00254 OP_REM_INT_LIT8 = 0xdc,
00255 OP_AND_INT_LIT8 = 0xdd,
00256 OP_OR_INT_LIT8 = 0xde,
00257 OP_XOR_INT_LIT8 = 0xdf,
00258 OP_SHL_INT_LIT8 = 0xe0,
00259 OP_SHR_INT_LIT8 = 0xe1,
00260 OP_USHR_INT_LIT8 = 0xe2,
00261 OP_UNUSED_E3 = 0xe3,
00262 OP_UNUSED_E4 = 0xe4,
00263 OP_UNUSED_E5 = 0xe5,
00264 OP_UNUSED_E6 = 0xe6,
00265 OP_UNUSED_E7 = 0xe7,
00266 OP_UNUSED_E8 = 0xe8,
00267 OP_UNUSED_E9 = 0xe9,
00268 OP_UNUSED_EA = 0xea,
00269 OP_UNUSED_EB = 0xeb,
00270 OP_BREAKPOINT = 0xec,
00271 OP_THROW_VERIFICATION_ERROR = 0xed,
00272 OP_EXECUTE_INLINE = 0xee,
00273 OP_EXECUTE_INLINE_RANGE = 0xef,
00274 OP_INVOKE_DIRECT_EMPTY = 0xf0,
00275 OP_UNUSED_F1 = 0xf1,
00276 OP_IGET_QUICK = 0xf2,
00277 OP_IGET_WIDE_QUICK = 0xf3,
00278 OP_IGET_OBJECT_QUICK = 0xf4,
00279 OP_IPUT_QUICK = 0xf5,
00280 OP_IPUT_WIDE_QUICK = 0xf6,
00281 OP_IPUT_OBJECT_QUICK = 0xf7,
00282 OP_INVOKE_VIRTUAL_QUICK = 0xf8,
00283 OP_INVOKE_VIRTUAL_QUICK_RANGE = 0xf9,
00284 OP_INVOKE_SUPER_QUICK = 0xfa,
00285 OP_INVOKE_SUPER_QUICK_RANGE = 0xfb,
00286 OP_UNUSED_FC = 0xfc,
00287 OP_UNUSED_FD = 0xfd,
00288 OP_UNUSED_FE = 0xfe,
00289 OP_UNUSED_FF = 0xff,
00290 } DexOpCode;
00291
00298 typedef enum DexPsuedoOpCode {
00299 PSUEDO_OP_NOP = 0x00,
00300 PSUEDO_OP_PACKED_SWITCH = 0x01,
00301 PSUEDO_OP_SPARSE_SWITCH = 0x02,
00302 PSUEDO_OP_FILL_DATA_ARRAY = 0x03
00303 } DexPsuedoOpCode;
00304
00314 typedef enum DexOpSpecialType {
00316 SPECIAL_NONE = 0x00,
00319 SPECIAL_CONSTANT = 0x01,
00327 SPECIAL_TARGET = 0x02,
00330 SPECIAL_STRING = 0x03,
00333 SPECIAL_TYPE = 0x04,
00336 SPECIAL_FIELD = 0x05,
00339 SPECIAL_METHOD = 0x06,
00343 SPECIAL_INLINE = 0x07,
00347 SPECIAL_OBJECT = 0x08,
00351 SPECIAL_VTABLE = 0x09
00352 } DexOpSpecialType;
00353
00354 typedef enum DexInstrFlag {
00355 DEX_INSTR_FLAG_CONTINUE = 1 << 0,
00356 DEX_INSTR_FLAG_THROW = 1 << 1,
00357 DEX_INSTR_FLAG_INVOKE = 1 << 2,
00358 DEX_INSTR_FLAG_RETURN = 1 << 3,
00359 DEX_INSTR_FLAG_SWITCH = 1 << 4,
00360 DEX_INSTR_FLAG_BRANCH = 1 << 5,
00361 DEX_INSTR_FLAG_WRITE_REG = 1 << 6,
00362 DEX_INSTR_FLAG_WIDE_R1 = 1 << 7,
00363 DEX_INSTR_FLAG_WIDE_R2 = 1 << 8,
00364 DEX_INSTR_FLAG_WIDE_R3 = 1 << 9,
00365 } DexInstrFlag;
00366
00367 typedef struct {
00369 const char* name;
00373 const char* format_id;
00375 int size;
00377 DexOpSpecialType specialType;
00380 int specialPos;
00383 int specialSize;
00385 int flags;
00386 } DexOpFormat;
00387
00395 extern
00396 const DexOpFormat dex_opcode_formats[256];
00397
00398 typedef struct {
00400 dx_ubyte opcode;
00402 dx_ubyte hi_byte;
00406 dx_ushort param[2];
00408 union {
00409 dx_long constant;
00410 dx_int target;
00411 ref_str* str;
00412 ref_str* type;
00413 struct {
00414 ref_str* defining_class;
00415 ref_str* name;
00416 ref_str* type;
00417 } field;
00418 struct {
00419 ref_str* defining_class;
00420 ref_str* name;
00421 ref_strstr* prototype;
00422 } method;
00423 dx_uint inline_ind;
00424 dx_uint object_off;
00425 dx_uint vtable_ind;
00428 struct {
00430 dx_ushort size;
00432 dx_int first_key;
00434 dx_int* targets;
00435 } packed_switch;
00438 struct {
00440 dx_ushort size;
00442 dx_int* keys;
00444 dx_int* targets;
00445 } sparse_switch;
00448 struct {
00450 dx_ushort element_width;
00452 dx_uint size;
00455 dx_ubyte* data;
00456 } fill_data_array;
00457 } special;
00458 } DexInstruction;
00459
00463 dx_uint dxc_insn_width(const DexInstruction* insn);
00464
00468 dx_ubyte dxc_num_registers(const DexInstruction* insn);
00469
00475 dx_int dxc_set_num_registers(DexInstruction* insn, dx_ubyte regs);
00476
00481 dx_int dxc_register_width(const DexInstruction* insn, dx_uint index);
00482
00487 dx_int dxc_get_register(const DexInstruction* insn, dx_uint index);
00488
00496 dx_int dxc_set_register(DexInstruction* insn, dx_uint index, dx_ushort reg);
00497
00502 extern
00503 void dxc_free_instruction(DexInstruction* insn);
00504
00505
00506 #ifdef __cplusplus
00507 }
00508 #endif
00509 #endif // __DXCUT_DALVIK_H