2011-02-02 13:02:20 +01:00
|
|
|
/* radare - LGPL - Copyright 2009-2011 nibble<.ds@gmail.com> */
|
2009-02-05 22:08:46 +01:00
|
|
|
|
|
|
|
#ifndef _INCLUDE_R_ASM_H_
|
|
|
|
#define _INCLUDE_R_ASM_H_
|
|
|
|
|
2009-02-18 01:49:26 +01:00
|
|
|
#include <r_types.h>
|
2011-06-26 20:29:24 +02:00
|
|
|
#include <r_bin.h> // only for binding, no hard dep required
|
2009-02-18 01:49:26 +01:00
|
|
|
#include <list.h>
|
2010-02-12 13:45:03 +01:00
|
|
|
#include <r_util.h>
|
2009-02-05 22:08:46 +01:00
|
|
|
|
2011-01-31 00:26:07 +01:00
|
|
|
#define R_ASM_BUFSIZE 1024
|
2009-08-14 00:37:18 +00:00
|
|
|
|
2011-05-06 00:59:10 +02:00
|
|
|
/* backward compatibility */
|
|
|
|
#define R_ASM_ARCH_NONE R_SYS_ARCH_NONE
|
|
|
|
#define R_ASM_ARCH_X86 R_SYS_ARCH_X86
|
|
|
|
#define R_ASM_ARCH_ARM R_SYS_ARCH_ARM
|
|
|
|
#define R_ASM_ARCH_PPC R_SYS_ARCH_PPC
|
|
|
|
#define R_ASM_ARCH_M68K R_SYS_ARCH_M68K
|
|
|
|
#define R_ASM_ARCH_JAVA R_SYS_ARCH_JAVA
|
|
|
|
#define R_ASM_ARCH_MIPS R_SYS_ARCH_MIPS
|
|
|
|
#define R_ASM_ARCH_SPARC R_SYS_ARCH_SPARC
|
|
|
|
#define R_ASM_ARCH_CSR R_SYS_ARCH_CSR
|
|
|
|
#define R_ASM_ARCH_MSIL R_SYS_ARCH_MSIL
|
|
|
|
#define R_ASM_ARCH_OBJD R_SYS_ARCH_OBJD
|
|
|
|
#define R_ASM_ARCH_BF R_SYS_ARCH_BF
|
|
|
|
#define R_ASM_ARCH_SH R_SYS_ARCH_SH
|
2009-02-18 01:49:26 +01:00
|
|
|
|
2011-06-29 00:36:52 +02:00
|
|
|
#define R_ASM_GET_OFFSET(x,y,z) \
|
|
|
|
(x && x->binb.bin && x->binb.get_offset)? \
|
|
|
|
x->binb.get_offset (x->binb.bin, y, z): -1
|
|
|
|
|
2009-02-05 22:08:46 +01:00
|
|
|
enum {
|
2010-01-25 11:54:25 +01:00
|
|
|
R_ASM_SYNTAX_NONE = 0,
|
|
|
|
R_ASM_SYNTAX_INTEL,
|
|
|
|
R_ASM_SYNTAX_ATT
|
2009-02-05 22:08:46 +01:00
|
|
|
};
|
|
|
|
|
2010-04-09 00:52:38 +02:00
|
|
|
enum {
|
|
|
|
R_ASM_MOD_RAWVALUE = 'r',
|
|
|
|
R_ASM_MOD_VALUE = 'v',
|
|
|
|
R_ASM_MOD_DSTREG = 'd',
|
|
|
|
R_ASM_MOD_SRCREG0 = '0',
|
2010-10-28 00:55:07 +02:00
|
|
|
R_ASM_MOD_SRCREG1 = '1',
|
|
|
|
R_ASM_MOD_SRCREG2 = '2'
|
2010-04-09 00:52:38 +02:00
|
|
|
};
|
|
|
|
|
2011-02-24 16:50:29 +01:00
|
|
|
typedef struct r_asm_op_t {
|
2009-02-18 01:49:26 +01:00
|
|
|
int inst_len;
|
2011-02-17 22:03:30 +01:00
|
|
|
// But this is pretty slow..so maybe we should add some accessors
|
2010-01-08 18:25:25 +01:00
|
|
|
ut8 buf[R_ASM_BUFSIZE];
|
2009-04-16 19:20:03 +02:00
|
|
|
char buf_asm[R_ASM_BUFSIZE];
|
|
|
|
char buf_hex[R_ASM_BUFSIZE];
|
|
|
|
char buf_err[R_ASM_BUFSIZE];
|
2011-02-24 16:50:29 +01:00
|
|
|
} RAsmOp;
|
2009-02-05 22:08:46 +01:00
|
|
|
|
2010-01-08 18:25:25 +01:00
|
|
|
typedef struct r_asm_code_t {
|
|
|
|
int len;
|
|
|
|
ut8 *buf;
|
|
|
|
char *buf_hex;
|
|
|
|
char *buf_asm;
|
2010-02-12 13:45:03 +01:00
|
|
|
RList *equs; // TODO: must be a hash
|
2010-01-26 01:28:33 +01:00
|
|
|
} RAsmCode;
|
2010-01-08 18:25:25 +01:00
|
|
|
|
2010-02-12 13:45:03 +01:00
|
|
|
// TODO: Must use Hashtable instead of this hack
|
|
|
|
typedef struct {
|
|
|
|
char *key;
|
|
|
|
char *value;
|
|
|
|
} RAsmEqu;
|
|
|
|
|
2009-12-24 03:17:53 +01:00
|
|
|
typedef struct r_asm_t {
|
2009-02-05 22:08:46 +01:00
|
|
|
int bits;
|
|
|
|
int big_endian;
|
|
|
|
int syntax;
|
2010-01-08 18:25:25 +01:00
|
|
|
ut64 pc;
|
2009-02-18 01:49:26 +01:00
|
|
|
void *user;
|
2010-05-26 01:42:22 +02:00
|
|
|
struct r_asm_plugin_t *cur;
|
2010-05-26 02:55:50 +02:00
|
|
|
RList *plugins;
|
2011-06-26 20:29:24 +02:00
|
|
|
RBinBind binb;
|
2010-01-26 01:28:33 +01:00
|
|
|
} RAsm;
|
2009-02-18 01:49:26 +01:00
|
|
|
|
2010-04-09 00:52:38 +02:00
|
|
|
typedef int (*RAsmModifyCallback)(RAsm *a, ut8 *buf, int field, ut64 val);
|
|
|
|
|
2010-05-26 01:42:22 +02:00
|
|
|
typedef struct r_asm_plugin_t {
|
2009-02-18 01:49:26 +01:00
|
|
|
char *name;
|
2009-04-11 21:22:20 +00:00
|
|
|
char *arch;
|
2009-02-18 01:49:26 +01:00
|
|
|
char *desc;
|
2010-01-21 02:38:52 +01:00
|
|
|
// TODO: bits -> renamed to bitmask
|
|
|
|
// use each bit to identify 4,8,16,32,64 bitsize it can be a mask, no need for pointers here
|
2009-04-11 21:22:20 +00:00
|
|
|
int *bits;
|
2009-02-18 01:49:26 +01:00
|
|
|
int (*init)(void *user);
|
|
|
|
int (*fini)(void *user);
|
2011-06-04 03:14:04 +02:00
|
|
|
int (*disassemble)(RAsm *a, struct r_asm_op_t *op, const ut8 *buf, ut64 len);
|
2011-02-24 16:50:29 +01:00
|
|
|
int (*assemble)(RAsm *a, struct r_asm_op_t *op, const char *buf);
|
2010-04-09 00:52:38 +02:00
|
|
|
RAsmModifyCallback modify;
|
|
|
|
int (*set_subarch)(RAsm *a, const char *buf);
|
2010-05-26 01:42:22 +02:00
|
|
|
} RAsmPlugin;
|
2009-02-05 22:08:46 +01:00
|
|
|
|
2009-12-24 03:17:53 +01:00
|
|
|
#ifdef R_API
|
2009-02-05 22:08:46 +01:00
|
|
|
/* asm.c */
|
2010-04-09 00:52:38 +02:00
|
|
|
R_API RAsm *r_asm_new();
|
2011-02-27 21:56:13 +01:00
|
|
|
#define r_asm_op_free free
|
2010-04-09 00:52:38 +02:00
|
|
|
R_API void r_asm_free(RAsm *a);
|
|
|
|
R_API int r_asm_modify(RAsm *a, ut8 *buf, int field, ut64 val);
|
|
|
|
R_API void r_asm_set_user_ptr(RAsm *a, void *user);
|
2010-05-26 01:42:22 +02:00
|
|
|
R_API int r_asm_add(RAsm *a, RAsmPlugin *foo);
|
2010-04-09 00:52:38 +02:00
|
|
|
R_API int r_asm_use(RAsm *a, const char *name);
|
|
|
|
R_API int r_asm_set_bits(RAsm *a, int bits);
|
|
|
|
R_API int r_asm_set_big_endian(RAsm *a, int boolean);
|
|
|
|
R_API int r_asm_set_syntax(RAsm *a, int syntax);
|
|
|
|
R_API int r_asm_set_pc(RAsm *a, ut64 pc);
|
2011-06-04 03:14:04 +02:00
|
|
|
R_API int r_asm_disassemble(RAsm *a, struct r_asm_op_t *op, const ut8 *buf, ut64 len);
|
2011-02-24 16:50:29 +01:00
|
|
|
R_API int r_asm_assemble(RAsm *a, struct r_asm_op_t *op, const char *buf);
|
2010-04-09 00:52:38 +02:00
|
|
|
R_API struct r_asm_code_t* r_asm_mdisassemble(RAsm *a, ut8 *buf, ut64 len);
|
2010-05-30 13:00:21 +02:00
|
|
|
R_API RAsmCode* r_asm_mdisassemble_hexstr(RAsm *a, const char *hexstr);
|
2010-04-09 00:52:38 +02:00
|
|
|
R_API struct r_asm_code_t* r_asm_massemble(RAsm *a, const char *buf);
|
2011-07-07 00:53:08 +02:00
|
|
|
R_API struct r_asm_code_t* r_asm_assemble_file(RAsm *a, const char *file);
|
2009-03-08 23:49:15 +00:00
|
|
|
|
2010-02-12 18:40:05 +01:00
|
|
|
/* code.c */
|
|
|
|
R_API RAsmCode *r_asm_code_new();
|
|
|
|
R_API void* r_asm_code_free(struct r_asm_code_t *acode);
|
|
|
|
R_API int r_asm_code_set_equ (RAsmCode *code, const char *key, const char *value);
|
|
|
|
R_API char *r_asm_code_equ_replace (RAsmCode *code, char *str);
|
|
|
|
|
2011-02-17 22:03:30 +01:00
|
|
|
// accessors, to make bindings happy
|
2011-02-24 16:50:29 +01:00
|
|
|
R_API char *r_asm_op_get_hex(RAsmOp *op);
|
|
|
|
R_API char *r_asm_op_get_asm(RAsmOp *op);
|
2011-02-17 22:03:30 +01:00
|
|
|
|
2009-03-08 23:49:15 +00:00
|
|
|
/* plugin pointers */
|
2010-05-26 01:42:22 +02:00
|
|
|
extern RAsmPlugin r_asm_plugin_bf;
|
|
|
|
extern RAsmPlugin r_asm_plugin_java;
|
|
|
|
extern RAsmPlugin r_asm_plugin_mips;
|
|
|
|
extern RAsmPlugin r_asm_plugin_x86;
|
|
|
|
extern RAsmPlugin r_asm_plugin_x86_olly;
|
|
|
|
extern RAsmPlugin r_asm_plugin_x86_nasm;
|
|
|
|
extern RAsmPlugin r_asm_plugin_arm;
|
2010-10-06 00:35:33 +02:00
|
|
|
extern RAsmPlugin r_asm_plugin_armthumb;
|
2010-05-26 01:42:22 +02:00
|
|
|
extern RAsmPlugin r_asm_plugin_csr;
|
|
|
|
extern RAsmPlugin r_asm_plugin_m68k;
|
|
|
|
extern RAsmPlugin r_asm_plugin_ppc;
|
|
|
|
extern RAsmPlugin r_asm_plugin_sparc;
|
|
|
|
extern RAsmPlugin r_asm_plugin_psosvm;
|
|
|
|
extern RAsmPlugin r_asm_plugin_avr;
|
2011-01-19 00:39:28 +01:00
|
|
|
extern RAsmPlugin r_asm_plugin_dalvik;
|
2011-02-23 13:00:24 +01:00
|
|
|
extern RAsmPlugin r_asm_plugin_msil;
|
2011-03-29 14:55:41 +02:00
|
|
|
extern RAsmPlugin r_asm_plugin_sh;
|
2010-01-12 02:12:18 +01:00
|
|
|
#endif
|
2009-03-10 01:49:24 +00:00
|
|
|
|
2009-02-05 22:08:46 +01:00
|
|
|
#endif
|