2011-07-26 23:29:22 +00:00
|
|
|
#ifndef _INCLUDE_R_EGG_H_
|
|
|
|
#define _INCLUDE_R_EGG_H_
|
|
|
|
|
2011-11-13 03:08:08 +00:00
|
|
|
#include <r_db.h>
|
2011-07-26 23:29:22 +00:00
|
|
|
#include <r_asm.h>
|
2011-11-13 03:08:08 +00:00
|
|
|
#include <r_lib.h>
|
2011-07-26 23:29:22 +00:00
|
|
|
#include <r_util.h>
|
2011-08-07 22:46:04 +00:00
|
|
|
#include <r_syscall.h>
|
2011-07-26 23:29:22 +00:00
|
|
|
|
2013-06-18 10:09:23 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2013-06-14 00:51:33 +00:00
|
|
|
R_LIB_VERSION_HEADER(r_egg);
|
|
|
|
|
2011-09-19 23:53:15 +00:00
|
|
|
#define R_EGG_INCDIR_ENV "EGG_INCDIR"
|
2011-10-24 08:59:27 +00:00
|
|
|
#define R_EGG_INCDIR_PATH R2_PREFIX"/lib/radare2/"R2_VERSION"/egg"
|
2011-09-19 23:53:15 +00:00
|
|
|
|
2011-11-12 05:16:00 +00:00
|
|
|
// rename to REggShellcode
|
2011-11-14 01:04:27 +00:00
|
|
|
#define R_EGG_PLUGIN_SHELLCODE 0
|
|
|
|
#define R_EGG_PLUGIN_ENCODER 1
|
2013-01-22 04:06:12 +00:00
|
|
|
|
|
|
|
typedef struct r_egg_plugin_t {
|
2011-11-12 05:16:00 +00:00
|
|
|
const char *name;
|
|
|
|
const char *desc;
|
2011-11-14 01:04:27 +00:00
|
|
|
int type;
|
2011-11-12 05:16:00 +00:00
|
|
|
RBuffer* (*build) (void *egg);
|
|
|
|
} REggPlugin;
|
|
|
|
|
2011-07-26 23:29:22 +00:00
|
|
|
typedef struct r_egg_t {
|
|
|
|
RBuffer *src;
|
|
|
|
RBuffer *buf;
|
|
|
|
RBuffer *bin;
|
|
|
|
RList *list;
|
2011-11-13 03:08:08 +00:00
|
|
|
//RList *shellcodes; // XXX is plugins nao?
|
2011-07-26 23:29:22 +00:00
|
|
|
RAsm *rasm;
|
2011-08-07 22:46:04 +00:00
|
|
|
RSyscall *syscall;
|
2011-11-13 03:08:08 +00:00
|
|
|
RPair *pair;
|
|
|
|
RList *plugins;
|
2011-11-30 09:27:01 +00:00
|
|
|
RList *patches; // <RBuffer>
|
2011-07-26 23:29:22 +00:00
|
|
|
struct r_egg_emit_t *emit;
|
2011-11-15 13:30:52 +00:00
|
|
|
int arch;
|
2011-07-26 23:29:22 +00:00
|
|
|
int endian;
|
|
|
|
int bits;
|
2011-08-09 00:03:12 +00:00
|
|
|
ut32 os;
|
2011-07-26 23:29:22 +00:00
|
|
|
} REgg;
|
|
|
|
|
2011-09-18 16:56:11 +00:00
|
|
|
/* XXX: this may fail in different arches */
|
2013-06-07 08:26:37 +00:00
|
|
|
#if 0
|
|
|
|
r2 -q - <<EOF
|
|
|
|
?e #define R_EGG_OS_LINUX \`?h linux\`
|
|
|
|
?e #define R_EGG_OS_OSX \`?h osx\`
|
|
|
|
?e #define R_EGG_OS_DARWIN \`?h darwin\`
|
|
|
|
?e #define R_EGG_OS_MACOS \`?h macos\`
|
|
|
|
?e #define R_EGG_OS_W32 \`?h w32\`
|
|
|
|
?e #define R_EGG_OS_WINDOWS \`?h windows\`
|
|
|
|
?e #define R_EGG_OS_BEOS \`?h beos\`
|
|
|
|
EOF
|
|
|
|
#endif
|
|
|
|
#define R_EGG_OS_LINUX 0x0a52b843
|
|
|
|
#define R_EGG_OS_OSX 0x0b875ee1
|
|
|
|
#define R_EGG_OS_DARWIN 0x4292f662
|
|
|
|
#define R_EGG_OS_MACOS 0x0a66c956
|
|
|
|
#define R_EGG_OS_W32 0x0b877473
|
|
|
|
#define R_EGG_OS_WINDOWS 0x7de634da
|
|
|
|
#define R_EGG_OS_BEOS 0x7c70357e
|
2011-08-09 00:03:12 +00:00
|
|
|
|
|
|
|
#if __APPLE__
|
|
|
|
#define R_EGG_OS_DEFAULT R_EGG_OS_OSX
|
2011-09-18 16:56:11 +00:00
|
|
|
#define R_EGG_OS_NAME "darwin"
|
2011-08-09 00:03:12 +00:00
|
|
|
#define R_EGG_FORMAT_DEFAULT "mach0"
|
|
|
|
#elif __WINDOWS__
|
|
|
|
#define R_EGG_OS_DEFAULT R_EGG_OS_W32
|
2011-09-18 16:56:11 +00:00
|
|
|
#define R_EGG_OS_NAME "windows"
|
2011-08-09 00:03:12 +00:00
|
|
|
#define R_EGG_FORMAT_DEFAULT "pe"
|
|
|
|
#else
|
|
|
|
#define R_EGG_OS_DEFAULT R_EGG_OS_LINUX
|
|
|
|
#define R_EGG_OS_NAME "linux"
|
|
|
|
#define R_EGG_FORMAT_DEFAULT "elf"
|
|
|
|
#endif
|
|
|
|
|
2011-07-26 23:29:22 +00:00
|
|
|
typedef struct r_egg_emit_t {
|
|
|
|
const char *arch;
|
|
|
|
int size; /* in bytes.. 32bit arch is 4, 64bit is 8 .. */
|
2011-09-19 00:39:33 +00:00
|
|
|
const char *retvar;
|
2011-07-26 23:29:22 +00:00
|
|
|
//const char *syscall_body;
|
|
|
|
const char* (*regs)(REgg *egg, int idx);
|
2011-08-10 09:24:15 +00:00
|
|
|
void (*init)(REgg *egg);
|
2011-07-26 23:29:22 +00:00
|
|
|
void (*call)(REgg *egg, const char *addr, int ptr);
|
2011-09-19 00:39:33 +00:00
|
|
|
void (*jmp)(REgg *egg, const char *addr, int ptr);
|
2011-07-26 23:29:22 +00:00
|
|
|
//void (*sc)(int num);
|
|
|
|
void (*frame)(REgg *egg, int sz);
|
2011-08-07 22:46:04 +00:00
|
|
|
char *(*syscall)(REgg *egg, int num);
|
2011-07-26 23:29:22 +00:00
|
|
|
void (*trap)(REgg *egg);
|
|
|
|
void (*frame_end)(REgg *egg, int sz, int ctx);
|
|
|
|
void (*comment)(REgg *egg, const char *fmt, ...);
|
|
|
|
void (*push_arg)(REgg *egg, int xs, int num, const char *str);
|
|
|
|
void (*set_string)(REgg *egg, const char *dstvar, const char *str, int j);
|
|
|
|
void (*equ)(REgg *egg, const char *key, const char *value);
|
|
|
|
void (*get_result)(REgg *egg, const char *ocn);
|
|
|
|
void (*restore_stack)(REgg *egg, int size);
|
|
|
|
void (*syscall_args)(REgg *egg, int nargs);
|
|
|
|
void (*get_var)(REgg *egg, int type, char *out, int idx);
|
|
|
|
void (*while_end)(REgg *egg, const char *label);
|
|
|
|
void (*load)(REgg *egg, const char *str, int sz);
|
|
|
|
void (*load_ptr)(REgg *egg, const char *str);
|
|
|
|
void (*branch)(REgg *egg, char *b, char *g, char *e, char *n, int sz, const char *dst);
|
|
|
|
void (*mathop)(REgg *egg, int ch, int sz, int type, const char *eq, const char *p);
|
|
|
|
void (*get_while_end)(REgg *egg, char *out, const char *ctxpush, const char *label);
|
|
|
|
} REggEmit;
|
|
|
|
|
|
|
|
typedef struct r_egg_lang_t {
|
|
|
|
int nsyscalls;
|
|
|
|
int nargs;
|
|
|
|
int docall;
|
|
|
|
} REggLang;
|
|
|
|
|
|
|
|
#ifdef R_API
|
|
|
|
R_API REgg *r_egg_new ();
|
|
|
|
R_API char *r_egg_to_string (REgg *egg);
|
|
|
|
R_API void r_egg_free (REgg *egg);
|
2011-11-13 03:08:08 +00:00
|
|
|
R_API int r_egg_add (REgg *a, REggPlugin *foo);
|
2011-07-26 23:29:22 +00:00
|
|
|
R_API void r_egg_reset (REgg *egg);
|
|
|
|
R_API int r_egg_setup(REgg *egg, const char *arch, int bits, int endian, const char *os);
|
|
|
|
R_API int r_egg_include(REgg *egg, const char *file, int format);
|
2011-08-08 13:00:42 +00:00
|
|
|
R_API void r_egg_load(REgg *egg, const char *code, int format);
|
2011-07-26 23:29:22 +00:00
|
|
|
R_API void r_egg_syscall(REgg *egg, const char *arg, ...);
|
|
|
|
R_API void r_egg_alloc(REgg *egg, int n);
|
|
|
|
R_API void r_egg_label(REgg *egg, const char *name);
|
2011-11-12 05:16:00 +00:00
|
|
|
R_API int r_egg_raw(REgg *egg, const ut8 *b, int len);
|
2011-11-14 01:04:27 +00:00
|
|
|
R_API int r_egg_encode(REgg *egg, const char *name);
|
2011-11-13 03:08:08 +00:00
|
|
|
R_API int r_egg_shellcode(REgg *egg, const char *name);
|
|
|
|
#define r_egg_get_shellcodes(x) x->plugins
|
2011-11-12 05:16:00 +00:00
|
|
|
R_API void r_egg_option_set (REgg *egg, const char *k, const char *v);
|
2011-11-13 03:47:56 +00:00
|
|
|
R_API char *r_egg_option_get (REgg *egg, const char *k);
|
2011-07-26 23:29:22 +00:00
|
|
|
R_API void r_egg_if(REgg *egg, const char *reg, char cmp, int v);
|
|
|
|
R_API void r_egg_printf(REgg *egg, const char *fmt, ...);
|
|
|
|
R_API int r_egg_compile(REgg *egg);
|
2011-11-13 04:26:07 +00:00
|
|
|
R_API int r_egg_padding (REgg *egg, const char *pad);
|
2011-08-08 00:07:26 +00:00
|
|
|
R_API int r_egg_assemble(REgg *egg);
|
2011-07-26 23:29:22 +00:00
|
|
|
R_API RBuffer *r_egg_get_bin(REgg *egg);
|
|
|
|
//R_API int r_egg_dump (REgg *egg, const char *file) { }
|
|
|
|
R_API char *r_egg_get_source(REgg *egg);
|
|
|
|
R_API RBuffer *r_egg_get_bin(REgg *egg);
|
|
|
|
R_API char *r_egg_get_assembly(REgg *egg);
|
2011-07-27 08:30:23 +00:00
|
|
|
R_API void r_egg_append(REgg *egg, const char *src);
|
2011-11-13 03:08:08 +00:00
|
|
|
R_API int r_egg_run(REgg *egg);
|
2011-11-30 09:27:01 +00:00
|
|
|
R_API int r_egg_patch(REgg *egg, int off, const ut8 *b, int l);
|
|
|
|
R_API void r_egg_finalize(REgg *egg);
|
2011-07-26 23:29:22 +00:00
|
|
|
|
|
|
|
/* lang.c */
|
|
|
|
R_API char *r_egg_mkvar(REgg *egg, char *out, const char *_str, int delta);
|
|
|
|
R_API int r_egg_lang_parsechar(REgg *egg, char c);
|
2011-09-19 23:53:15 +00:00
|
|
|
R_API void r_egg_lang_include_path (REgg *egg, const char *path);
|
|
|
|
R_API void r_egg_lang_include_init (REgg *egg);
|
2011-11-13 03:08:08 +00:00
|
|
|
|
|
|
|
/* plugin pointers */
|
2011-11-14 01:04:27 +00:00
|
|
|
extern REggPlugin r_egg_plugin_xor;
|
2011-12-01 02:28:12 +00:00
|
|
|
extern REggPlugin r_egg_plugin_shya;
|
2011-11-14 01:04:27 +00:00
|
|
|
extern REggPlugin r_egg_plugin_exec;
|
2011-07-26 23:29:22 +00:00
|
|
|
#endif
|
2013-06-18 10:09:23 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2011-07-26 23:29:22 +00:00
|
|
|
#endif
|