#ifndef _INCLUDE_LIBR_BP_H_ #define _INCLUDE_LIBR_BP_H_ #include #include #include #define R_BP_MAXPIDS 10 #define R_BP_CONT_NORMAL 0 #define R_BP_CONT_NORMAL 0 typedef struct r_bp_arch_t { int length; int endian; const ut8 *bytes; } RBreakpointArch; enum { R_BP_TYPE_SW, R_BP_TYPE_HW, R_BP_TYPE_COND, R_BP_TYPE_FAULT, R_BP_TYPE_DELETE, }; typedef struct r_bp_plugin_t { char *name; char *arch; int type; // R_BP_TYPE_SW int nbps; struct r_bp_arch_t *bps; } RBreakpointPlugin; // XXX: type is add() or del() typedef int (*RBreakpointCallback)(void *user, int type, ut64 addr, int hw, int rwx); typedef struct r_bp_item_t { ut64 addr; int size; /* size of breakpoint area */ int recoil; /* recoil */ int rwx; int hw; int trace; int enabled; int hits; ut8 *obytes; /* original bytes */ ut8 *bbytes; /* breakpoint bytes */ int pids[R_BP_MAXPIDS]; char *data; RBreakpointCallback callback; // per-bp callback } RBreakpointItem; typedef struct r_bp_t { int trace_all; ut64 trace_bp; int nbps; int stepcont; int endian; RIOBind iob; // compile time dependency RBreakpointPlugin *cur; RList *bps; RList *traces; RList *plugins; PrintfCallback printf; RBreakpointCallback breakpoint; void *user; } RBreakpoint; enum { R_BP_PROT_READ = 1, R_BP_PROT_WRITE = 2, R_BP_PROT_EXEC = 4, }; typedef struct r_bp_trace_t { ut64 addr; ut64 addr_end; ut8 *traps; ut8 *buffer; ut8 *bits; int length; int bitlen; } RBreakpointTrace; #ifdef R_API R_API RBreakpoint *r_bp_new(); R_API RBreakpoint *r_bp_free(RBreakpoint *bp); R_API int r_bp_del(RBreakpoint *bp, ut64 addr); R_API int r_bp_plugin_add(RBreakpoint *bp, struct r_bp_plugin_t *foo); R_API int r_bp_use(RBreakpoint *bp, const char *name); R_API int r_bp_plugin_del(RBreakpoint *bp, const char *name); R_API void r_bp_plugin_list(RBreakpoint *bp); R_API int r_bp_in(RBreakpoint *bp, ut64 addr, int rwx); // deprecate? R_API int r_bp_list(RBreakpoint *bp, int rad); R_API int r_bp_get_bytes(RBreakpoint *bp, ut8 *buf, int len, int endian, int idx); R_API int r_bp_set_trace(RBreakpoint *bp, ut64 addr, int set); //R_API int r_bp_set_trace_bp(RBreakpoint *bp, ut64 addr, int set); R_API RBreakpointItem *r_bp_enable(RBreakpoint *bp, ut64 addr, int set); R_API RBreakpointItem *r_bp_get(RBreakpoint *bp, ut64 addr); R_API int r_bp_add_cond(RBreakpoint *bp, const char *cond); R_API int r_bp_del_cond(RBreakpoint *bp, int idx); R_API int r_bp_add_fault(RBreakpoint *bp, ut64 addr, int size, int rwx); R_API RBreakpointItem *r_bp_add_sw(RBreakpoint *bp, ut64 addr, int size, int rwx); R_API RBreakpointItem *r_bp_add_hw(RBreakpoint *bp, ut64 addr, int size, int rwx); R_API RBreakpointItem *r_bp_at_addr(RBreakpoint *bp, ut64 addr, int rwx); R_API int r_bp_restore(RBreakpoint *bp, int set); R_API int r_bp_recoil(RBreakpoint *bp, ut64 addr); /* traptrace */ R_API void r_bp_traptrace_free(void *ptr); R_API void r_bp_traptrace_enable(RBreakpoint *bp, int enable); R_API void r_bp_traptrace_reset(RBreakpoint *bp, int hard); R_API ut64 r_bp_traptrace_next(RBreakpoint *bp, ut64 addr); R_API int r_bp_traptrace_add(RBreakpoint *bp, ut64 from, ut64 to); R_API int r_bp_traptrace_free_at(RBreakpoint *bp, ut64 from); R_API void r_bp_traptrace_list(RBreakpoint *bp); R_API int r_bp_traptrace_at(RBreakpoint *bp, ut64 from, int len); R_API RList *r_bp_traptrace_new(); R_API void r_bp_traptrace_enable(RBreakpoint *bp, int enable); /* plugin pointers */ extern struct r_bp_plugin_t r_bp_plugin_x86; extern struct r_bp_plugin_t r_bp_plugin_arm; extern struct r_bp_plugin_t r_bp_plugin_mips; extern struct r_bp_plugin_t r_bp_plugin_ppc; extern struct r_bp_plugin_t r_bp_plugin_sh; #endif #if 0 extern struct r_bp_plugin_t r_bp_plugin_sparc; #endif #endif