35 ht_pp_free(trace->
ht);
78 if (
val->memref > 32) {
79 eprintf(
"Error: adding changes to %d bytes in memory.\n",
val->memref);
125 RZ_LOG_ERROR(
"invalid register, unable to trace register state\n");
143 for (
i = 0;
i <
val->memref;
i++) {
184 eprintf(
"Run aeim to get dbg->analysis->esil initialized\n");
206 static int cmpaddr(
const void *_a,
const void *_b) {
288 t->
ht = ht_pp_new0();
RZ_API void rz_analysis_trace_bb(RzAnalysis *analysis, ut64 addr)
static RzILOpEffect * mul(cs_insn *insn, bool is_thumb)
RzBinInfo * info(RzBinFile *bf)
RZ_API ut64 rz_debug_reg_get(RzDebug *dbg, const char *name)
RZ_API int rz_debug_reg_sync(RzDebug *dbg, int type, int write)
RZ_API bool rz_debug_session_add_reg_change(RzDebugSession *session, int arena, ut64 offset, ut64 data)
RZ_API bool rz_debug_session_add_mem_change(RzDebugSession *session, ut64 addr, ut8 data)
RZ_API void rz_analysis_esil_trace_op(RzAnalysisEsil *esil, RZ_NONNULL RzAnalysisOp *op)
RZ_API char * sdb_fmt(const char *fmt,...)
RZ_API void Ht_() free(HtName_(Ht) *ht)
RZ_API void rz_list_delete(RZ_NONNULL RzList *list, RZ_NONNULL RzListIter *iter)
Removes an entry in the list by using the RzListIter pointer.
RZ_API RZ_OWN RzList * rz_list_new(void)
Returns a new initialized RzList pointer (free method is not initialized)
RZ_API void rz_list_sort(RZ_NONNULL RzList *list, RZ_NONNULL RzListComparator cmp)
Sorts via merge sort or via insertion sort a list.
RZ_API RZ_BORROW RzListIter * rz_list_append(RZ_NONNULL RzList *list, void *data)
Appends at the end of the list a new element.
RZ_API void rz_list_free(RZ_NONNULL RzList *list)
Empties the list and frees the list pointer.
RZ_API void rz_list_purge(RZ_NONNULL RzList *list)
Empties the list without freeing the list pointer.
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")
RZ_API void rz_analysis_op_free(void *op)
RZ_API bool rz_analysis_op_fini(RzAnalysisOp *op)
RZ_API int rz_analysis_op(RzAnalysis *analysis, RzAnalysisOp *op, ut64 addr, const ut8 *data, int len, RzAnalysisOpMask mask)
RZ_API ut64 rz_reg_get_value(RzReg *reg, RzRegItem *item)
@ RZ_ANALYSIS_OP_MASK_VAL
@ RZ_ANALYSIS_OP_MASK_ESIL
#define rz_return_val_if_fail(expr, val)
static ut64 rz_itv_begin(RzInterval itv)
struct rz_interval_t RzInterval
#define RZ_LOG_ERROR(fmtstr,...)
RZ_API char * rz_str_newf(const char *fmt,...) RZ_PRINTF_CHECK(1
RZ_API ut64 rz_time_now(void)
Returns the current time in microseconds.
struct rz_analysis_esil_t * esil
RzIOIsValidOff is_valid_offset
char * name[RZ_REG_NAME_LAST]
RZ_API void rz_debug_trace_at(RzDebug *dbg, const char *str)
RZ_API int rz_debug_trace_tag(RzDebug *dbg, int tag)
RZ_API RZ_OWN RzList * rz_debug_traces_info(RzDebug *dbg, ut64 offset)
RZ_API RzDebugTracepoint * rz_debug_trace_add(RzDebug *dbg, ut64 addr, int size)
RZ_API RzDebugTracepoint * rz_debug_trace_get(RzDebug *dbg, ut64 addr)
RZ_API void rz_debug_trace_free(RzDebugTrace *trace)
RZ_API RzDebugTrace * rz_debug_trace_new(void)
RZ_API void rz_debug_trace_op(RzDebug *dbg, RzAnalysisOp *op)
RZ_API bool rz_debug_trace_ins_after(RzDebug *dbg)
RZ_API int rz_debug_trace_pc(RzDebug *dbg, ut64 pc)
static int rz_debug_trace_is_traceable(RzDebug *dbg, ut64 addr)
RZ_API bool rz_debug_trace_ins_before(RzDebug *dbg)
static int cmpaddr(const void *_a, const void *_b)
RZ_API void rz_debug_trace_reset(RzDebug *dbg)
ut64(WINAPI *w32_GetEnabledXStateFeatures)()