9 #include "../../asm/arch/pyc/pyc_dis.h"
12 if (!strcmp(analysis->
cpu,
"x86")) {
18 return (analysis->
bits == 16) ? 1 : 2;
20 return (analysis->
bits == 16) ? 3 : 2;
41 bool is_pyc = (plugin && strcmp(plugin->
name,
"pyc") == 0);
53 rz_list_foreach (cobjs,
iter, t) {
64 ut32 extended_arg = 0, oparg = 0;
82 bool is_python36 =
a->bits == 8;
90 op->size = is_python36 ? 2 : ((
op_code >=
ops->have_argument) ? 3 : 1);
94 oparg = data[1] + data[2] * 256 + extended_arg;
96 oparg = data[1] + extended_arg;
102 op->jump = func_base + oparg;
106 op->fail =
addr + ((is_python36) ? 2 : 3);
112 op->jump =
addr + oparg + ((is_python36) ? 2 : 3);
113 op->fail =
addr + ((is_python36) ? 2 : 3);
141 .desc =
"Python bytecode analysis plugin",
152 #ifndef RZ_PLUGIN_INCORE
static char * get_reg_profile(RzAnalysis *analysis)
static int pyc_op(RzAnalysis *a, RzAnalysisOp *op, ut64 addr, const ut8 *data, int len, RzAnalysisOpMask mask)
RzAnalysisPlugin rz_analysis_plugin_pyc
RZ_API RzLibStruct rizin_plugin
static RzList * get_pyc_code_obj(RzAnalysis *analysis)
static bool finish(void *user)
static int archinfo(RzAnalysis *analysis, int query)
RZ_API RZ_BORROW void * rz_list_get_n(RZ_NONNULL const RzList *list, ut32 n)
Returns the N-th element of the list.
return strdup("=SP r13\n" "=LR r14\n" "=PC r15\n" "=A0 r0\n" "=A1 r1\n" "=A2 r2\n" "=A3 r3\n" "=ZF zf\n" "=SF nf\n" "=OF vf\n" "=CF cf\n" "=SN or0\n" "gpr lr .32 56 0\n" "gpr pc .32 60 0\n" "gpr cpsr .32 64 0 ____tfiae_________________qvczn\n" "gpr or0 .32 68 0\n" "gpr tf .1 64.5 0 thumb\n" "gpr ef .1 64.9 0 endian\n" "gpr jf .1 64.24 0 java\n" "gpr qf .1 64.27 0 sticky_overflow\n" "gpr vf .1 64.28 0 overflow\n" "gpr cf .1 64.29 0 carry\n" "gpr zf .1 64.30 0 zero\n" "gpr nf .1 64.31 0 negative\n" "gpr itc .4 64.10 0 if_then_count\n" "gpr gef .4 64.16 0 great_or_equal\n" "gpr r0 .32 0 0\n" "gpr r1 .32 4 0\n" "gpr r2 .32 8 0\n" "gpr r3 .32 12 0\n" "gpr r4 .32 16 0\n" "gpr r5 .32 20 0\n" "gpr r6 .32 24 0\n" "gpr r7 .32 28 0\n" "gpr r8 .32 32 0\n" "gpr r9 .32 36 0\n" "gpr r10 .32 40 0\n" "gpr r11 .32 44 0\n" "gpr r12 .32 48 0\n" "gpr r13 .32 52 0\n" "gpr r14 .32 56 0\n" "gpr r15 .32 60 0\n" "gpr r16 .32 64 0\n" "gpr r17 .32 68 0\n")
void free_opcode(pyc_opcodes *opcodes)
pyc_opcodes * get_opcode_by_version(char *version)
bool pyc_opcodes_equal(pyc_opcodes *op, const char *version)
void analysis_pyc_op(RzAnalysisOp *op, pyc_opcode_object *op_obj, ut32 oparg)
#define RZ_ANALYSIS_ARCHINFO_MAX_OP_SIZE
#define RZ_ANALYSIS_ARCHINFO_MIN_OP_SIZE
@ RZ_ANALYSIS_OP_TYPE_CMP
@ RZ_ANALYSIS_OP_TYPE_JMP
@ RZ_ANALYSIS_OP_TYPE_CJMP
@ RZ_ANALYSIS_OP_TYPE_ILL
#define RZ_BETWEEN(x, y, z)
ut64(WINAPI *w32_GetEnabledXStateFeatures)()