radare2/libr/include/r_anal.h
Nibble 2368a1e3b6 * r_bin_elf
- Fix section va bug
* r_anal
  - Store mnemonic in RAnalOp
  - Initial work on bindiff
2010-05-23 12:51:37 +02:00

300 lines
8.6 KiB
C

/* radare - LGPL - Copyright 2009-2010 */
/* nibble<.ds@gmail.com> */
/* pancake<nopcode.org> */
#ifndef _INCLUDE_R_ANAL_H_
#define _INCLUDE_R_ANAL_H_
#include <r_types.h>
#include <list.h>
#include <r_list.h>
// deprecate this macro?
#define R_ANAL_MAXREG 16
enum {
R_ANAL_OP_FAMILY_UNKNOWN = 0,
R_ANAL_OP_FAMILY_CPU, /* normal cpu insturction */
R_ANAL_OP_FAMILY_FPU, /* fpu (floating point) */
R_ANAL_OP_FAMILY_MMX, /* multimedia instruction (packed data) */
R_ANAL_OP_FAMILY_PRIV, /* priviledged instruction */
R_ANAL_OP_FAMILY_LAST
};
enum {
R_ANAL_OP_TYPE_NULL = 0,
R_ANAL_OP_TYPE_JMP, /* mandatory jump */
R_ANAL_OP_TYPE_UJMP, /* unknown jump (register or so) */
R_ANAL_OP_TYPE_CJMP, /* conditional jump */
R_ANAL_OP_TYPE_CALL, /* call to subroutine (branch+link) */
R_ANAL_OP_TYPE_RCALL, /* call to register */
R_ANAL_OP_TYPE_REP, /* repeats next instruction N times */
R_ANAL_OP_TYPE_RET, /* returns from subrutine */
R_ANAL_OP_TYPE_ILL, /* illegal instruction // trap */
R_ANAL_OP_TYPE_UNK, /* unknown opcode type */
R_ANAL_OP_TYPE_NOP, /* does nothing */
R_ANAL_OP_TYPE_MOV, /* register move */
R_ANAL_OP_TYPE_TRAP, /* it's a trap! */
R_ANAL_OP_TYPE_SWI, /* syscall, software interrupt */
R_ANAL_OP_TYPE_UPUSH, /* unknown push of data into stack */
R_ANAL_OP_TYPE_PUSH, /* push value into stack */
R_ANAL_OP_TYPE_POP, /* pop value from stack to register */
R_ANAL_OP_TYPE_CMP, /* copmpare something */
R_ANAL_OP_TYPE_ADD,
R_ANAL_OP_TYPE_SUB,
R_ANAL_OP_TYPE_MUL,
R_ANAL_OP_TYPE_DIV,
R_ANAL_OP_TYPE_SHR,
R_ANAL_OP_TYPE_SHL,
R_ANAL_OP_TYPE_OR,
R_ANAL_OP_TYPE_AND,
R_ANAL_OP_TYPE_XOR,
R_ANAL_OP_TYPE_NOT,
R_ANAL_OP_TYPE_STORE, /* store from register to memory */
R_ANAL_OP_TYPE_LOAD, /* load from memory to register */
R_ANAL_OP_TYPE_LAST
};
/* TODO: what to do with signed/unsigned conditionals? */
enum {
R_ANAL_OP_COND_EQ = 0,
R_ANAL_OP_COND_NE,
R_ANAL_OP_COND_GE,
R_ANAL_OP_COND_GT,
R_ANAL_OP_COND_LE,
R_ANAL_OP_COND_LT,
};
enum {
R_ANAL_BB_DIFF_NULL = 0,
R_ANAL_BB_DIFF_NEW,
R_ANAL_BB_DIFF_MATCH,
R_ANAL_BB_DIFF_UNMATCH,
};
enum {
R_ANAL_VAR_TYPE_NULL = 0,
R_ANAL_VAR_TYPE_GLOBAL,
R_ANAL_VAR_TYPE_LOCAL,
R_ANAL_VAR_TYPE_ARG,
R_ANAL_VAR_TYPE_ARGREG,
};
typedef enum {
R_ANAL_DATA_NULL = 0,
R_ANAL_DATA_HEX, /* hex byte pairs */
R_ANAL_DATA_STR, /* ascii string */
R_ANAL_DATA_CODE, /* plain assembly code */
R_ANAL_DATA_FUN, /* plain assembly code */
R_ANAL_DATA_STRUCT, /* memory */
R_ANAL_DATA_LAST
} RAnalData;
typedef enum {
R_ANAL_BB_TYPE_NULL = 0,
R_ANAL_BB_TYPE_HEAD = 0x1, /* first block */
R_ANAL_BB_TYPE_BODY = 0x2, /* conditional jump */
R_ANAL_BB_TYPE_LAST = 0x4, /* ret */
R_ANAL_BB_TYPE_FOOT = 0x8 /* unknown jump */
} RAnalBlockType;
enum {
R_ANAL_STACK_NULL = 0,
R_ANAL_STACK_NOP,
R_ANAL_STACK_INCSTACK,
R_ANAL_STACK_GET,
R_ANAL_STACK_SET,
};
enum {
R_ANAL_REFLINE_STYLE = 1,
R_ANAL_REFLINE_WIDE = 2,
};
enum {
R_ANAL_RET_ERROR = -1,
R_ANAL_RET_DUP = -2,
R_ANAL_RET_NEW = -3,
R_ANAL_RET_END = -4
};
typedef struct r_anal_t {
int bits;
int big_endian;
void *user;
RList *bbs;
RList *fcns;
RList *vartypes;
struct r_anal_ctx_t *ctx;
struct r_anal_handle_t *cur;
struct list_head anals;
} RAnal;
typedef struct r_anal_aop_t {
char *mnemonic; /* mnemonic */
ut64 addr; /* address */
int type; /* type of opcode */
int stackop; /* operation on stack? */
int cond; /* condition type */
int length; /* length in bytes of opcode */
int nopcode; /* number of opcodes */
int family; /* family of opcode */
int eob; /* end of block (boolean) */
ut64 jump; /* true jmp */
ut64 fail; /* false jmp */
st64 ref; /* reference to memory */ /* XXX signed? */
ut64 value; /* reference to value */ /* XXX signed? */
st64 stackptr; /* stack pointer */
int r_dst[R_ANAL_MAXREG]; /* register arguments */
ut64 i_dst[R_ANAL_MAXREG]; /* inmediate arguments */
} RAnalOp;
typedef struct r_anal_bb_t {
ut64 addr;
ut64 size;
ut64 jump;
ut64 fail;
int type;
int diff;
int ninstr;
ut64 fingerprint;
RList *aops;
} RAnalBlock;
typedef struct r_anal_fcn_t {
char *name;
ut64 addr;
ut64 size;
int stack;
int ninstr;
ut64 fingerprint;
RList *vars;
RList *refs;
RList *xrefs;
} RAnalFcn;
typedef struct r_anal_var_t {
char *name;
int delta;
int type; /* global, local... */
char *vartype; /* float, int... */
RList *accesses; /* list of accesses for this var */
} RAnalVar;
typedef struct r_anal_var_type_t {
char *name;
char *fmt;
unsigned int size;
} RAnalVarType;
typedef struct r_anal_var_access_t {
ut64 addr;
int set;
} RAnalVarAccess;
typedef ut64 RAnalRef; // XXX
typedef struct r_anal_refline_t {
ut64 from;
ut64 to;
int index;
struct list_head list;
} RAnalRefline;
//TODO: typedef RAnalOpCallback
typedef struct r_anal_handle_t {
char *name;
char *desc;
int (*init)(void *user);
int (*fini)(void *user);
// TODO: typedef
int (*aop)(RAnal *a, struct r_anal_aop_t *aop, ut64 addr,
const ut8 *data, int len);
struct list_head list;
} RAnalHandle;
#ifdef R_API
/* anal.c */
R_API RAnal *r_anal_new();
R_API RAnal *r_anal_free(RAnal *r);
R_API void r_anal_set_user_ptr(RAnal *anal, void *user);
R_API int r_anal_add(RAnal *anal, struct r_anal_handle_t *foo);
R_API int r_anal_list(RAnal *anal);
R_API int r_anal_use(RAnal *anal, const char *name);
R_API int r_anal_set_bits(RAnal *anal, int bits);
R_API int r_anal_set_big_endian(RAnal *anal, int boolean);
R_API char *r_anal_strmask (RAnal *anal, const char *data);
/* bb.c */
R_API RAnalBlock *r_anal_bb_new();
R_API RList *r_anal_bb_list_new();
R_API void r_anal_bb_free(void *bb);
R_API int r_anal_bb(RAnal *anal, RAnalBlock *bb,
ut64 addr, ut8 *buf, ut64 len, int head);
R_API int r_anal_bb_split(RAnal *anal, RAnalBlock *bb,
RList *bbs, ut64 addr);
R_API int r_anal_bb_overlap(RAnal *anal, RAnalBlock *bb, RList *bbs);
R_API int r_anal_bb_add(RAnal *anal, ut64 addr,
ut64 size, ut64 jump, ut64 fail, int type);
R_API int r_anal_bb_del(RAnal *anal, ut64 addr);
/* aop.c */
R_API RAnalOp *r_anal_aop_new();
R_API RList *r_anal_aop_list_new();
R_API void r_anal_aop_free(void *aop);
R_API int r_anal_aop(RAnal *anal, RAnalOp *aop, ut64 addr,
const ut8 *data, int len);
/* fcn.c */
R_API RAnalFcn *r_anal_fcn_new();
R_API RList *r_anal_fcn_list_new();
R_API void r_anal_fcn_free(void *fcn);
R_API int r_anal_fcn(RAnal *anal, RAnalFcn *fcn, ut64 addr, ut8 *buf, ut64 len);
R_API int r_anal_fcn_add(RAnal *anal, ut64 addr, ut64 size, const char *name);
R_API int r_anal_fcn_del(RAnal *anal, ut64 addr);
R_API RList *r_anal_fcn_bb_list(RAnal *anal, RAnalFcn *fcn);
/* ref.c */
R_API RAnalRef *r_anal_ref_new();
R_API RList *r_anal_ref_list_new();
R_API void r_anal_ref_free(void *ref);
/* var.c */
R_API RAnalVar *r_anal_var_new();
R_API RAnalVarType *r_anal_var_type_new();
R_API RAnalVarAccess *r_anal_var_access_new();
R_API RList *r_anal_var_list_new();
R_API RList *r_anal_var_type_list_new();
R_API RList *r_anal_var_access_list_new();
R_API void r_anal_var_free(void *var);
R_API void r_anal_var_type_free(void *vartype);
R_API void r_anal_var_access_free(void *access);
R_API int r_anal_var_type_add(RAnal *anal, const char *name, int size, const char *fmt);
R_API int r_anal_var_type_del(RAnal *anal, const char *name);
R_API RAnalVarType *r_anal_var_type_get(RAnal *anal, const char *name);
R_API int r_anal_var_add(RAnal *anal, RAnalFcn *fcn, ut64 from, int delta, int type,
const char *vartype, const char *name, int set);
R_API int r_anal_var_del(RAnal *anal, RAnalFcn *fcn, int delta, int type);
R_API RAnalVar *r_anal_var_get(RAnal *anal, RAnalFcn *fcn, int delta, int type);
R_API const char *r_anal_var_type_to_str (RAnal *anal, int type);
R_API int r_anal_var_access_add(RAnal *anal, RAnalVar *var, ut64 from, int set);
R_API int r_anal_var_access_del(RAnal *anal, RAnalVar *var, ut64 from);
R_API RAnalVarAccess *r_anal_var_access_get(RAnal *anal, RAnalVar *var, ut64 from);
/* reflines.c */
R_API struct r_anal_refline_t *r_anal_reflines_get(RAnal *anal,
ut64 addr, ut8 *buf, ut64 len, int nlines, int linesout);
R_API char* r_anal_reflines_str(struct r_anal_t *anal, struct r_anal_refline_t *list,
ut64 addr, int opts);
R_API int r_anal_reflines_middle(RAnal *anal, RAnalRefline *list, ut64 addr, int len);
/* plugin pointers */
extern RAnalHandle r_anal_plugin_csr;
extern RAnalHandle r_anal_plugin_arm;
extern RAnalHandle r_anal_plugin_x86;
extern RAnalHandle r_anal_plugin_x86_x86im;
extern RAnalHandle r_anal_plugin_ppc;
#endif
#endif