mirror of
https://github.com/radareorg/radare2.git
synced 2025-01-27 00:05:10 +00:00
159 lines
3.6 KiB
C
159 lines
3.6 KiB
C
/* radare - LGPL - Copyright 2009-2013 - pancake */
|
|
|
|
static void cmd_egg_option (REgg *egg, const char *key, const char *input) {
|
|
if (input[1]!=' ') {
|
|
char *a = r_egg_option_get (egg, key);
|
|
if (a) {
|
|
r_cons_printf ("%s\n", a);
|
|
free (a);
|
|
}
|
|
} else r_egg_option_set (egg, key, input+2);
|
|
}
|
|
|
|
static int cmd_egg_compile(REgg *egg) {
|
|
int i;
|
|
RBuffer *b;
|
|
int ret = R_FALSE;
|
|
char *p = r_egg_option_get (egg, "egg.shellcode");
|
|
if (p && *p) {
|
|
if (!r_egg_shellcode (egg, p)) {
|
|
free (p);
|
|
return R_FALSE;
|
|
}
|
|
free (p);
|
|
}
|
|
r_egg_compile (egg);
|
|
if (!r_egg_assemble (egg)) {
|
|
eprintf ("r_egg_assemble: invalid assembly\n");
|
|
return R_FALSE;
|
|
}
|
|
p = r_egg_option_get (egg, "egg.padding");
|
|
if (p && *p) {
|
|
r_egg_padding (egg, p);
|
|
free (p);
|
|
}
|
|
p = r_egg_option_get (egg, "egg.encoder");
|
|
if (p && *p) {
|
|
r_egg_encode (egg, p);
|
|
free (p);
|
|
}
|
|
if ((b = r_egg_get_bin (egg))) {
|
|
if (b->length>0) {
|
|
for (i=0; i<b->length; i++)
|
|
r_cons_printf ("%02x", b->buf[i]);
|
|
r_cons_printf ("\n");
|
|
}
|
|
ret = R_TRUE;
|
|
}
|
|
// we do not own this buffer!!
|
|
// r_buf_free (b);
|
|
r_egg_reset (egg);
|
|
return ret;
|
|
}
|
|
|
|
static int cmd_egg(void *data, const char *input) {
|
|
RCore *core = (RCore *)data;
|
|
REgg *egg = core->egg;
|
|
char *oa, *p;
|
|
r_egg_setup (egg,
|
|
r_config_get (core->config, "asm.arch"),
|
|
core->assembler->bits, 0,
|
|
r_config_get (core->config, "asm.os")); // XXX
|
|
switch (*input) {
|
|
case 's':
|
|
// TODO: pass args to r_core_syscall without vararg
|
|
if (input[1]=='?' || !input[1]) {
|
|
eprintf ("Usage: gs [syscallname] [parameters]\n");
|
|
} else {
|
|
oa = strdup (input+2);
|
|
p = strchr (oa+1, ' ');
|
|
if (p) {
|
|
*p = 0;
|
|
r_core_syscall (core, oa, p+1);
|
|
} else {
|
|
r_core_syscall (core, oa, "");
|
|
}
|
|
free (oa);
|
|
}
|
|
break;
|
|
case ' ':
|
|
r_egg_load (egg, input+2, 0);
|
|
if (!cmd_egg_compile (egg))
|
|
eprintf ("Cannot compile '%s'\n", input+2);
|
|
break;
|
|
case '\0':
|
|
if (!cmd_egg_compile (egg))
|
|
eprintf ("Cannot compile\n");
|
|
break;
|
|
case 'p':
|
|
cmd_egg_option (egg, "egg.padding", input);
|
|
break;
|
|
case 'e':
|
|
cmd_egg_option (egg, "egg.encoder", input);
|
|
break;
|
|
case 'i':
|
|
cmd_egg_option (egg, "egg.shellcode", input);
|
|
break;
|
|
case 'l':
|
|
{
|
|
RListIter *iter;
|
|
REggPlugin *p;
|
|
r_list_foreach (egg->plugins, iter, p) {
|
|
printf ("%s %6s : %s\n",
|
|
(p->type==R_EGG_PLUGIN_SHELLCODE)?
|
|
"shc":"enc", p->name, p->desc);
|
|
}
|
|
}
|
|
break;
|
|
case 'r':
|
|
cmd_egg_option (egg, "egg.padding", "");
|
|
cmd_egg_option (egg, "egg.shellcode", "");
|
|
cmd_egg_option (egg, "egg.encoder", "");
|
|
break;
|
|
case 'c':
|
|
// list, get, set egg options
|
|
switch (input[1]) {
|
|
case ' ':
|
|
oa = strdup (input+2);
|
|
p = strchr (oa, '=');
|
|
if (p) {
|
|
*p = 0;
|
|
r_egg_option_set (egg, oa, p+1);
|
|
} else {
|
|
char *o = r_egg_option_get (egg, oa);
|
|
if (o) {
|
|
r_cons_printf ("%s\n", o);
|
|
free (o);
|
|
}
|
|
}
|
|
break;
|
|
case '\0':
|
|
// list
|
|
r_pair_list (egg->pair,NULL);
|
|
eprintf ("list options\n");
|
|
break;
|
|
default:
|
|
eprintf ("Usage: gc [k=v]\n");
|
|
break;
|
|
}
|
|
break;
|
|
case '?':
|
|
eprintf ("Usage: g[wcilper] [arg]\n"
|
|
" g foo.r : compile r_egg source file\n"
|
|
" gw : compile and write\n"
|
|
" gc cmd=/bin/ls : set config option for shellcodes and encoders\n"
|
|
" gc : list all config options\n"
|
|
" gl : list plugins (shellcodes, encoders)\n"
|
|
" gs name args : compile syscall name(args)\n"
|
|
" gi exec : compile shellcode. like ragg2 -i\n"
|
|
" gp padding : define padding for command\n"
|
|
" ge xor : specify an encoder\n"
|
|
" gr : reset r_egg\n"
|
|
"EVAL VARS: asm.arch, asm.bits, asm.os\n"
|
|
);
|
|
break;
|
|
}
|
|
return R_TRUE;
|
|
}
|
|
|