2015-01-11 19:40:26 +01:00
|
|
|
/* radare - LGPL - Copyright 2009-2015 - pancake */
|
2009-02-05 22:08:46 +01:00
|
|
|
|
|
|
|
#include <r_core.h>
|
2013-07-17 22:12:14 +02:00
|
|
|
|
2014-07-02 07:43:09 -03:00
|
|
|
#define SETI(x,y,z) r_config_node_desc(r_config_set_i(cfg,x,y), z);
|
|
|
|
#define SETICB(w,x,y,z) r_config_node_desc(r_config_set_i_cb(cfg,w,x,y), z);
|
|
|
|
#define SETPREF(x,y,z) r_config_node_desc(r_config_set(cfg,x,y), z);
|
|
|
|
#define SETCB(w,x,y,z) r_config_node_desc(r_config_set_cb(cfg,w,x,y), z);
|
2015-01-30 00:56:37 +01:00
|
|
|
#if LIL_ENDIAN
|
|
|
|
#define CFG_BIGENDIAN "false"
|
|
|
|
#else
|
|
|
|
#define CFG_BIGENDIAN "true"
|
|
|
|
#endif
|
2010-11-20 16:47:15 +01:00
|
|
|
|
2014-08-24 14:35:30 +02:00
|
|
|
static const char *has_esil(RCore *core, const char *name) {
|
|
|
|
RListIter *iter;
|
|
|
|
RAnalPlugin *h;
|
|
|
|
RAnal *a = core->anal;
|
|
|
|
r_list_foreach (a->plugins, iter, h) {
|
|
|
|
if (!strcmp (name, h->name)) {
|
|
|
|
if (h->esil)
|
|
|
|
return "Ae";
|
|
|
|
return "A_";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return "__";
|
|
|
|
}
|
|
|
|
|
2014-04-10 22:18:26 +02:00
|
|
|
// copypasta from binr/rasm2/rasm2.c
|
2014-08-24 14:35:30 +02:00
|
|
|
static void rasm2_list(RCore *core, const char *arch) {
|
2014-04-10 22:18:26 +02:00
|
|
|
int i;
|
2014-08-24 14:35:30 +02:00
|
|
|
const char *feat2, *feat;
|
|
|
|
RAsm *a = core->assembler;
|
2014-04-10 22:18:26 +02:00
|
|
|
char bits[32];
|
|
|
|
RAsmPlugin *h;
|
|
|
|
RListIter *iter;
|
|
|
|
r_list_foreach (a->plugins, iter, h) {
|
|
|
|
if (arch && *arch) {
|
|
|
|
if (h->cpus && !strcmp (arch, h->name)) {
|
|
|
|
char *c = strdup (h->cpus);
|
|
|
|
int n = r_str_split (c, ',');
|
|
|
|
for (i=0;i<n;i++)
|
|
|
|
r_cons_printf ("%s\n",
|
|
|
|
r_str_word_get0 (c, i));
|
|
|
|
free (c);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
bits[0] = 0;
|
2014-09-12 20:18:55 +02:00
|
|
|
/* The underscore makes it easier to distinguish the
|
|
|
|
* columns */
|
2014-07-02 23:18:50 +02:00
|
|
|
if (h->bits&8) strcat (bits, "_8");
|
|
|
|
if (h->bits&16) strcat (bits, "_16");
|
|
|
|
if (h->bits&32) strcat (bits, "_32");
|
|
|
|
if (h->bits&64) strcat (bits, "_64");
|
|
|
|
if (!*bits) strcat (bits, "_0");
|
2014-08-24 14:35:30 +02:00
|
|
|
feat = "__";
|
2014-04-10 22:18:26 +02:00
|
|
|
if (h->assemble && h->disassemble) feat = "ad";
|
|
|
|
if (h->assemble && !h->disassemble) feat = "a_";
|
|
|
|
if (!h->assemble && h->disassemble) feat = "_d";
|
2014-08-24 14:35:30 +02:00
|
|
|
feat2 = has_esil (core, h->name);
|
|
|
|
r_cons_printf ("%s%s %-9s %-11s %-7s %s\n",
|
|
|
|
feat, feat2, bits, h->name,
|
2014-04-10 22:18:26 +02:00
|
|
|
h->license?h->license:"unknown", h->desc);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-09 03:25:32 +02:00
|
|
|
static inline void __setsegoff(RConfig *cfg, const char *asmarch, int asmbits) {
|
2013-06-09 01:21:06 +02:00
|
|
|
if (!strcmp (asmarch, "x86"))
|
2013-11-04 03:50:30 +01:00
|
|
|
r_config_set (cfg, "asm.segoff", (asmbits==16)?"true":"false");
|
2013-06-09 01:21:06 +02:00
|
|
|
}
|
|
|
|
|
2014-10-20 23:13:38 +02:00
|
|
|
static int cb_analeobjmp(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->anal->eobjmp = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
2014-11-02 02:01:09 +01:00
|
|
|
|
2014-11-27 11:42:12 +01:00
|
|
|
static int cb_analafterjmp(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->anal->afterjmp = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-11-02 02:01:09 +01:00
|
|
|
static int cb_analsleep(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->anal->sleep = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-11-26 01:12:54 +01:00
|
|
|
static int cb_analmaxrefs(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->anal->maxreflines = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-09-14 11:52:30 +02:00
|
|
|
static int cb_analnopskip (void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->anal->nopskip = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-01-29 23:27:18 +01:00
|
|
|
static int cb_analbbsplit (void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->anal->bbsplit = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-02-06 00:08:46 +04:00
|
|
|
static int cb_analarch(void *user, void *data) {
|
2013-11-05 02:58:00 +01:00
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (*node->value == '?') {
|
|
|
|
r_anal_list (core->anal);
|
|
|
|
return R_FALSE;
|
2014-08-23 02:01:20 +02:00
|
|
|
} else {
|
|
|
|
if (*node->value) {
|
|
|
|
if (!r_anal_use (core->anal, node->value)) {
|
|
|
|
const char *aa = r_config_get (core->config, "asm.arch");
|
2015-06-04 12:38:54 +02:00
|
|
|
if (!aa || strcmp (aa, node->value)) {
|
2014-08-23 02:01:20 +02:00
|
|
|
eprintf ("anal.arch: cannot find '%s'\n", node->value);
|
2015-06-04 12:38:54 +02:00
|
|
|
}
|
2014-08-23 02:01:20 +02:00
|
|
|
return R_FALSE;
|
|
|
|
}
|
|
|
|
} else return R_FALSE;
|
2013-11-05 02:58:00 +01:00
|
|
|
}
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-02-06 00:08:46 +04:00
|
|
|
static int cb_analcpu(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
r_anal_set_cpu (core->anal, node->value);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_analsplit(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->anal->split = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-02-23 15:39:54 +01:00
|
|
|
static int cb_analrecont(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->anal->recont = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_asmarch(void *user, void *data) {
|
2014-06-10 11:48:02 +02:00
|
|
|
char asmparser[32];
|
2013-11-05 02:58:00 +01:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2014-06-13 12:06:29 +02:00
|
|
|
const char *asmos = r_config_get (core->config, "asm.os");
|
2014-04-10 22:18:26 +02:00
|
|
|
|
2014-04-11 02:22:41 +02:00
|
|
|
if (*node->value=='?') {
|
2014-08-24 14:35:30 +02:00
|
|
|
rasm2_list (core, NULL);
|
2014-09-27 03:10:44 +02:00
|
|
|
return R_FALSE;
|
2014-04-10 22:18:26 +02:00
|
|
|
}
|
2013-11-05 02:58:00 +01:00
|
|
|
r_egg_setup (core->egg, node->value, core->anal->bits, 0, R_SYS_OS);
|
2014-08-23 02:01:20 +02:00
|
|
|
if (*node->value) {
|
|
|
|
if (!r_asm_use (core->assembler, node->value)) {
|
|
|
|
eprintf ("asm.arch: cannot find (%s)\n", node->value);
|
2014-09-18 16:54:21 +02:00
|
|
|
return R_FALSE;
|
2014-08-23 02:01:20 +02:00
|
|
|
}
|
2014-09-27 03:10:44 +02:00
|
|
|
} else return R_FALSE;
|
2013-11-05 02:58:00 +01:00
|
|
|
|
2014-06-10 11:48:02 +02:00
|
|
|
snprintf (asmparser, sizeof (asmparser), "%s.pseudo", node->value);
|
|
|
|
r_config_set (core->config, "asm.parser", asmparser);
|
|
|
|
if (!(core->assembler->cur->bits & core->anal->bits)) {
|
|
|
|
int bits = core->assembler->cur->bits;
|
|
|
|
if (8&bits) bits = 8;
|
|
|
|
else if (16&bits) bits=16;
|
|
|
|
else if (32&bits) bits=32;
|
|
|
|
else bits=64;
|
|
|
|
r_config_set_i (core->config, "asm.bits", bits);
|
2013-11-05 02:58:00 +01:00
|
|
|
}
|
2013-12-07 14:25:15 +01:00
|
|
|
if (!r_config_set (core->config, "anal.arch", node->value)) {
|
2013-11-05 02:58:00 +01:00
|
|
|
char *p, *s = strdup (node->value);
|
|
|
|
p = strchr (s, '.');
|
|
|
|
if (p) *p = 0;
|
2014-09-27 03:10:44 +02:00
|
|
|
if (!r_config_set (core->config, "anal.arch", s)) {
|
|
|
|
/* fall back to the anal.null plugin */
|
|
|
|
r_config_set (core->config, "anal.arch", "null");
|
|
|
|
}
|
2013-11-05 02:58:00 +01:00
|
|
|
free (s);
|
|
|
|
}
|
|
|
|
if (!r_syscall_setup (core->anal->syscall, node->value,
|
|
|
|
asmos, core->anal->bits)) {
|
|
|
|
//eprintf ("asm.arch: Cannot setup syscall '%s/%s' from '%s'\n",
|
|
|
|
// node->value, asmos, R2_LIBDIR"/radare2/"R2_VERSION"/syscall");
|
|
|
|
}
|
|
|
|
//if (!strcmp (node->value, "bf"))
|
|
|
|
// r_config_set (core->config, "dbg.backend", "bf");
|
|
|
|
__setsegoff (core->config, node->value, core->assembler->bits);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-09-26 13:57:03 +02:00
|
|
|
static int cb_dbgbpsize(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->dbg->bpsize = node->i_value;
|
2014-09-26 14:24:33 +02:00
|
|
|
return R_TRUE;
|
2014-09-26 13:57:03 +02:00
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_asmbits(void *user, void *data) {
|
|
|
|
const char *asmos, *asmarch;
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2014-10-26 01:26:41 +02:00
|
|
|
int ret;
|
2014-05-22 11:22:48 +02:00
|
|
|
if (!core) {
|
|
|
|
eprintf ("user can't be NULL\n");
|
|
|
|
return R_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
ret = r_asm_set_bits (core->assembler, node->i_value);
|
2013-11-05 02:58:00 +01:00
|
|
|
if (ret == R_FALSE) {
|
|
|
|
RAsmPlugin *h = core->assembler->cur;
|
|
|
|
if (h) {
|
|
|
|
eprintf ("Cannot set bits %"PFMT64d" to '%s'\n",
|
|
|
|
node->i_value, h->name);
|
|
|
|
} else {
|
|
|
|
eprintf ("e asm.bits: Cannot set value, no plugins defined yet\n");
|
|
|
|
ret = R_TRUE;
|
|
|
|
}
|
|
|
|
}
|
2015-05-21 02:26:54 +02:00
|
|
|
if (!r_anal_set_bits (core->anal, node->i_value)) {
|
2013-11-05 02:58:00 +01:00
|
|
|
eprintf ("asm.arch: Cannot setup '%i' bits analysis engine\n", (int)node->i_value);
|
2015-05-21 02:26:54 +02:00
|
|
|
}
|
2013-11-05 02:58:00 +01:00
|
|
|
core->print->bits = node->i_value;
|
2014-06-26 10:27:10 +02:00
|
|
|
if (core->dbg && core->anal && core->anal->cur) {
|
2015-05-21 02:26:54 +02:00
|
|
|
int load_from_debug = 0;
|
2013-11-05 02:58:00 +01:00
|
|
|
r_debug_set_arch (core->dbg, core->anal->cur->arch, node->i_value);
|
2015-05-21 02:26:54 +02:00
|
|
|
if (r_config_get_i (core->config, "cfg.debug")) {
|
|
|
|
if (core->dbg->h && core->dbg->h->reg_profile) {
|
|
|
|
char *rp = core->dbg->h->reg_profile (core->dbg);
|
|
|
|
r_reg_set_profile_string (core->dbg->reg, rp);
|
|
|
|
r_reg_set_profile_string (core->anal->reg, rp);
|
|
|
|
free (rp);
|
|
|
|
} else {
|
|
|
|
load_from_debug = 1;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (core->anal->cur->set_reg_profile) {
|
|
|
|
core->anal->cur->set_reg_profile (core->anal);
|
|
|
|
} else {
|
|
|
|
load_from_debug = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (load_from_debug) {
|
|
|
|
if (core->dbg->h && core->dbg->h->reg_profile) {
|
|
|
|
char *rp = core->dbg->h->reg_profile (core->dbg);
|
|
|
|
r_reg_set_profile_string (core->dbg->reg, rp);
|
|
|
|
r_reg_set_profile_string (core->anal->reg, rp);
|
|
|
|
free (rp);
|
|
|
|
}
|
2014-06-26 10:27:10 +02:00
|
|
|
}
|
|
|
|
}
|
2013-11-05 02:58:00 +01:00
|
|
|
|
|
|
|
asmos = r_config_get (core->config, "asm.os");
|
|
|
|
asmarch = r_config_get (core->config, "asm.arch");
|
2014-06-25 03:07:54 +02:00
|
|
|
if (core->anal) {
|
2013-11-05 02:58:00 +01:00
|
|
|
if (!r_syscall_setup (core->anal->syscall, asmarch,
|
|
|
|
asmos, node->i_value)) {
|
|
|
|
//eprintf ("asm.arch: Cannot setup syscall '%s/%s' from '%s'\n",
|
|
|
|
// node->value, asmos, R2_LIBDIR"/radare2/"R2_VERSION"/syscall");
|
|
|
|
}
|
2014-06-25 03:07:54 +02:00
|
|
|
__setsegoff (core->config, asmarch, core->anal->bits);
|
2015-06-27 20:31:37 +03:00
|
|
|
if (core->dbg) {
|
|
|
|
r_bp_use (core->dbg->bp, asmarch, core->anal->bits);
|
|
|
|
}
|
2014-06-25 03:07:54 +02:00
|
|
|
}
|
2013-11-05 02:58:00 +01:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2015-02-11 03:50:56 +01:00
|
|
|
static int cb_asmfeatures(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2015-02-18 13:04:59 +01:00
|
|
|
|
|
|
|
if (*node->value == '?') {
|
2015-02-11 03:50:56 +01:00
|
|
|
if (core && core->assembler && core->assembler->cur) {
|
|
|
|
if (core->assembler->cur->features) {
|
|
|
|
char *feat = strdup (core->assembler->cur->features);
|
|
|
|
r_str_replace_char (feat, ',','\n');
|
|
|
|
r_cons_printf ("%s\n", feat);
|
|
|
|
free (feat);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
2015-02-18 13:04:59 +01:00
|
|
|
|
2015-02-11 03:50:56 +01:00
|
|
|
free (core->assembler->features);
|
2015-02-18 13:04:59 +01:00
|
|
|
core->assembler->features = NULL;
|
|
|
|
|
|
|
|
if (node->value[0])
|
2015-02-11 03:50:56 +01:00
|
|
|
core->assembler->features = strdup (node->value);
|
2015-02-18 13:04:59 +01:00
|
|
|
|
2015-02-11 03:50:56 +01:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_asmcpu(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2014-04-11 02:22:41 +02:00
|
|
|
if (*node->value=='?') {
|
2014-08-24 14:35:30 +02:00
|
|
|
rasm2_list (core, r_config_get (core->config, "asm.arch"));
|
2014-04-10 22:18:26 +02:00
|
|
|
return 0;
|
|
|
|
}
|
2013-11-05 02:58:00 +01:00
|
|
|
r_asm_set_cpu (core->assembler, node->value);
|
2014-08-07 01:57:10 +02:00
|
|
|
r_config_set (core->config, "anal.cpu", node->value);
|
2013-11-05 02:58:00 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_asmlineswidth(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->anal->lineswidth = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_asmos(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
int asmbits = r_config_get_i (core->config, "asm.bits");
|
2014-11-04 11:47:42 +01:00
|
|
|
RConfigNode *asmarch, *node = (RConfigNode*) data;
|
|
|
|
|
|
|
|
if (*node->value=='?') {
|
|
|
|
r_cons_printf ("dos\ndarwin\nlinux\nfreebsd\nopenbsd\nnetbsd\nwindows\n");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
asmarch = r_config_node_get (core->config, "asm.arch");
|
2013-11-05 02:58:00 +01:00
|
|
|
if (asmarch) {
|
|
|
|
r_syscall_setup (core->anal->syscall, asmarch->value,
|
|
|
|
node->value, core->anal->bits);
|
|
|
|
__setsegoff (core->config, asmarch->value, asmbits);
|
|
|
|
}
|
|
|
|
//if (!ret) eprintf ("asm.os: Cannot setup syscall os/arch for '%s'\n", node->value);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_asmparser(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
// XXX this is wrong? snprintf(buf, 127, "parse_%s", node->value),
|
|
|
|
return r_parse_use (core->parser, node->value);
|
|
|
|
// TODO: control error and restore old value (return false?) show errormsg?
|
|
|
|
//return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-01-11 19:40:26 +01:00
|
|
|
static int cb_binforce(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
r_bin_force_plugin (core->bin, node->value);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_asmsyntax(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
2014-04-11 02:22:41 +02:00
|
|
|
if (*node->value == '?') {
|
2015-05-09 11:11:46 +02:00
|
|
|
r_cons_printf ("att\nintel\njz\nregnum\n");
|
2014-04-11 02:22:41 +02:00
|
|
|
return R_FALSE;
|
2014-06-25 15:44:03 +02:00
|
|
|
} else if (!strcmp (node->value, "regnum")) {
|
|
|
|
r_asm_set_syntax (core->assembler, R_ASM_SYNTAX_REGNUM);
|
2015-05-09 11:11:46 +02:00
|
|
|
} else if (!strcmp (node->value, "jz")) {
|
|
|
|
r_asm_set_syntax (core->assembler, R_ASM_SYNTAX_JZ);
|
2014-04-11 02:22:41 +02:00
|
|
|
} else if (!strcmp (node->value, "intel")) {
|
2013-11-05 02:58:00 +01:00
|
|
|
r_asm_set_syntax (core->assembler, R_ASM_SYNTAX_INTEL);
|
2014-04-11 02:22:41 +02:00
|
|
|
} else if (!strcmp (node->value, "att")) {
|
2013-11-05 02:58:00 +01:00
|
|
|
r_asm_set_syntax (core->assembler, R_ASM_SYNTAX_ATT);
|
2014-04-11 02:22:41 +02:00
|
|
|
} else return R_FALSE;
|
2013-11-05 02:58:00 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_bigendian(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->assembler->big_endian = node->i_value;
|
|
|
|
core->anal->big_endian = node->i_value;
|
2014-11-03 19:49:37 +00:00
|
|
|
core->anal->reg->big_endian = node->i_value;
|
2013-11-05 02:58:00 +01:00
|
|
|
core->print->big_endian = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_cfgdatefmt(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
2014-04-22 18:39:17 -05:00
|
|
|
snprintf (core->print->datefmt, 32, "%s", node->value);
|
2013-11-05 02:58:00 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-04-03 23:24:09 +02:00
|
|
|
static int cb_timezone(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->print->datezone = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_cfgdebug(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (!core) return R_FALSE;
|
|
|
|
if (core->io)
|
|
|
|
core->io->debug = node->i_value;
|
|
|
|
if (core->dbg && node->i_value) {
|
|
|
|
const char *dbgbackend = r_config_get (core->config, "dbg.backend");
|
2015-01-29 01:45:39 +01:00
|
|
|
core->bin->is_debugger = R_TRUE;
|
2013-11-05 02:58:00 +01:00
|
|
|
r_debug_use (core->dbg, dbgbackend);
|
|
|
|
if (!strcmp (dbgbackend, "bf"))
|
|
|
|
r_config_set (core->config, "asm.arch", "bf");
|
|
|
|
if (core->file) {
|
2014-05-28 04:34:12 +02:00
|
|
|
r_debug_select (core->dbg, core->file->desc->fd,
|
|
|
|
core->file->desc->fd);
|
2013-11-05 02:58:00 +01:00
|
|
|
}
|
2015-01-29 01:45:39 +01:00
|
|
|
} else {
|
|
|
|
if (core->dbg) r_debug_use (core->dbg, NULL);
|
|
|
|
core->bin->is_debugger = R_FALSE;
|
|
|
|
}
|
2014-05-25 02:23:33 +02:00
|
|
|
r_config_set (core->config, "io.raw", "true");
|
2013-11-05 02:58:00 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_cfgsanbox(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
int ret = r_sandbox_enable (node->i_value);
|
2014-06-14 02:52:56 +02:00
|
|
|
if (node->i_value != ret)
|
|
|
|
eprintf ("Cannot disable sandbox\n");
|
2013-11-05 02:58:00 +01:00
|
|
|
return (!node->i_value && ret)? 0: 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_cmdrepeat(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->cmdrepeat = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-01-08 23:44:05 +01:00
|
|
|
static int cb_scrnull(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->cons->null = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_color(void *user, void *data) {
|
2010-03-11 00:51:32 +01:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
if (node->i_value) {
|
|
|
|
core->print->flags |= R_PRINT_FLAGS_COLOR;
|
|
|
|
} else {
|
|
|
|
//c:core->print->flags ^= R_PRINT_FLAGS_COLOR;
|
|
|
|
core->print->flags &= (~R_PRINT_FLAGS_COLOR);
|
|
|
|
}
|
|
|
|
r_print_set_flags (core->print, core->print->flags);
|
2010-03-11 00:51:32 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-05-07 23:21:34 +02:00
|
|
|
static int cb_dbgbep(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (*node->value == '?') {
|
|
|
|
r_cons_printf ("loader\nentry\nconstructor\nmain\n");
|
|
|
|
return R_FALSE;
|
|
|
|
}
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
2014-10-09 01:21:49 +02:00
|
|
|
|
2015-06-25 16:40:39 +02:00
|
|
|
static int cb_dbg_btalgo(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (*node->value == '?') {
|
2015-06-29 22:23:04 +02:00
|
|
|
r_cons_printf ("default\nfuzzy\nanal\n");
|
2015-06-25 16:40:39 +02:00
|
|
|
return R_FALSE;
|
|
|
|
}
|
|
|
|
free (core->dbg->btalgo);
|
|
|
|
core->dbg->btalgo = strdup (node->value);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-10-09 01:21:49 +02:00
|
|
|
static int cb_dbg_forks(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->dbg->trace_forks = node->i_value;
|
|
|
|
r_debug_attach (core->dbg, core->dbg->pid);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_dbg_execs(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->dbg->trace_execs = node->i_value;
|
|
|
|
r_debug_attach (core->dbg, core->dbg->pid);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_dbg_clone(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
core->dbg->trace_clone = node->i_value;
|
|
|
|
r_debug_attach (core->dbg, core->dbg->pid);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-08-11 16:07:17 +02:00
|
|
|
static int cb_runprofile(void *user, void *data) {
|
2014-07-09 02:24:31 +02:00
|
|
|
RCore *r = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
free ((void*)r->io->runprofile);
|
2014-08-11 16:07:17 +02:00
|
|
|
if (!node || !*(node->value))
|
2014-07-09 02:24:31 +02:00
|
|
|
r->io->runprofile = NULL;
|
2014-07-09 03:48:47 +02:00
|
|
|
else r->io->runprofile = strdup (node->value);
|
2014-07-09 02:24:31 +02:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
2014-05-07 23:21:34 +02:00
|
|
|
|
2014-07-02 02:36:41 +02:00
|
|
|
static int cb_dbgstatus(void *user, void *data) {
|
|
|
|
RCore *r = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (r_config_get_i (r->config, "cfg.debug")) {
|
|
|
|
if (node->i_value)
|
|
|
|
r_config_set (r->config, "cmd.prompt",
|
|
|
|
".dr* ; drd ; sr pc;pi 1;s-");
|
|
|
|
else r_config_set (r->config, "cmd.prompt", ".dr*");
|
|
|
|
}
|
2014-07-01 22:44:39 -03:00
|
|
|
return R_TRUE;
|
2014-07-02 02:36:41 +02:00
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_dbgbackend(void *user, void *data) {
|
|
|
|
RCore *core = (RCore*) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
// XXX: remove this spagetti
|
|
|
|
if (!strcmp (node->value, "bf"))
|
|
|
|
r_config_set (core->config, "asm.arch", "bf");
|
|
|
|
r_debug_use (core->dbg, node->value);
|
2010-03-12 18:46:11 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-04-01 00:38:24 +02:00
|
|
|
static int cb_gotolimit(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (r_sandbox_enable (0)) {
|
|
|
|
eprintf ("Cannot change gotolimit\n");
|
|
|
|
return R_FALSE;
|
|
|
|
}
|
|
|
|
if (core->anal->esil)
|
|
|
|
core->anal->esil_goto_limit = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-03-12 16:45:23 +01:00
|
|
|
static int cb_esildebug (void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (core->anal->esil)
|
|
|
|
core->anal->esil->debug = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-01-09 00:29:00 +01:00
|
|
|
static int cb_fixrows(void *user, void *data) {
|
2010-03-12 18:46:11 +01:00
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2014-01-09 00:29:00 +01:00
|
|
|
r_cons_singleton ()->fix_rows = node->i_value;
|
2010-03-12 18:46:11 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-01-09 00:29:00 +01:00
|
|
|
static int cb_fixcolumns(void *user, void *data) {
|
2011-08-27 20:25:37 +02:00
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2014-01-09 00:29:00 +01:00
|
|
|
r_cons_singleton ()->fix_columns = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_rows(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
r_cons_singleton ()->force_rows = node->i_value;
|
2011-08-27 20:25:37 +02:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-04-10 22:18:26 +02:00
|
|
|
static int cb_hexpairs(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->print->pairs = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_fsview(void *user, void *data) {
|
2011-05-13 02:31:18 +02:00
|
|
|
int type = R_FS_VIEW_NORMAL;
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2014-04-11 02:22:41 +02:00
|
|
|
if (*node->value == '?') {
|
2011-05-13 02:31:18 +02:00
|
|
|
eprintf ("Values: all|deleted|special\n");
|
|
|
|
return R_FALSE;
|
|
|
|
}
|
|
|
|
if (!strcmp (node->value, "all"))
|
|
|
|
type = R_FS_VIEW_ALL;
|
|
|
|
if (!strstr (node->value, "del"))
|
|
|
|
type |= R_FS_VIEW_DELETED;
|
|
|
|
if (!strstr (node->value, "spe"))
|
|
|
|
type |= R_FS_VIEW_SPECIAL;
|
|
|
|
r_fs_view (core->fs, type);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-12-22 01:53:15 +01:00
|
|
|
static int cb_cmddepth(void *user, void *data) {
|
|
|
|
int c = R_MAX (((RConfigNode*)data)->i_value, 0);
|
|
|
|
((RCore *)user)->cmd_depth = c;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_hexcols(void *user, void *data) {
|
|
|
|
int c = R_MIN (128, R_MAX (((RConfigNode*)data)->i_value, 0));
|
|
|
|
((RCore *)user)->print->cols = c & ~1;
|
2010-10-27 17:45:53 +02:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_hexstride(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
((RCore *)user)->print->stride = node->i_value;
|
2012-07-06 02:17:44 +02:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-02-03 00:46:44 +01:00
|
|
|
static int cb_search_kwidx(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->search->n_kws = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-05-18 02:19:11 +02:00
|
|
|
static int cb_ioenforce(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
int perm = node->i_value;
|
|
|
|
core->io->enforce_rwx = 0;
|
|
|
|
if (perm & 1) core->io->enforce_rwx |= R_IO_READ;
|
|
|
|
if (perm & 2) core->io->enforce_rwx |= R_IO_WRITE;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-11-24 00:41:20 +01:00
|
|
|
static int cb_iosectonly(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->io->sectonly = node->i_value? 1: 0;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_iobuffer(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
2011-08-27 03:31:55 +02:00
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
if (node->i_value) {
|
|
|
|
ut64 from, to;
|
|
|
|
from = r_config_get_i (core->config, "io.buffer.from");
|
|
|
|
to = r_config_get_i (core->config, "io.buffer.to");
|
|
|
|
if (from>=to) {
|
|
|
|
eprintf ("ERROR: io.buffer.from >= io.buffer.to"
|
|
|
|
" (0x%"PFMT64x" >= 0x%"PFMT64x")\n", from, to);
|
|
|
|
} else r_io_buffer_load (core->io, from, (int)(to-from));
|
|
|
|
} else r_io_buffer_close (core->io);
|
|
|
|
r_core_block_read (core, 0);
|
2011-08-27 03:31:55 +02:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_iocache(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
2011-02-28 00:03:26 +01:00
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
r_io_cache_enable (core->io, node->i_value, node->i_value);
|
2011-02-28 00:03:26 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_iova(void *user, void *data) {
|
2010-03-04 01:46:25 +01:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
if (node->i_value != core->io->va) {
|
|
|
|
core->io->va = node->i_value;
|
2015-04-29 18:35:13 +02:00
|
|
|
if (r_io_desc_get (core->io, core->io->raised)) //ugly fix for r2 -d ... "r2 is going to die soon ..."
|
|
|
|
r_core_block_read (core, 0);
|
2013-11-05 02:58:00 +01:00
|
|
|
// reload symbol information
|
|
|
|
if (r_list_length (r_bin_get_sections (core->bin))>0)
|
|
|
|
r_core_cmd0 (core, ".ia*");
|
|
|
|
}
|
2010-02-28 22:58:21 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_iozeromap(void *user, void *data) {
|
2012-12-19 12:15:35 +01:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
core->io->zeromap = node->i_value;
|
2012-12-19 12:15:35 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-05-25 02:23:33 +02:00
|
|
|
static int cb_ioraw(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
r_io_set_raw (core->io, node->i_value);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-06-10 11:20:17 +02:00
|
|
|
static int cb_ioff(void *user, void *data) {
|
2011-02-03 09:31:50 +01:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2014-05-28 19:32:29 +02:00
|
|
|
core->io->ff = node->i_value;
|
2011-02-03 09:31:50 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-06-03 15:55:56 +02:00
|
|
|
static int cb_ioautofd(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->io->autofd = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-02-09 23:13:49 +01:00
|
|
|
static int cb_iovio(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->io->vio = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_pager(void *user, void *data) {
|
2013-06-17 03:26:48 +02:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
|
|
|
|
/* Let cons know we have a new pager. */
|
|
|
|
core->cons->pager = node->value;
|
2013-06-17 03:26:48 +02:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-02-24 16:10:12 +01:00
|
|
|
static int cb_fps(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
r_cons_singleton ()->fps = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_rgbcolors(void *user, void *data) {
|
2010-03-04 01:46:25 +01:00
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
if (node->i_value) {
|
|
|
|
r_cons_singleton()->truecolor =
|
|
|
|
(r_config_get_i (core->config, "scr.truecolor"))?2:1;
|
|
|
|
} else {
|
|
|
|
r_cons_singleton()->truecolor = 0;
|
2011-10-24 12:07:12 +02:00
|
|
|
}
|
2010-10-23 14:27:13 +02:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_scrcolumns(void* user, void* data) {
|
2010-03-04 01:46:25 +01:00
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
int n = atoi (node->value);
|
|
|
|
((RCore *)user)->cons->force_columns = n;
|
|
|
|
return R_TRUE;
|
2009-03-17 22:06:50 +00:00
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_scrfgets(void* user, void* data) {
|
2010-02-28 22:58:21 +01:00
|
|
|
RCore *core = (RCore *) user;
|
2013-11-05 02:58:00 +01:00
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
2015-04-11 18:54:35 +02:00
|
|
|
if (node->i_value)
|
2013-11-05 02:58:00 +01:00
|
|
|
core->cons->user_fgets = NULL;
|
|
|
|
else core->cons->user_fgets = (void *)r_core_fgets;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_scrhtml(void *user, void *data) {
|
2010-02-28 22:58:21 +01:00
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
r_cons_singleton ()->is_html = node->i_value;
|
|
|
|
// TODO: control error and restore old value (return false?) show errormsg?
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
2012-08-19 03:28:17 +02:00
|
|
|
|
2014-09-27 03:48:54 +02:00
|
|
|
static int cb_scrhighlight(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
r_cons_highlight (node->value);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-10-30 22:58:51 +01:00
|
|
|
static int cb_screcho(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
r_cons_singleton()->echo = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_scrint(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2015-02-12 21:48:04 +01:00
|
|
|
if (node->i_value && r_sandbox_enable (0)) {
|
2015-02-12 17:23:30 +01:00
|
|
|
return R_FALSE;
|
|
|
|
}
|
2013-11-05 02:58:00 +01:00
|
|
|
r_cons_singleton()->is_interactive = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_scrnkey(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (!strcmp (node->value, "help") || *node->value == '?') {
|
|
|
|
r_cons_printf ("scr.nkey = fun, hit, flag\n");
|
|
|
|
return R_FALSE;
|
2011-11-15 23:26:45 +01:00
|
|
|
}
|
2013-11-05 02:58:00 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_scrprompt(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
r_line_singleton()->echo = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_scrrows(void* user, void* data) {
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
int n = atoi (node->value);
|
|
|
|
((RCore *)user)->cons->force_rows = n;
|
|
|
|
return R_TRUE;
|
2009-04-11 21:22:20 +00:00
|
|
|
}
|
|
|
|
|
2014-05-31 13:44:52 +02:00
|
|
|
static int cb_contiguous(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *)user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->search->contiguous = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_searchalign(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *)user;
|
2013-07-17 22:12:14 +02:00
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
core->search->align = node->i_value;
|
|
|
|
core->print->addrmod = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_segoff(void *user, void *data) {
|
2013-07-17 22:12:14 +02:00
|
|
|
RCore *core = (RCore *) user;
|
2013-11-05 02:58:00 +01:00
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
if (node->i_value)
|
|
|
|
core->print->flags |= R_PRINT_FLAGS_SEGOFF;
|
|
|
|
else core->print->flags &= (((ut32)-1) & (~R_PRINT_FLAGS_SEGOFF));
|
2013-07-17 22:12:14 +02:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_stopthreads(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
2013-07-17 19:34:27 +02:00
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
core->dbg->stop_all_threads = node->i_value;
|
2013-07-17 19:34:27 +02:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_swstep(void *user, void *data) {
|
2010-02-28 22:58:21 +01:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
core->dbg->swstep = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_teefile(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
r_cons_singleton()->teefile = node->value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2015-02-22 11:18:40 +01:00
|
|
|
static int cb_anal_trace(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
if (core->anal) {
|
|
|
|
if (node->i_value && !core->anal->esil) {
|
|
|
|
r_core_cmd0 (core, "aei");
|
|
|
|
}
|
|
|
|
core->anal->trace = node->i_value;
|
|
|
|
}
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_trace(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->dbg->trace->enabled = node->i_value;
|
2009-03-12 22:19:58 +00:00
|
|
|
return R_TRUE;
|
2009-03-12 01:42:35 +00:00
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_tracetag(void *user, void *data) {
|
2012-02-05 02:39:04 +01:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
2013-11-05 02:58:00 +01:00
|
|
|
core->dbg->trace->tag = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
2012-02-05 02:39:04 +01:00
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_truecolor(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
if (r_cons_singleton()->truecolor)
|
|
|
|
r_cons_singleton()->truecolor = (node->i_value)? 2: 1;
|
2012-02-05 02:39:04 +01:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_utf8(void *user, void *data) {
|
2013-07-19 00:20:23 +04:00
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->utf8 = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
static int cb_zoombyte(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
switch (*node->value) {
|
|
|
|
case 'p': case 'f': case 's': case '0':
|
|
|
|
case 'F': case 'e': case 'h':
|
|
|
|
core->print->zoom->mode = *node->value;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
eprintf ("Invalid zoom.byte value. See pz? for help\n");
|
|
|
|
return R_FALSE;
|
|
|
|
}
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-05-19 02:41:53 +02:00
|
|
|
static int cb_rawstr(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
core->bin->rawstr = node->i_value;
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-10-21 04:39:37 +02:00
|
|
|
static int cb_binmaxstr(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
if (core->bin) {
|
|
|
|
int v = node->i_value;
|
|
|
|
if (v<1) v = 4; // HACK
|
|
|
|
core->bin->maxstrlen = v;
|
|
|
|
// TODO: Do not refresh if nothing changed (minstrlen ?)
|
|
|
|
r_core_bin_refresh_strings (core);
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2013-12-05 23:51:17 -06:00
|
|
|
static int cb_binminstr(void *user, void *data) {
|
|
|
|
RCore *core = (RCore *) user;
|
|
|
|
RConfigNode *node = (RConfigNode *) data;
|
|
|
|
if (core->bin) {
|
2013-12-29 03:42:18 +01:00
|
|
|
int v = node->i_value;
|
|
|
|
if (v<1) v = 4; // HACK
|
|
|
|
core->bin->minstrlen = v;
|
|
|
|
// TODO: Do not refresh if nothing changed (minstrlen ?)
|
|
|
|
r_core_bin_refresh_strings (core);
|
2013-12-05 23:51:17 -06:00
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-04-27 04:25:51 +02:00
|
|
|
static int cb_searchin(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (*node->value == '?') {
|
2014-10-15 12:08:34 +02:00
|
|
|
r_cons_printf ("raw\nblock\nfile\nio.maps\nio.maprange\nio.section\n" \
|
|
|
|
"io.sections\nio.sections.write\nio.sections.exec\n" \
|
|
|
|
"dbg.stack\ndbg.heap\ndbg.map\ndbg.maps\n"\
|
2015-01-14 21:48:56 +01:00
|
|
|
"dbg.maps.exec\ndbg.maps.write\nanal.fcn\nanal.bb\n");
|
2014-04-27 04:25:51 +02:00
|
|
|
return R_FALSE;
|
|
|
|
}
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_fileloadmethod(void *user, void *data) {
|
|
|
|
RConfigNode *node = (RConfigNode*) data;
|
|
|
|
if (*node->value == '?') {
|
|
|
|
r_cons_printf ("fail\noverwrite\nappend\n");
|
|
|
|
return R_FALSE;
|
|
|
|
}
|
|
|
|
return R_TRUE;
|
|
|
|
}
|
|
|
|
|
2014-10-26 01:26:41 +02:00
|
|
|
static int __dbg_swstep_getter(void *user, RConfigNode *node) {
|
|
|
|
RCore *core = (RCore*)user;
|
|
|
|
node->i_value = core->dbg->swstep;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2014-11-07 03:48:27 +01:00
|
|
|
static int cb_anal_gp(RCore *core, RConfigNode *node) {
|
|
|
|
core->anal->gp = node->i_value;
|
|
|
|
return 1;
|
|
|
|
}
|
2014-11-24 00:41:20 +01:00
|
|
|
|
2014-11-03 04:05:19 +01:00
|
|
|
static int cb_anal_from(RCore *core, RConfigNode *node) {
|
|
|
|
if (r_config_get_i (core->config, "anal.limits")) {
|
2015-04-11 18:54:35 +02:00
|
|
|
r_anal_set_limits (core->anal,
|
2014-11-03 04:05:19 +01:00
|
|
|
r_config_get_i (core->config, "anal.from"),
|
|
|
|
r_config_get_i (core->config, "anal.to"));
|
|
|
|
}
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cb_anal_limits(void *user, RConfigNode *node) {
|
|
|
|
RCore *core = (RCore*)user;
|
|
|
|
if (node->i_value) {
|
2015-04-11 18:54:35 +02:00
|
|
|
r_anal_set_limits (core->anal,
|
2014-11-03 04:05:19 +01:00
|
|
|
r_config_get_i (core->config, "anal.from"),
|
|
|
|
r_config_get_i (core->config, "anal.to"));
|
|
|
|
} else {
|
|
|
|
r_anal_unset_limits (core->anal);
|
|
|
|
}
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2011-07-13 17:41:26 +02:00
|
|
|
#define SLURP_LIMIT (10*1024*1024)
|
2010-03-04 01:46:25 +01:00
|
|
|
R_API int r_core_config_init(RCore *core) {
|
2012-08-19 03:28:17 +02:00
|
|
|
int i;
|
2013-01-03 00:47:58 +01:00
|
|
|
char buf[128], *p, *tmpdir;
|
2014-02-01 16:13:35 +00:00
|
|
|
RConfig *cfg = core->config = r_config_new (core);
|
2009-04-06 22:53:25 +00:00
|
|
|
cfg->printf = r_cons_printf;
|
2012-08-13 04:33:01 +02:00
|
|
|
cfg->num = core->num;
|
2009-03-17 22:06:50 +00:00
|
|
|
|
2014-12-11 16:33:32 +02:00
|
|
|
/* pdb */
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("pdb.user_agent", "Microsoft-Symbol-Server/6.11.0001.402", "User agent for Microsoft symbol server");
|
|
|
|
SETPREF("pdb.server", "http://msdl.microsoft.com/download/symbols", "Base URL for Microsoft symbol server");
|
2015-05-25 17:48:43 +03:00
|
|
|
SETI("pdb.extract", 1, "Avoid extract of the pdb file, just download");
|
2014-12-11 16:33:32 +02:00
|
|
|
|
2010-02-28 22:58:21 +01:00
|
|
|
/* anal */
|
2015-01-12 02:33:57 +01:00
|
|
|
SETPREF("anal.a2f", "false", "Use the new WIP analysis algorithm (core/p/a2f), anal.depth ignored atm");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETICB("anal.gp", 0, (RConfigCallback)&cb_anal_gp, "Set the value of the GP register (MIPS)");
|
|
|
|
SETCB("anal.limits", "false", (RConfigCallback)&cb_anal_limits, "Restrict analysis to address range [anal.from:anal.to]");
|
|
|
|
SETICB("anal.from", -1, (RConfigCallback)&cb_anal_from, "Lower limit on the address range for analysis");
|
|
|
|
SETICB("anal.to", -1, (RConfigCallback)&cb_anal_from, "Upper limit on the address range for analysis");
|
2014-11-03 04:05:19 +01:00
|
|
|
|
2014-11-25 02:07:01 +01:00
|
|
|
SETCB("anal.eobjmp", "false", &cb_analeobjmp, "jmp is end of block mode (option)");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("anal.afterjmp", "false", &cb_analafterjmp, "Continue analysis after jmp/ujmp");
|
2014-10-09 18:43:57 +02:00
|
|
|
SETI("anal.depth", 16, "Max depth at code analysis"); // XXX: warn if depth is > 50 .. can be problematic
|
2015-05-07 15:49:25 +02:00
|
|
|
SETICB("anal.sleep", 0, &cb_analsleep, "Sleep N usecs every so often during analysis. Avoid 100% CPU usage");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("anal.hasnext", "true", "Continue analysis after each function");
|
2014-09-12 02:37:49 +02:00
|
|
|
SETPREF("anal.esil", "false", "Use the new ESIL code analysis");
|
2014-12-05 18:31:28 -05:00
|
|
|
SETCB("anal.nopskip", "true", &cb_analnopskip, "Skip nops at the beginning of functions");
|
2015-01-29 23:27:18 +01:00
|
|
|
SETCB("anal.bbsplit", "true", &cb_analbbsplit, "Use the experimental basic block split for JMPs");
|
2014-02-06 00:08:46 +04:00
|
|
|
SETCB("anal.arch", R_SYS_ARCH, &cb_analarch, "Specify the anal.arch to use");
|
|
|
|
SETCB("anal.cpu", R_SYS_ARCH, &cb_analcpu, "Specify the anal.cpu to use");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("anal.prelude", "", "Specify an hexpair to find preludes in code");
|
2015-05-13 23:30:58 +02:00
|
|
|
SETCB("anal.split", "true", &cb_analsplit, "Split functions into basic blocks in analysis");
|
|
|
|
SETCB("anal.recont", "false", &cb_analrecont, "End block after splitting a basic block instead of error"); // testing
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("anal.trace", "false", &cb_anal_trace, "Record ESIL trace in log database");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETI("anal.ptrdepth", 3, "Maximum number of nested pointers to follow in analysis");
|
2014-11-26 01:12:54 +01:00
|
|
|
SETICB("anal.maxreflines", 0, &cb_analmaxrefs, "Maximum number of reflines to be analyzed and displayed in asm.lines with pd");
|
2013-11-05 02:58:00 +01:00
|
|
|
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("esil.debug", "false", &cb_esildebug, "Show ESIL debug info");
|
|
|
|
SETICB("esil.gotolimit", core->anal->esil_goto_limit, &cb_gotolimit, "Maximum number of gotos per ESIL expression");
|
2015-03-12 16:45:23 +01:00
|
|
|
|
2010-06-02 19:17:47 +02:00
|
|
|
/* asm */
|
2013-11-05 02:58:00 +01:00
|
|
|
//asm.os needs to be first, since other asm.* depend on it
|
|
|
|
SETCB("asm.os", R_SYS_OS, &cb_asmos, "Select operating system (kernel) (linux, darwin, w32,..)");
|
2014-09-23 10:15:19 +02:00
|
|
|
SETI("asm.maxrefs", 5, "Maximum number of xrefs to be displayed as list (use columns above)");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.bytes", "true", "Display the bytes of each instruction");
|
2014-10-16 02:16:52 +02:00
|
|
|
SETPREF("asm.flagsinbytes", "false", "Display flags inside the bytes space");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("asm.midflags", "true", "Realign disassembly if there is a flag in the middle of an instruction");
|
|
|
|
SETPREF("asm.cmtflgrefs", "true", "Show comment flags associated to branch refenrece");
|
2014-11-13 03:36:48 +01:00
|
|
|
SETPREF("asm.cmtright", "true", "Show comments at right of disassembly if they fit in screen");
|
2014-11-14 15:49:34 +01:00
|
|
|
SETI("asm.cmtcol", 70, "Align comments at column 60");
|
2014-11-24 00:16:36 +01:00
|
|
|
SETPREF("asm.calls", "true", "Show calling convention calls as comments in disasm");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.comments", "true", "Show comments in disassembly view");
|
|
|
|
SETPREF("asm.decode", "false", "Use code analysis as a disassembler");
|
2014-08-05 05:37:48 +02:00
|
|
|
SETPREF("asm.indent", "false", "Indent disassembly based on reflines depth");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.dwarf", "false", "Show dwarf comment at disassembly");
|
2013-11-13 01:51:15 +01:00
|
|
|
SETPREF("asm.esil", "false", "Show ESIL instead of mnemonic");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("asm.filter", "true", "Replace numeric values by flags (e.g. 0x4003e0 -> sym.imp.printf)");
|
2014-07-21 04:18:27 +02:00
|
|
|
SETPREF("asm.fcnlines", "true", "Show function boundary lines");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.flags", "true", "Show flags");
|
|
|
|
SETPREF("asm.lbytes", "true", "Align disasm bytes to left");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("asm.lines", "true", "Show ASCII-art lines at disassembly");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.linescall", "false", "Enable call lines");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("asm.linesout", "true", "Show out of block lines");
|
|
|
|
SETPREF("asm.linesright", "false", "Show lines before opcode instead of offset");
|
|
|
|
SETPREF("asm.linesstyle", "false", "Iterate the jump list backwards");
|
|
|
|
SETPREF("asm.lineswide", "false", "Put a space between lines");
|
2014-09-17 11:01:36 +02:00
|
|
|
SETICB("asm.lineswidth", 7, &cb_asmlineswidth, "Number of columns for program flow arrows");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.middle", "false", "Allow disassembling jumps in the middle of an instruction");
|
|
|
|
SETPREF("asm.offset", "true", "Show offsets at disassembly");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("asm.reloff", "false", "Show relative offsets instead of absolute address in disasm");
|
2014-11-22 05:39:52 +01:00
|
|
|
SETPREF("asm.section", "false", "Show section name before offset");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("asm.pseudo", "false", "Enable pseudo syntax");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.size", "false", "Show size of opcodes in disassembly (pd)");
|
|
|
|
SETPREF("asm.stackptr", "false", "Show stack pointer at disassembly");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("asm.cyclespace", "false", "Indent instructions depending on CPU-cycles");
|
|
|
|
SETPREF("asm.cycles", "false", "Show CPU-cycles taken by instruction at disassembly");
|
2013-12-04 00:47:34 +01:00
|
|
|
SETI("asm.tabs", 0, "Use tabs in disassembly");
|
2014-07-02 18:12:07 +02:00
|
|
|
SETPREF("asm.trace", "false", "Show execution traces for each opcode");
|
2014-11-02 02:19:31 +01:00
|
|
|
SETPREF("asm.tracespace", "false", "Indent disassembly with trace.count information");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.ucase", "false", "Use uppercase syntax at disassembly");
|
2015-01-11 04:29:15 +01:00
|
|
|
SETPREF("asm.vars", "true", "Show local function variables in disassembly");
|
|
|
|
SETPREF("asm.varxs", "false", "Show accesses of local variables");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.varsub", "true", "Substitute variables in disassembly");
|
2015-06-02 01:04:10 +02:00
|
|
|
SETPREF("asm.cmtfold", "false", "Fold comments, toggle with Vz");
|
2015-03-23 10:19:53 +01:00
|
|
|
SETCB("asm.arch", R_SYS_ARCH, &cb_asmarch, "Set the arch to be used by asm");
|
2015-02-11 03:50:56 +01:00
|
|
|
SETCB("asm.features", "", &cb_asmfeatures, "Specify supported features by the target CPU (=? for help)");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETCB("asm.cpu", R_SYS_ARCH, &cb_asmcpu, "Set the kind of asm.arch cpu");
|
|
|
|
SETCB("asm.parser", "x86.pseudo", &cb_asmparser, "Set the asm parser to use");
|
|
|
|
SETCB("asm.segoff", "false", &cb_segoff, "Show segmented address in prompt (x86-16)");
|
|
|
|
SETCB("asm.syntax", "intel", &cb_asmsyntax, "Select assembly syntax");
|
|
|
|
SETI("asm.nbytes", 6, "Number of bytes for each opcode at disassembly");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("asm.bytespace", "false", "Separate hexadecimal bytes with a whitespace");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETICB("asm.bits", 32, &cb_asmbits, "Word size in bits at assembler");
|
|
|
|
SETPREF("asm.functions", "true", "Show functions in disassembly");
|
2015-01-28 17:05:18 +01:00
|
|
|
SETPREF("asm.fcncalls", "true", "Show functions calls");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("asm.xrefs", "true", "Show xrefs in disassembly");
|
2014-09-24 03:01:18 +02:00
|
|
|
SETPREF("asm.demangle", "true", "Show demangled symbols in disasm");
|
2015-03-08 02:27:39 +01:00
|
|
|
SETPREF("asm.describe", "false", "Show opcode description");
|
2015-01-11 19:40:26 +01:00
|
|
|
SETCB("bin.force", "", &cb_binforce, "Force that rbin plugin");
|
2015-01-10 01:00:01 +01:00
|
|
|
SETPREF("bin.lang", "", "Language for bin.demangle");
|
2014-09-24 03:01:18 +02:00
|
|
|
SETPREF("bin.demangle", "false", "Import demangled symbols from RBin");
|
2013-11-05 02:58:00 +01:00
|
|
|
|
2012-12-13 09:22:17 +01:00
|
|
|
/* bin */
|
2015-05-07 15:49:25 +02:00
|
|
|
SETI("bin.baddr", 0, "Base address of the binary");
|
|
|
|
SETI("bin.laddr", 0, "Base address for loading library ('*.so')");
|
2014-04-21 19:28:46 +04:00
|
|
|
SETPREF("bin.dwarf", "true", "Load dwarf information on startup if available");
|
2013-12-05 23:51:17 -06:00
|
|
|
SETICB("bin.minstr", 0, &cb_binminstr, "Minimum string length for r_bin");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETICB("bin.maxstr", 0, &cb_binmaxstr, "Maximum string length for r_bin");
|
2014-05-19 02:41:53 +02:00
|
|
|
SETCB("bin.rawstr", "false", &cb_rawstr, "Load strings from raw binaries");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("bin.strings", "true", "Load strings from rbin on startup");
|
|
|
|
|
|
|
|
/* cfg */
|
2015-01-30 00:56:37 +01:00
|
|
|
r_config_set_cb (cfg, "cfg.bigendian", CFG_BIGENDIAN, &cb_bigendian);
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("cfg.plugins", "true", "Load plugins at startup");
|
2012-08-08 10:31:17 +02:00
|
|
|
r_config_desc (cfg, "cfg.bigendian", "Use little (false) or big (true) endiannes");
|
2015-04-03 23:24:09 +02:00
|
|
|
SETCB("time.fmt", "%Y-%m-%d %H:%M:%S %z", &cb_cfgdatefmt, "Date format (%Y-%m-%d %H:%M:%S %z)");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETICB("time.zone", 0, &cb_timezone, "Time zone, in hours relative to GMT: +2, -1,..");
|
|
|
|
SETCB("cfg.debug", "false", &cb_cfgdebug, "Debugger mode");
|
2011-05-21 14:27:46 +02:00
|
|
|
p = r_sys_getenv ("EDITOR");
|
2015-01-26 21:41:57 +03:00
|
|
|
#if __WINDOWS__ && !__CYGWIN__
|
2011-11-23 02:29:09 +01:00
|
|
|
r_config_set (cfg, "cfg.editor", p? p: "notepad");
|
|
|
|
#else
|
2011-05-21 14:27:46 +02:00
|
|
|
r_config_set (cfg, "cfg.editor", p? p: "vi");
|
2011-11-23 02:29:09 +01:00
|
|
|
#endif
|
2011-08-27 20:25:37 +02:00
|
|
|
free (p);
|
2013-11-05 02:58:00 +01:00
|
|
|
r_config_desc (cfg, "cfg.editor", "Select default editor program");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("cfg.user", r_sys_whoami (buf), "Set current username/pid");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("cfg.fortunes", "true", "If enabled show tips at start");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("cfg.fortunetype", "tips,fun", "Type of fortunes to show (tips, fun, nsfw)");
|
|
|
|
SETI("cfg.hashlimit", SLURP_LIMIT, "If the file is bigger than hashlimit, do not compute hashes");
|
|
|
|
SETPREF("cfg.prefixdump", "dump", "Filename prefix for automated dumps");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETCB("cfg.sandbox", "false", &cb_cfgsanbox, "Sandbox mode disables systems and open on upper directories");
|
|
|
|
SETPREF("cfg.wseek", "false", "Seek after write");
|
|
|
|
|
|
|
|
/* diff */
|
|
|
|
SETI("diff.from", 0, "Set source diffing address for px (uses cc command)");
|
|
|
|
SETI("diff.to", 0, "Set destination diffing address for px (uses cc command)");
|
2014-12-26 11:24:49 +10:30
|
|
|
SETPREF("diff.bare", "false", "Never show function names in diff output");
|
2013-11-05 02:58:00 +01:00
|
|
|
|
|
|
|
/* dir */
|
|
|
|
SETPREF("dir.magic", R_MAGIC_PATH, "Path to r_magic files");
|
|
|
|
SETPREF("dir.plugins", R2_LIBDIR"/radare2/"R2_VERSION"/", "Path to plugin files to be loaded at startup");
|
|
|
|
SETPREF("dir.source", "", "Path to find source files");
|
|
|
|
SETPREF("dir.types", "/usr/include", "Default path to look for cparse type files");
|
2015-01-24 21:18:26 +01:00
|
|
|
#if __ANDROID__
|
2015-04-22 04:50:37 +02:00
|
|
|
SETPREF("dir.projects", "/data/data/org.radare2.installer/radare2/projects", "Default path for projects");
|
2015-06-11 12:12:22 +02:00
|
|
|
#elif __WINDOWS__
|
|
|
|
SETPREF("dir.projects", "~\\"R2_HOMEDIR"\\projects", "Default path for projects");
|
2015-01-24 21:18:26 +01:00
|
|
|
#else
|
2014-02-22 02:36:24 +01:00
|
|
|
SETPREF("dir.projects", "~/"R2_HOMEDIR"/projects", "Default path for projects");
|
2015-01-24 21:18:26 +01:00
|
|
|
#endif
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("stack.bytes", "true", "Show bytes instead of words in stack");
|
2014-09-27 03:48:54 +02:00
|
|
|
SETPREF("stack.anotated", "false", "Show anotated hexdump in visual debug");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETI("stack.size", 64, "Size of anotated hexdump in visual debug");
|
|
|
|
SETI("stack.delta", 0, "Delta for the stack dump");
|
2014-09-27 03:48:54 +02:00
|
|
|
|
2014-10-17 00:38:37 +02:00
|
|
|
SETCB("dbg.forks", "false", &cb_dbg_forks, "Stop execution if fork() is done (see dbg.threads)");
|
2015-06-29 22:23:04 +02:00
|
|
|
SETCB("dbg.btalgo", "fuzzy", &cb_dbg_btalgo, "Select backtrace algorithm");
|
2014-10-17 00:38:37 +02:00
|
|
|
SETCB("dbg.threads", "false", &cb_stopthreads, "Stop all threads when debugger breaks (see dbg.forks)");
|
2014-10-09 01:21:49 +02:00
|
|
|
SETCB("dbg.clone", "false", &cb_dbg_clone, "Stop execution if new thread is created");
|
|
|
|
SETCB("dbg.execs", "false", &cb_dbg_execs, "Stop execution if new thread is created");
|
2014-07-09 02:24:31 +02:00
|
|
|
SETCB("dbg.profile", "", &cb_runprofile, "Path to RRunProfile file");
|
2013-11-05 02:58:00 +01:00
|
|
|
/* debug */
|
2014-07-21 04:18:27 +02:00
|
|
|
SETCB("dbg.status", "false", &cb_dbgstatus, "Set cmd.prompt to '.dr*' or '.dr*;drd;sr pc;pi 1;s-'");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETCB("dbg.backend", "native", &cb_dbgbackend, "Select the debugger backend");
|
2014-05-07 23:21:34 +02:00
|
|
|
SETCB("dbg.bep", "loader", &cb_dbgbep, "break on entrypoint (loader, entry, constructor, main)");
|
2013-11-05 02:58:00 +01:00
|
|
|
if (core->cons->rows>30) // HACKY
|
|
|
|
r_config_set_i (cfg, "dbg.follow", 64);
|
|
|
|
else r_config_set_i (cfg, "dbg.follow", 32);
|
|
|
|
r_config_desc (cfg, "dbg.follow", "Follow program counter when pc > core->offset + dbg.follow");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("dbg.swstep", "false", &cb_swstep, "Force use of software steps (code analysis+breakpoint)");
|
2015-06-12 00:56:43 +02:00
|
|
|
SETPREF("dbg.shallow_trace", "false", "While tracing, avoid following calls outside specified range");
|
2014-10-26 01:26:41 +02:00
|
|
|
|
|
|
|
r_config_set_getter (cfg, "dbg.swstep", (RConfigCallback)__dbg_swstep_getter);
|
|
|
|
|
2014-09-26 13:57:03 +02:00
|
|
|
// TODO: This should be specified at first by the debug backend when attaching
|
|
|
|
#if __arm__ || __mips__
|
2015-05-07 15:49:25 +02:00
|
|
|
SETICB("dbg.bpsize", 4, &cb_dbgbpsize, "Size of software breakpoints");
|
2014-09-26 13:57:03 +02:00
|
|
|
#else
|
2015-05-07 15:49:25 +02:00
|
|
|
SETICB("dbg.bpsize", 1, &cb_dbgbpsize, "Size of software breakpoints");
|
2014-09-26 13:57:03 +02:00
|
|
|
#endif
|
2013-11-05 02:58:00 +01:00
|
|
|
SETCB("dbg.trace", "false", &cb_trace, "Trace program execution (see asm.trace)");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETICB("dbg.trace.tag", 0, &cb_tracetag, "Trace tag");
|
2013-11-05 02:58:00 +01:00
|
|
|
|
|
|
|
/* cmd */
|
2012-09-06 08:59:13 +02:00
|
|
|
if (r_file_exists ("/usr/bin/xdot"))
|
2012-08-14 03:21:31 +02:00
|
|
|
r_config_set (cfg, "cmd.graph", "!xdot a.dot");
|
2014-10-07 00:56:39 +02:00
|
|
|
else if (r_file_exists ("/usr/bin/open"))
|
|
|
|
r_config_set (cfg, "cmd.graph", "!dot -Tgif -oa.gif a.dot;!open a.gif");
|
|
|
|
else if (r_file_exists ("/usr/bin/gqview"))
|
|
|
|
r_config_set (cfg, "cmd.graph", "!dot -Tgif -oa.gif a.dot;!gqview a.gif");
|
|
|
|
else if (r_file_exists ("/usr/bin/eog"))
|
|
|
|
r_config_set (cfg, "cmd.graph", "!dot -Tgif -oa.gif a.dot;!eog a.gif");
|
|
|
|
else if (r_file_exists ("/usr/bin/xdg-open"))
|
|
|
|
r_config_set (cfg, "cmd.graph", "!dot -Tgif -oa.gif a.dot;!xdg-open a.gif");
|
|
|
|
else r_config_set (cfg, "cmd.graph", "?e cannot find a valid picture viewer");
|
2012-08-14 03:21:31 +02:00
|
|
|
r_config_desc (cfg, "cmd.graph", "Command executed by 'agv' command to view graphs");
|
2014-10-07 00:56:39 +02:00
|
|
|
SETPREF("cmd.xterm", "xterm -bg black -fg gray -e", "xterm command to spawn with V@");
|
2013-12-22 01:53:15 +01:00
|
|
|
SETICB("cmd.depth", 10, &cb_cmddepth, "Maximum command depth");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("cmd.bp", "", "Run when a breakpoint is hit");
|
|
|
|
SETPREF("cmd.times", "", "Run when a command is repeated (number prefix)");
|
2014-09-27 03:48:54 +02:00
|
|
|
SETPREF("cmd.stack", "", "Command to display the stack in visual debug mode");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("cmd.cprompt", "", "Column visual prompt commands");
|
2014-10-23 03:29:05 +02:00
|
|
|
SETPREF("cmd.gprompt", "", "Graph visual prompt commands");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("cmd.hit", "", "Run when a search hit is found");
|
|
|
|
SETPREF("cmd.open", "", "Run when file is opened");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("cmd.prompt", "", "Prompt commands");
|
|
|
|
SETCB("cmd.repeat", "true", &cb_cmdrepeat, "Alias newline (empty command) as '..'");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("cmd.fcn.new", "", "Run when new function is analyzed");
|
|
|
|
SETPREF("cmd.fcn.delete", "", "Run when a function is deleted");
|
|
|
|
SETPREF("cmd.fcn.rename", "", "Run when a function is renamed");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("cmd.visual", "", "Replace current print mode");
|
|
|
|
SETPREF("cmd.vprompt", "", "Visual prompt commands");
|
|
|
|
|
|
|
|
/* filesystem */
|
|
|
|
SETCB("fs.view", "normal", &cb_fsview, "Set visibility options for filesystems");
|
|
|
|
|
|
|
|
/* hexdump */
|
2014-04-10 22:18:26 +02:00
|
|
|
SETCB("hex.pairs", "true", &cb_hexpairs, "Show bytes paired in 'px' hexdump");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETI("hex.flagsz", 0, "If non zero, overrides the flag size in pxa");
|
|
|
|
SETICB("hex.cols", 16, &cb_hexcols, "Number of columns in hexdump");
|
|
|
|
SETPREF("hex.onechar", "false", "Number of columns in hexdump");
|
|
|
|
SETICB("hex.stride", 0, &cb_hexstride, "Line stride in hexdump (default is 0)");
|
2013-11-05 02:58:00 +01:00
|
|
|
|
|
|
|
/* http */
|
2015-04-11 18:54:35 +02:00
|
|
|
SETPREF("http.cors", "false", "Enable CORS");
|
2014-06-22 14:57:54 +02:00
|
|
|
SETPREF("http.dirlist", "false", "Enable directory listing");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("http.allow", "", "Only accept clients from the comma separated IP list");
|
2012-09-06 03:12:54 +02:00
|
|
|
#if __WINDOWS__
|
|
|
|
r_config_set (cfg, "http.browser", "start");
|
|
|
|
#else
|
2014-01-20 03:03:45 +01:00
|
|
|
if (r_file_exists ("/usr/bin/openURL")) // iOS ericautils
|
|
|
|
r_config_set (cfg, "http.browser", "/usr/bin/openURL");
|
|
|
|
else if (r_file_exists ("/system/bin/toolbox"))
|
2012-09-06 03:12:54 +02:00
|
|
|
r_config_set (cfg, "http.browser",
|
2013-11-05 02:58:00 +01:00
|
|
|
"LD_LIBRARY_PATH=/system/lib am start -a android.intent.action.VIEW -d");
|
2012-09-06 08:59:13 +02:00
|
|
|
else if (r_file_exists ("/usr/bin/xdg-open"))
|
2012-09-06 03:12:54 +02:00
|
|
|
r_config_set (cfg, "http.browser", "xdg-open");
|
2012-09-06 08:59:13 +02:00
|
|
|
else if (r_file_exists ("/usr/bin/open"))
|
2012-09-06 03:12:54 +02:00
|
|
|
r_config_set (cfg, "http.browser", "open");
|
|
|
|
else r_config_set (cfg, "http.browser", "firefox");
|
2015-05-07 15:49:25 +02:00
|
|
|
r_config_desc (cfg, "http.browser", "Command to open HTTP URLs");
|
2013-11-05 02:58:00 +01:00
|
|
|
#endif
|
2015-05-07 15:49:25 +02:00
|
|
|
SETI("http.maxsize", 0, "Maximum file size for upload");
|
|
|
|
SETPREF("http.bind", "localhost", "Server address");
|
2014-04-21 12:55:34 +02:00
|
|
|
#if __WINDOWS__
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("http.root", "www", "Root directory");
|
2014-04-21 12:55:34 +02:00
|
|
|
#else
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("http.root", R2_WWWROOT, "Root directory");
|
2014-04-21 12:55:34 +02:00
|
|
|
#endif
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("http.port", "9090", "Server port");
|
2015-01-20 22:25:15 +01:00
|
|
|
#if __ANDROID__ || __IPHONE_2_0
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("http.ui", "enyo", "Default webui (enyo, p, t)");
|
2015-01-20 22:25:15 +01:00
|
|
|
#else
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("http.ui", "p", "Default webui (enyo, p, t)");
|
2015-01-20 22:25:15 +01:00
|
|
|
#endif
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("http.sandbox", "false", "Sandbox the HTTP server");
|
|
|
|
SETI("http.timeout", 3, "Disconnect clients after N seconds of inactivity");
|
|
|
|
SETI("http.dietime", 0, "Kill server after N seconds with no client");
|
|
|
|
SETPREF("http.verbose", "true", "Output server logs to stdout");
|
|
|
|
SETPREF("http.upget", "false", "/up/ answers GET requests, in addition to POST");
|
|
|
|
SETPREF("http.upload", "false", "Enable file uploads to /up/<filename>");
|
|
|
|
SETPREF("http.uri", "", "Address of HTTP proxy");
|
2013-01-03 00:47:58 +01:00
|
|
|
tmpdir = r_file_tmpdir ();
|
|
|
|
r_config_set (cfg, "http.uproot", tmpdir);
|
|
|
|
free (tmpdir);
|
2015-05-07 15:49:25 +02:00
|
|
|
r_config_desc(cfg, "http.uproot", "Path where files are uploaded");
|
2013-11-05 02:58:00 +01:00
|
|
|
|
|
|
|
/* graph */
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("graph.font", "Courier", "Font for dot graphs");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("graph.offset", "false", "Show offsets in graphs");
|
2014-04-29 03:53:48 +02:00
|
|
|
SETPREF("graph.web", "false", "Display graph in web browser (VV)");
|
2014-12-22 04:16:50 +01:00
|
|
|
SETI("graph.from", UT64_MAX, "");
|
|
|
|
SETI("graph.to", UT64_MAX, "");
|
2015-06-29 23:49:38 +02:00
|
|
|
SETI("graph.scroll", 5, "Scroll speed in ascii-art graph");
|
2012-09-06 03:12:54 +02:00
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
/* hud */
|
2014-08-30 01:22:34 +02:00
|
|
|
SETPREF("hud.path", "", "Set a custom path for the HUD file");
|
2013-09-16 04:08:08 +02:00
|
|
|
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("esil.romem", "false", "Set memory as read-only for ESIL");
|
|
|
|
SETPREF("esil.stats", "false", "Statistics from ESIL emulation stored in sdb");
|
2014-09-11 04:18:23 +02:00
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
/* scr */
|
2013-09-16 04:08:08 +02:00
|
|
|
#if __EMSCRIPTEN__
|
2013-11-05 02:58:00 +01:00
|
|
|
r_config_set_cb (cfg, "scr.fgets", "true", cb_scrfgets);
|
2013-09-16 04:08:08 +02:00
|
|
|
#else
|
2013-11-05 02:58:00 +01:00
|
|
|
r_config_set_cb (cfg, "scr.fgets", "false", cb_scrfgets);
|
2013-09-16 04:08:08 +02:00
|
|
|
#endif
|
2015-05-07 15:49:25 +02:00
|
|
|
r_config_desc (cfg, "scr.fgets", "Use fgets() instead of dietline for prompt input");
|
2014-10-30 22:58:51 +01:00
|
|
|
SETCB("scr.echo", "false", &cb_screcho, "Show rcons output in realtime to stderr and buffer");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("scr.colorops", "true", "Colorize numbers and registers in opcodes");
|
2014-09-22 15:00:41 +02:00
|
|
|
#if __ANDROID__
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("scr.responsive", "true", "Auto-adjust Visual depending on screen (e.g. unset asm.bytes)");
|
2014-09-22 15:00:41 +02:00
|
|
|
#else
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("scr.responsive", "false", "Auto-adjust Visual depending on screen (e.g. unset asm.bytes)");
|
2014-09-22 15:00:41 +02:00
|
|
|
#endif
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("scr.wheel", "true", "Mouse wheel in Visual; temporaryly disable/reenable by right click/Enter)");
|
2015-05-19 00:18:14 +02:00
|
|
|
SETPREF("scr.atport", "false", "V@ starts a background http server and spawns an r2 -C");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETI("scr.wheelspeed", 1, "Mouse wheel speed");
|
2014-10-06 02:36:22 +02:00
|
|
|
// DEPRECATED: USES hex.cols now SETI("scr.colpos", 80, "Column position of cmd.cprompt in visual");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETICB("scr.columns", 0, &cb_scrcolumns, "Force console column count (width)");
|
|
|
|
SETCB("scr.rows", "0", &cb_scrrows, "Force console row count (height) ");
|
|
|
|
SETICB("scr.rows", 0, &cb_rows, "Force console row count (height) (duplicate?)");
|
|
|
|
SETCB("scr.fps", "false", &cb_fps, "Show FPS in Visual");
|
2014-01-09 00:29:00 +01:00
|
|
|
SETICB("scr.fix_rows", 0, &cb_fixrows, "Workaround for Linux TTY");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETICB("scr.fix_columns", 0, &cb_fixcolumns, "Workaround for Prompt iOS SSH client");
|
|
|
|
SETCB("scr.highlight", "", &cb_scrhighlight, "Highlight that word at RCons level");
|
|
|
|
SETCB("scr.interactive", "true", &cb_scrint, "Start in interactive mode");
|
2014-09-28 03:27:22 +02:00
|
|
|
SETI("scr.feedback", 1, "Set visual feedback level (1=arrow on jump, 2=every key (useful for videos))");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("scr.html", "false", &cb_scrhtml, "Disassembly uses HTML syntax");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETCB("scr.nkey", "hit", &cb_scrnkey, "Select the seek mode in visual");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("scr.pager", "", &cb_pager, "Select pager program (when output overflows the window)");
|
|
|
|
SETPREF("scr.pipecolor", "false", "Enable colors when using pipes");
|
|
|
|
SETPREF("scr.promptfile", "false", "Show user prompt file (used by r2 -q)");
|
|
|
|
SETCB("scr.prompt", "true", &cb_scrprompt, "Show user prompt (used by r2 -q)");
|
|
|
|
SETCB("scr.tee", "", &cb_teefile, "Pipe output to file of this name");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("scr.seek", "", "Seek to the specified address on startup");
|
2015-01-26 21:41:57 +03:00
|
|
|
#if __WINDOWS__ && !__CYGWIN__
|
2013-11-05 02:58:00 +01:00
|
|
|
r_config_set_cb (cfg, "scr.rgbcolor", "false", &cb_rgbcolors);
|
2013-07-17 22:12:14 +02:00
|
|
|
#else
|
2013-11-05 02:58:00 +01:00
|
|
|
r_config_set_cb (cfg, "scr.rgbcolor", "true", &cb_rgbcolors);
|
2013-07-17 22:12:14 +02:00
|
|
|
#endif
|
2015-05-07 15:49:25 +02:00
|
|
|
r_config_desc (cfg, "scr.rgbcolor", "Use RGB colors (not available on Windows)");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETCB("scr.truecolor", "false", &cb_truecolor, "Manage color palette (0: ansi 16, 1: 256, 2: 16M)");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("scr.color", (core->print->flags&R_PRINT_FLAGS_COLOR)?"true":"false", &cb_color, "Enable colors");
|
|
|
|
SETCB("scr.null", "false", &cb_scrnull, "Show no output");
|
2015-04-20 14:44:54 +02:00
|
|
|
SETCB("scr.utf8", r_cons_is_utf8()?"true":"false",
|
|
|
|
&cb_utf8, "Show UTF-8 characters instead of ANSI");
|
2015-01-17 19:32:19 +01:00
|
|
|
SETPREF("scr.histsave", "true", "Always save history on exit");
|
2013-11-05 02:58:00 +01:00
|
|
|
/* search */
|
2014-05-31 13:44:52 +02:00
|
|
|
SETCB("search.contiguous", "true", &cb_contiguous, "Accept contiguous/adjacent search hits");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETICB("search.align", 0, &cb_searchalign, "Only catch aligned search hits");
|
2014-10-06 02:36:22 +02:00
|
|
|
SETI("search.chunk", 0, "Chunk size for /+ (default size is asm.bits/8");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETI("search.esilcombo", 8, "Stop search after N consecutive hits");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETI("search.count", 0, "Start index number at search hits");
|
|
|
|
SETI("search.distance", 0, "Search string distance");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("search.flags", "true", "All search results are flagged, otherwise only printed");
|
|
|
|
SETI("search.maxhits", 0, "Maximum number of hits (0: no limit)");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETI("search.from", -1, "Search start address");
|
2014-04-28 11:37:48 +02:00
|
|
|
SETCB("search.in", "file", &cb_searchin, "Specify search boundaries (raw, block, file, section)");
|
2015-02-03 00:46:44 +01:00
|
|
|
SETICB("search.kwidx", 0, &cb_search_kwidx, "Store last search index count");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("search.prefix", "hit", "Prefix name in search hits label");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("search.show", "true", "Show search results");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETI("search.to", -1, "Search end address");
|
2014-12-14 18:19:10 -05:00
|
|
|
|
|
|
|
/* rop */
|
2015-05-07 15:49:25 +02:00
|
|
|
SETI("rop.len", 5, "Maximum ROP gadget length");
|
2015-05-28 21:27:36 +02:00
|
|
|
SETPREF("rop.subchains", "false", "Display every length gadget from rop.len=X to 2 in /Rl");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("rop.conditional", "false", "Include conditional jump, calls and returns in ropsearch");
|
2015-05-22 01:05:00 -04:00
|
|
|
SETPREF("rop.nx", "false", "Include NX/XN/XD sections in ropsearch");
|
2013-11-05 02:58:00 +01:00
|
|
|
|
|
|
|
/* io */
|
2014-05-18 02:19:11 +02:00
|
|
|
SETICB("io.enforce", 0, &cb_ioenforce, "Honor IO section permissions for 1=read , 2=write, 0=none");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETCB("io.buffer", "false", &cb_iobuffer, "Load and use buffer cache if enabled");
|
2014-11-24 00:41:20 +01:00
|
|
|
SETCB("io.sectonly", "false", &cb_iosectonly, "Only read from sections (if any)");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETI("io.buffer.from", 0, "Lower address of buffered cache");
|
|
|
|
SETI("io.buffer.to", 0, "Higher address of buffered cache");
|
|
|
|
SETCB("io.cache", "false", &cb_iocache, "Enable cache for io changes");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("io.raw", "false", &cb_ioraw, "Ignore maps/sections and use raw io");
|
2014-06-10 11:20:17 +02:00
|
|
|
SETCB("io.ff", "true", &cb_ioff, "Fill invalid buffers with 0xff instead of returning error");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("io.va", "true", &cb_iova, "Use virtual address layout");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETCB("io.zeromap", "0", &cb_iozeromap, "Double map the last opened file to address zero");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETCB("io.autofd", "true", &cb_ioautofd, "Change fd when opening a new file");
|
|
|
|
SETCB("io.vio", "false", &cb_iovio, "Enable the new vio (reading only) (WIP)");
|
2014-10-07 19:35:15 +02:00
|
|
|
|
2013-11-05 02:58:00 +01:00
|
|
|
/* file */
|
|
|
|
SETPREF("file.analyze", "false", "Analyze file on load. Same as r2 -c aa ..");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("file.desc", "", "User defined file description (used by projects)");
|
|
|
|
SETPREF("file.md5", "", "MD5 sum of current file");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("file.path", "", "Path of current file");
|
|
|
|
SETPREF("file.project", "", "Name of current project");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETPREF("file.sha1", "", "SHA1 hash of current file");
|
2013-11-05 02:58:00 +01:00
|
|
|
SETPREF("file.type", "", "Type of current file");
|
2014-04-28 11:37:48 +02:00
|
|
|
SETCB("file.loadmethod", "fail", &cb_fileloadmethod, "What to do when load addresses overlap: fail, overwrite, or append (next available)");
|
2014-01-25 18:06:17 -06:00
|
|
|
SETI("file.loadalign", 1024, "Alignment of load addresses");
|
2015-05-07 15:49:25 +02:00
|
|
|
SETI("file.openmany", 1, "Maximum number of files opened at once");
|
|
|
|
SETPREF("file.nowarn", "true", "Suppress file loading warning messages");
|
2014-04-23 18:04:25 -05:00
|
|
|
SETPREF("file.location", "", "Is the file 'local', 'remote', or 'memory'");
|
2013-11-05 02:58:00 +01:00
|
|
|
/* magic */
|
|
|
|
SETI("magic.depth", 100, "Recursivity depth in magic description strings");
|
|
|
|
|
|
|
|
/* rap */
|
|
|
|
SETPREF("rap.loop", "true", "Run rap as a forever-listening daemon");
|
|
|
|
|
2012-09-28 02:20:52 +02:00
|
|
|
/* nkeys */
|
2015-06-12 02:19:58 +02:00
|
|
|
SETPREF("key.s", "", "override step into action");
|
|
|
|
SETPREF("key.S", "", "override step over action");
|
2012-08-19 03:28:17 +02:00
|
|
|
for (i=1; i<13; i++) {
|
|
|
|
snprintf (buf, sizeof (buf), "key.f%d", i);
|
|
|
|
snprintf (buf+10, sizeof (buf)-10,
|
2013-11-05 02:58:00 +01:00
|
|
|
"Run this when F%d key is pressed in visual mode", i);
|
2012-08-19 03:28:17 +02:00
|
|
|
switch (i) {
|
2013-11-05 02:58:00 +01:00
|
|
|
case 2: p = "dbs $$"; break;
|
|
|
|
case 7: p = "ds"; break;
|
|
|
|
case 8: p = "dso"; break;
|
|
|
|
case 9: p = "dc"; break;
|
|
|
|
default: p = ""; break;
|
2012-08-19 03:28:17 +02:00
|
|
|
}
|
|
|
|
r_config_set (cfg, buf, p);
|
|
|
|
r_config_desc (cfg, buf, buf+10);
|
|
|
|
}
|
2013-11-05 02:58:00 +01:00
|
|
|
|
2011-02-17 00:58:54 +01:00
|
|
|
/* zoom */
|
2013-11-05 02:58:00 +01:00
|
|
|
SETCB("zoom.byte", "h", &cb_zoombyte, "Zoom callback to calculate each byte (See pz? for help)");
|
|
|
|
SETI("zoom.from", 0, "Zoom start address");
|
|
|
|
SETI("zoom.maxsz", 512, "Zoom max size of block");
|
|
|
|
SETI("zoom.to", 0, "Zoom end address");
|
2009-02-05 22:08:46 +01:00
|
|
|
|
2010-02-22 04:25:35 +01:00
|
|
|
r_config_lock (cfg, R_TRUE);
|
|
|
|
return R_TRUE;
|
2009-02-05 22:08:46 +01:00
|
|
|
}
|