2015-01-24 23:26:17 +01:00
|
|
|
/* radare - LGPL - Copyright 2009-2015 - pancake */
|
2012-02-27 02:40:27 +01:00
|
|
|
|
|
|
|
static int cmd_open(void *data, const char *input) {
|
|
|
|
RCore *core = (RCore*)data;
|
2012-10-22 10:12:13 +02:00
|
|
|
int perms = R_IO_READ;
|
2013-11-06 01:32:24 +01:00
|
|
|
ut64 addr, baddr = r_config_get_i (core->config, "bin.baddr");
|
2014-01-31 02:02:51 +01:00
|
|
|
int nowarn = r_config_get_i (core->config, "file.nowarn");
|
2012-10-25 15:21:47 +02:00
|
|
|
RIOMap *map = NULL;
|
2012-02-27 02:40:27 +01:00
|
|
|
RCoreFile *file;
|
2012-10-22 10:12:13 +02:00
|
|
|
int num = -1;
|
2013-10-11 01:24:30 +02:00
|
|
|
int isn = 0;
|
2012-02-27 02:40:27 +01:00
|
|
|
char *ptr;
|
|
|
|
|
|
|
|
switch (*input) {
|
|
|
|
case '\0':
|
2014-12-19 13:46:04 +01:00
|
|
|
case '*':
|
|
|
|
case 'j':
|
2015-01-24 23:26:17 +01:00
|
|
|
r_core_file_list (core, (int)(*input));
|
2012-02-27 02:40:27 +01:00
|
|
|
break;
|
2014-12-19 02:08:58 +01:00
|
|
|
case 'p':
|
|
|
|
if (r_sandbox_enable (0)) {
|
|
|
|
eprintf ("This command is disabled in sandbox mode\n");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (input[1]==' ') {
|
|
|
|
if (r_lib_open (core->lib, input+2) == R_FAIL)
|
|
|
|
eprintf ("Oops\n");
|
|
|
|
} else {
|
|
|
|
eprintf ("Usage: op [r2plugin."R_LIB_EXT"]\n");
|
|
|
|
}
|
|
|
|
break;
|
2012-10-22 10:12:13 +02:00
|
|
|
case '+':
|
|
|
|
perms = R_IO_READ|R_IO_WRITE;
|
2013-10-11 01:24:30 +02:00
|
|
|
case 'n':
|
|
|
|
// like in r2 -n
|
|
|
|
isn = 1;
|
2012-02-27 02:40:27 +01:00
|
|
|
case ' ':
|
2013-10-11 03:11:15 +02:00
|
|
|
ptr = strchr (input+(isn?2:1), ' ');
|
2012-02-27 02:40:27 +01:00
|
|
|
if (ptr && ptr[1]=='0' && ptr[2]=='x') { // hack to fix opening files with space in path
|
|
|
|
*ptr = '\0';
|
|
|
|
addr = r_num_math (core->num, ptr+1);
|
|
|
|
} else {
|
2013-10-11 01:24:30 +02:00
|
|
|
num = atoi (ptr? ptr: input+1);
|
2012-02-27 02:40:27 +01:00
|
|
|
addr = 0LL;
|
|
|
|
}
|
|
|
|
if (num<=0) {
|
2014-10-17 00:04:52 +02:00
|
|
|
const char *fn = input+1; //(isn?2:1);
|
|
|
|
if (fn && *fn) {
|
|
|
|
if (isn) fn++;
|
|
|
|
file = r_core_file_open (core, fn, perms, addr);
|
|
|
|
if (file) {
|
2014-12-19 12:17:17 +01:00
|
|
|
r_cons_printf ("%d\n", file->desc->fd);
|
2014-10-17 00:04:52 +02:00
|
|
|
// MUST CLEAN BEFORE LOADING
|
|
|
|
if (!isn)
|
|
|
|
r_core_bin_load (core, fn, baddr);
|
|
|
|
} else if (!nowarn) {
|
|
|
|
eprintf ("Cannot open file '%s'\n", fn);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
eprintf ("Usage: on [file]\n");
|
2014-01-25 18:06:17 -06:00
|
|
|
}
|
2014-01-18 09:26:09 -06:00
|
|
|
} else {
|
|
|
|
RListIter *iter = NULL;
|
|
|
|
RCoreFile *f;
|
|
|
|
core->switch_file_view = 0;
|
|
|
|
r_list_foreach (core->files, iter, f) {
|
2014-05-28 04:34:12 +02:00
|
|
|
if (f->desc->fd == num) {
|
2014-01-18 09:26:09 -06:00
|
|
|
r_io_raise (core->io, num);
|
|
|
|
core->switch_file_view = 1;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-02-27 02:40:27 +01:00
|
|
|
r_core_block_read (core, 0);
|
|
|
|
break;
|
2014-04-27 02:06:50 -05:00
|
|
|
case 'b':
|
2014-05-12 22:57:51 -05:00
|
|
|
{
|
|
|
|
const char *value = NULL;
|
|
|
|
ut32 binfile_num = -1, binobj_num = -1;
|
2014-04-27 02:06:50 -05:00
|
|
|
|
2014-10-17 00:04:52 +02:00
|
|
|
switch (input[1]) {
|
|
|
|
case 0:
|
2014-05-12 22:57:51 -05:00
|
|
|
case 'l':
|
2014-10-17 00:04:52 +02:00
|
|
|
case 'j':
|
|
|
|
case '*':
|
|
|
|
r_core_bin_list (core, input[1]);
|
2014-05-12 22:57:51 -05:00
|
|
|
break;
|
|
|
|
case 's':
|
|
|
|
value = *(input+2) ? input+3 : NULL;
|
|
|
|
if (!value) {
|
|
|
|
eprintf ("Invalid binfile number.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
binfile_num = *value && r_is_valid_input_num_value (core->num, value) ?
|
|
|
|
r_get_input_num_value (core->num, value) : UT32_MAX;
|
|
|
|
|
|
|
|
if (binfile_num == UT32_MAX) {
|
|
|
|
eprintf ("Invalid binfile number.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
value = *(value+1) ? r_str_tok (value+1, ' ', -1) : NULL;
|
|
|
|
value = value && *(value+1) ? value+1 : NULL;
|
|
|
|
|
|
|
|
binobj_num = value && binfile_num != -1 && r_is_valid_input_num_value (core->num, value) ?
|
|
|
|
r_get_input_num_value (core->num, value) : UT32_MAX;
|
|
|
|
|
|
|
|
if (binobj_num == UT32_MAX) {
|
|
|
|
eprintf ("Invalid bin object number.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
r_core_bin_raise (core, binfile_num, binobj_num);
|
|
|
|
break;
|
|
|
|
case 'b':
|
|
|
|
value = *(input+2) ? input+3 : NULL;
|
|
|
|
if (!value) {
|
|
|
|
eprintf ("Invalid binfile number.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
binfile_num = *value && r_is_valid_input_num_value (core->num, value) ?
|
|
|
|
r_get_input_num_value (core->num, value) : UT32_MAX;
|
|
|
|
|
|
|
|
if (binfile_num == UT32_MAX) {
|
|
|
|
eprintf ("Invalid binfile number.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
value = *(value+1) ? r_str_tok (value+1, ' ', -1) : NULL;
|
|
|
|
value = value && *(value+1) ? value+1 : NULL;
|
|
|
|
|
|
|
|
r_core_bin_raise (core, binfile_num, -1);
|
|
|
|
break;
|
|
|
|
case 'o':
|
|
|
|
value = *(input+2) ? input+3 : NULL;
|
|
|
|
if (!value) {
|
|
|
|
eprintf ("Invalid binfile number.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
binobj_num = *value && r_is_valid_input_num_value (core->num, value) ?
|
|
|
|
r_get_input_num_value (core->num, value) : UT32_MAX;
|
|
|
|
|
|
|
|
if (binobj_num == UT32_MAX) {
|
|
|
|
eprintf ("Invalid bin object number.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
r_core_bin_raise (core, -1, binobj_num);
|
|
|
|
break;
|
2015-01-22 02:22:29 +01:00
|
|
|
case '-': // "ob-"
|
|
|
|
if (input[2] == '*') {
|
|
|
|
r_cons_printf ("[i] Deleted %d binfiles\n", r_bin_file_delete_all (core->bin));
|
|
|
|
} else {
|
|
|
|
if (!r_bin_file_delete (core->bin, r_num_math (core->num, input+2))) {
|
|
|
|
eprintf ("Cant find an RBinFile associated with that fd.\n");
|
|
|
|
}
|
2014-10-17 00:04:52 +02:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'd': // backward compat, must be deleted
|
|
|
|
value = *(input+2) ? input+2 : NULL;
|
2014-05-12 22:57:51 -05:00
|
|
|
if (!value) {
|
|
|
|
eprintf ("Invalid binfile number.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
binobj_num = *value && r_is_valid_input_num_value (core->num, value) ?
|
|
|
|
r_get_input_num_value (core->num, value) : UT32_MAX;
|
|
|
|
if (binobj_num == UT32_MAX) {
|
|
|
|
eprintf ("Invalid bin object number.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
r_core_bin_delete (core, -1, binobj_num);
|
|
|
|
break;
|
2014-06-21 21:32:43 +02:00
|
|
|
case '?':{
|
|
|
|
const char* help_msg[] = {
|
|
|
|
"Usage:", "ob", " # List open binary files backed by fd",
|
2014-10-17 00:04:52 +02:00
|
|
|
"ob", "", "List opened binfiles and bin objects",
|
2014-06-21 21:32:43 +02:00
|
|
|
"obb", " [binfile #]", "Prioritize by binfile number with current selected object",
|
2014-10-17 00:04:52 +02:00
|
|
|
"ob-", " [binfile #]", "Delete binfile",
|
2014-06-21 21:32:43 +02:00
|
|
|
"obd", " [binobject #]", "Delete binfile object numbers, if more than 1 object is loaded",
|
|
|
|
"obo", " [binobject #]", "Prioritize by bin object number",
|
|
|
|
"obs", " [bf #] [bobj #]", "Prioritize by binfile and object numbers",
|
|
|
|
NULL};
|
|
|
|
r_core_cmd_help (core, help_msg);
|
|
|
|
}
|
2014-05-12 22:57:51 -05:00
|
|
|
}
|
2014-04-27 02:06:50 -05:00
|
|
|
}
|
|
|
|
break;
|
2012-02-27 02:40:27 +01:00
|
|
|
case '-':
|
2015-01-22 02:22:29 +01:00
|
|
|
switch (input[1]) {
|
|
|
|
case '*':
|
|
|
|
r_core_file_close_fd (core, -1);
|
|
|
|
r_io_close_all (core->io);
|
|
|
|
r_bin_file_delete_all (core->bin);
|
|
|
|
break;
|
|
|
|
case '-':
|
|
|
|
eprintf ("All core files, io, anal and flags info purged.\n");
|
|
|
|
r_core_file_close_fd (core, -1);
|
|
|
|
r_io_close_all (core->io);
|
|
|
|
r_bin_file_delete_all (core->bin);
|
|
|
|
|
|
|
|
// TODO: Move to a-- ?
|
|
|
|
r_anal_purge (core->anal);
|
|
|
|
// TODO: Move to f-- ?
|
|
|
|
r_flag_unset_all (core->flags);
|
|
|
|
// TODO: rbin?
|
|
|
|
break;
|
|
|
|
case ' ':
|
|
|
|
if (!r_core_file_close_fd (core, atoi (input+1)))
|
|
|
|
eprintf ("Unable to find filedescriptor %d\n",
|
|
|
|
atoi (input+1));
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
eprintf ("Usage: ob-# or ob-*, where # is the filedescriptor number\n");
|
|
|
|
}
|
2014-12-19 12:17:17 +01:00
|
|
|
// hackaround to fix invalid read
|
|
|
|
//r_core_cmd0 (core, "oo");
|
2014-11-07 10:37:54 +01:00
|
|
|
// uninit deref
|
|
|
|
//r_core_block_read (core, 0);
|
2012-02-27 02:40:27 +01:00
|
|
|
break;
|
|
|
|
case 'm':
|
|
|
|
switch (input[1]) {
|
2012-10-25 09:48:45 +02:00
|
|
|
case 'r':
|
|
|
|
{
|
|
|
|
ut64 cur, new;
|
2014-08-25 22:56:47 +02:00
|
|
|
const char *p;
|
|
|
|
if (input[2] != ' ')
|
|
|
|
break;
|
|
|
|
p = strchr (input+3, ' ');
|
2012-10-25 09:48:45 +02:00
|
|
|
if (p) {
|
|
|
|
cur = r_num_math (core->num, input+3);
|
|
|
|
new = r_num_math (core->num, p+1);
|
|
|
|
map = atoi (input+3)>0?
|
|
|
|
r_io_map_resolve (core->io, cur):
|
|
|
|
r_io_map_get (core->io, cur);
|
|
|
|
if (map) {
|
|
|
|
ut64 diff = map->to - map->from;
|
|
|
|
map->from = new;
|
|
|
|
map->to = new+diff;
|
|
|
|
} else eprintf ("Cannot find any map here\n");
|
2012-10-25 15:21:47 +02:00
|
|
|
} else {
|
|
|
|
cur = core->offset;
|
|
|
|
new = r_num_math (core->num, input+3);
|
2014-05-28 04:34:12 +02:00
|
|
|
map = r_io_map_resolve (core->io, core->file->desc->fd);
|
2012-10-25 15:21:47 +02:00
|
|
|
if (map) {
|
|
|
|
ut64 diff = map->to - map->from;
|
|
|
|
map->from = new;
|
|
|
|
map->to = new+diff;
|
|
|
|
} else eprintf ("Cannot find any map here\n");
|
|
|
|
}
|
2012-10-25 09:48:45 +02:00
|
|
|
}
|
|
|
|
break;
|
2012-02-27 02:40:27 +01:00
|
|
|
case ' ':
|
|
|
|
// i need to parse delta, offset, size
|
|
|
|
{
|
|
|
|
ut64 fd = 0LL;
|
|
|
|
ut64 addr = 0LL;
|
|
|
|
ut64 size = 0LL;
|
|
|
|
ut64 delta = 0LL;
|
|
|
|
char *s = strdup (input+2);
|
|
|
|
char *p = strchr (s, ' ');
|
|
|
|
if (p) {
|
|
|
|
char *q = strchr (p+1, ' ');
|
|
|
|
*p = 0;
|
|
|
|
fd = r_num_math (core->num, s);
|
|
|
|
addr = r_num_math (core->num, p+1);
|
|
|
|
if (q) {
|
|
|
|
char *r = strchr (q+1, ' ');
|
|
|
|
*q = 0;
|
|
|
|
if (r) {
|
|
|
|
*r = 0;
|
|
|
|
size = r_num_math (core->num, q+1);
|
|
|
|
delta = r_num_math (core->num, r+1);
|
|
|
|
} else size = r_num_math (core->num, q+1);
|
|
|
|
} else size = r_io_size (core->io);
|
|
|
|
r_io_map_add (core->io, fd, 0, delta, addr, size);
|
2014-06-21 21:32:43 +02:00
|
|
|
} else eprintf ("Invalid use of om . See om? for help.");
|
2012-02-27 02:40:27 +01:00
|
|
|
free (s);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '-':
|
2012-10-25 09:48:45 +02:00
|
|
|
if (atoi (input+3)>0) {
|
|
|
|
r_io_map_del(core->io,
|
|
|
|
r_num_math (core->num, input+2));
|
|
|
|
} else {
|
|
|
|
r_io_map_del_at (core->io,
|
|
|
|
r_num_math (core->num, input+2));
|
|
|
|
}
|
2012-02-27 02:40:27 +01:00
|
|
|
break;
|
|
|
|
case '\0':
|
2014-10-22 11:01:51 +02:00
|
|
|
r_io_map_list (core->io);
|
2012-02-27 02:40:27 +01:00
|
|
|
break;
|
|
|
|
default:
|
2014-06-21 21:32:43 +02:00
|
|
|
case '?':{
|
|
|
|
const char* help_msg[] = {
|
|
|
|
"Usage:", "om[-] [arg]", " # map opened files",
|
|
|
|
"om", "", "list all defined IO maps",
|
|
|
|
"om", "-0x10000", "remove the map at given address",
|
|
|
|
"om", " fd addr [size]", "create new io map",
|
|
|
|
"omr", " fd|0xADDR ADDR", "relocate current map",
|
|
|
|
NULL};
|
|
|
|
r_core_cmd_help (core, help_msg);
|
|
|
|
}
|
2012-02-27 02:40:27 +01:00
|
|
|
break;
|
|
|
|
}
|
2012-10-25 09:48:45 +02:00
|
|
|
r_core_block_read (core, 0);
|
2012-02-27 02:40:27 +01:00
|
|
|
break;
|
|
|
|
case 'o':
|
2014-10-17 00:36:00 +02:00
|
|
|
switch (input[1]) {
|
|
|
|
case 'b': // "oob" : reopen with bin info
|
|
|
|
r_core_file_reopen (core, input+2, 0, 2);
|
|
|
|
break;
|
|
|
|
case 'n':
|
|
|
|
r_core_file_reopen (core, input+2, 0, 0);
|
|
|
|
break;
|
|
|
|
case '+':
|
|
|
|
r_core_file_reopen (core, input+2, R_IO_READ | R_IO_WRITE, 1);
|
|
|
|
break;
|
|
|
|
case 0: // "oo"
|
|
|
|
r_core_file_reopen (core, input+2, 0, 1);
|
|
|
|
break;
|
|
|
|
case '?':
|
|
|
|
default:
|
|
|
|
{
|
|
|
|
const char* help_msg[] = {
|
|
|
|
"Usage:", "oo[-] [arg]", " # map opened files",
|
|
|
|
"oo", "", "reopen current file",
|
|
|
|
"oob", "", "reopen loading rbin info",
|
|
|
|
"oon", "", "reopen without loading rbin info",
|
|
|
|
"oo+", "", "reopen in read-write",
|
|
|
|
NULL};
|
|
|
|
r_core_cmd_help (core, help_msg);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2012-02-27 02:40:27 +01:00
|
|
|
break;
|
2012-09-07 03:26:38 +02:00
|
|
|
case 'c':
|
|
|
|
// memleak? lose all settings wtf
|
|
|
|
// if load fails does not fallbacks to previous file
|
|
|
|
r_core_fini (core);
|
|
|
|
r_core_init (core);
|
|
|
|
if (!r_core_file_open (core, input+2, R_IO_READ, 0))
|
|
|
|
eprintf ("Cannot open file\n");
|
2013-11-06 01:32:24 +01:00
|
|
|
if (!r_core_bin_load (core, NULL, baddr))
|
2012-09-07 03:26:38 +02:00
|
|
|
r_config_set (core->config, "io.va", "false");
|
|
|
|
break;
|
2012-02-27 02:40:27 +01:00
|
|
|
case '?':
|
|
|
|
default:
|
2014-06-20 11:10:27 +02:00
|
|
|
{
|
|
|
|
const char *help_msg[] = {
|
|
|
|
"Usage: o","[com- ] [file] ([offset])","",
|
|
|
|
"o","","list opened files",
|
2014-12-19 13:46:04 +01:00
|
|
|
"o*","","list opened files in r2 commands",
|
|
|
|
"oj","","list opened files in JSON format",
|
2014-06-20 11:10:27 +02:00
|
|
|
"oc"," [file]","open core file, like relaunching r2",
|
2014-12-19 02:08:58 +01:00
|
|
|
"op"," ["R_LIB_EXT"]","open r2 native plugin (asm, bin, core, ..)",
|
2014-06-20 11:10:27 +02:00
|
|
|
"oo","","reopen current file (kill+fork in debugger)",
|
|
|
|
"oo","+","reopen current file in read-write",
|
|
|
|
"o"," 4","priorize io on fd 4 (bring to front)",
|
|
|
|
"o","-1","close file descriptor 1",
|
2015-01-22 02:22:29 +01:00
|
|
|
"o-","*","close all opened files",
|
|
|
|
"o--","","close all files, analysis, binfiles, flags, same as !r2 --",
|
2014-06-20 11:10:27 +02:00
|
|
|
"o"," /bin/ls","open /bin/ls file in read-only",
|
|
|
|
"o","+/bin/ls","open /bin/ls file in read-write mode",
|
|
|
|
"o"," /bin/ls 0x4000","map file at 0x4000",
|
|
|
|
"on"," /bin/ls 0x4000","map raw file at 0x4000 (no r_bin involved)",
|
2014-10-07 10:49:29 +02:00
|
|
|
"ob","[lbdos] [...]","list open binary files backed by fd",
|
2014-06-20 11:10:27 +02:00
|
|
|
"ob"," 4","priorize io and fd on 4 (bring to binfile to front)",
|
|
|
|
"om","[?]","create, list, remove IO maps",
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
r_core_cmd_help (core, help_msg);
|
|
|
|
}
|
2012-02-27 02:40:27 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|