Add asm.calls and fix asm.section indentation issue in pd

This commit is contained in:
pancake 2014-11-24 00:16:36 +01:00
parent 0131f257f8
commit 3c1300a915
2 changed files with 45 additions and 20 deletions

View File

@ -857,6 +857,7 @@ R_API int r_core_config_init(RCore *core) {
SETPREF("asm.cmtflgrefs", "true", "Show comment flags associated to branch referece"); SETPREF("asm.cmtflgrefs", "true", "Show comment flags associated to branch referece");
SETPREF("asm.cmtright", "true", "Show comments at right of disassembly if they fit in screen"); SETPREF("asm.cmtright", "true", "Show comments at right of disassembly if they fit in screen");
SETI("asm.cmtcol", 70, "Align comments at column 60"); SETI("asm.cmtcol", 70, "Align comments at column 60");
SETPREF("asm.calls", "true", "Show calling convention calls as comments in disasm");
SETPREF("asm.comments", "true", "Show comments in disassembly view"); SETPREF("asm.comments", "true", "Show comments in disassembly view");
SETPREF("asm.decode", "false", "Use code analysis as a disassembler"); SETPREF("asm.decode", "false", "Use code analysis as a disassembler");
SETPREF("asm.indent", "false", "Indent disassembly based on reflines depth"); SETPREF("asm.indent", "false", "Indent disassembly based on reflines depth");

View File

@ -66,6 +66,7 @@ typedef struct r_disam_options_t {
int show_comments; int show_comments;
int cmtcol; int cmtcol;
int show_fcnlines; int show_fcnlines;
int show_calls;
int show_cmtflgrefs; int show_cmtflgrefs;
int show_cycles; int show_cycles;
int show_stackptr; int show_stackptr;
@ -187,6 +188,20 @@ static int cmpaddr (void *_a, void *_b) {
return (a->addr > b->addr); return (a->addr > b->addr);
} }
static const char *getSectionName (RCore *core, ut64 addr) {
static char section[128] = {0};
static ut64 oaddr = UT64_MAX;
RIOSection *s;
if (oaddr == addr)
return section;
s = r_io_section_vget (core->io, addr);
if (s) {
snprintf (section, sizeof (section)-1, "%10s ", s->name);
} else *section = 0;
oaddr = addr;
return section;
}
static RDisasmState * handle_init_ds (RCore * core) { static RDisasmState * handle_init_ds (RCore * core) {
RDisasmState * ds = R_NEW0(RDisasmState); RDisasmState * ds = R_NEW0(RDisasmState);
ds->pal_comment = core->cons->pal.comment; ds->pal_comment = core->cons->pal.comment;
@ -246,6 +261,7 @@ static RDisasmState * handle_init_ds (RCore * core) {
ds->show_bytes = r_config_get_i (core->config, "asm.bytes"); ds->show_bytes = r_config_get_i (core->config, "asm.bytes");
ds->show_fcnlines = r_config_get_i (core->config, "asm.fcnlines"); ds->show_fcnlines = r_config_get_i (core->config, "asm.fcnlines");
ds->show_comments = r_config_get_i (core->config, "asm.comments"); ds->show_comments = r_config_get_i (core->config, "asm.comments");
ds->show_calls = r_config_get_i (core->config, "asm.calls");
ds->cmtcol = r_config_get_i (core->config, "asm.cmtcol"); ds->cmtcol = r_config_get_i (core->config, "asm.cmtcol");
ds->show_cmtflgrefs = r_config_get_i (core->config, "asm.cmtflgrefs"); ds->show_cmtflgrefs = r_config_get_i (core->config, "asm.cmtflgrefs");
ds->show_cycles = r_config_get_i (core->config, "asm.cycles"); ds->show_cycles = r_config_get_i (core->config, "asm.cycles");
@ -561,14 +577,19 @@ static char *filter_refline(RCore *core, const char *str) {
#endif #endif
static void beginline (RCore *core, RDisasmState *ds, RAnalFunction *f) { static void beginline (RCore *core, RDisasmState *ds, RAnalFunction *f) {
const char *section = "";
if (ds->show_section)
section = getSectionName (core, ds->at);
// THAT'S OK // THAT'S OK
if (ds->show_color) { if (ds->show_color) {
r_cons_printf ("%s%s "Color_RESET"%s%s"Color_RESET, ds->color_fline, r_cons_printf ("%s%s "Color_RESET"%s%s%s"Color_RESET,ds->color_fline,
((f&&f->type==R_ANAL_FCN_TYPE_FCN)&&f->addr==ds->at) ((f&&f->type==R_ANAL_FCN_TYPE_FCN)&&f->addr==ds->at)
?" ":core->cons->vline[LINE_VERT], ds->color_flow, ds->refline2); ?" ":core->cons->vline[LINE_VERT], ds->color_flow, section,
ds->refline2);
} else { } else {
r_cons_printf ("%s %s", ((f&&f->type==R_ANAL_FCN_TYPE_FCN) r_cons_printf ("%s %s%s", ((f&&f->type==R_ANAL_FCN_TYPE_FCN)
&& f->addr==ds->at)?" ":core->cons->vline[LINE_VERT], ds->refline2); && f->addr==ds->at)?" ":core->cons->vline[LINE_VERT],
section, ds->refline2);
} }
} }
@ -945,7 +966,7 @@ static void handle_control_flow_comments (RCore * core, RDisasmState *ds) {
if (ds->show_color) r_cons_strcat (ds->pal_comment); if (ds->show_color) r_cons_strcat (ds->pal_comment);
handle_comment_align (core, ds); handle_comment_align (core, ds);
r_cons_printf (" ; ref to %s: %s\n", item->name, item->comment); r_cons_printf (" ; ref to %s: %s\n", item->name, item->comment);
handle_print_color_reset(core, ds); handle_print_color_reset (core, ds);
} }
break; break;
} }
@ -961,10 +982,7 @@ static void handle_print_lines_right (RCore *core, RDisasmState *ds){
} }
static void handle_print_lines_left (RCore *core, RDisasmState *ds){ static void handle_print_lines_left (RCore *core, RDisasmState *ds){
if (ds->show_section) { if (ds->show_section) {
RIOSection *s = r_io_section_vget (core->io, ds->at); r_cons_strcat (getSectionName (core, ds->at));
if (s) {
r_cons_printf ("%10s ", s->name);
}
} }
if (!ds->linesright && ds->show_lines && ds->line) { if (!ds->linesright && ds->show_lines && ds->line) {
if (ds->show_color) { if (ds->show_color) {
@ -1308,7 +1326,7 @@ static void handle_print_color_reset (RCore *core, RDisasmState *ds) {
r_cons_strcat (Color_RESET); r_cons_strcat (Color_RESET);
} }
static int handle_print_middle (RCore *core, RDisasmState *ds, int ret ){ static int handle_print_middle (RCore *core, RDisasmState *ds, int ret) {
if (ds->middle != 0) { if (ds->middle != 0) {
ret -= ds->middle; ret -= ds->middle;
handle_comment_align (core, ds); handle_comment_align (core, ds);
@ -1348,7 +1366,7 @@ static void handle_print_import_name (RCore * core, RDisasmState *ds) {
case R_ANAL_OP_TYPE_CJMP: case R_ANAL_OP_TYPE_CJMP:
case R_ANAL_OP_TYPE_CALL: case R_ANAL_OP_TYPE_CALL:
if (core->bin->cur->o->imports && core->bin->cur->o->relocs) { if (core->bin->cur->o->imports && core->bin->cur->o->relocs) {
r_list_foreach(core->bin->cur->o->relocs, iter, rel) { r_list_foreach (core->bin->cur->o->relocs, iter, rel) {
if ((rel->vaddr == ds->analop.jump) && if ((rel->vaddr == ds->analop.jump) &&
(rel->import != NULL)) { (rel->import != NULL)) {
if (ds->show_color) if (ds->show_color)
@ -1377,6 +1395,7 @@ static void handle_print_fcn_name (RCore * core, RDisasmState *ds) {
if (ds->show_color) if (ds->show_color)
r_cons_strcat (ds->color_fname); r_cons_strcat (ds->color_fname);
handle_comment_align (core, ds); handle_comment_align (core, ds);
//beginline (core, ds, f);
r_cons_printf (" ; (%s)", f->name); r_cons_printf (" ; (%s)", f->name);
handle_print_color_reset (core, ds); handle_print_color_reset (core, ds);
} }
@ -1440,13 +1459,13 @@ static void handle_print_cc_update (RCore *core, RDisasmState *ds) {
tmp[0] = 0; tmp[0] = 0;
} else { } else {
if (delta) if (delta)
snprintf (tmp, sizeof (tmp), " ; %s+%d", flag->name, delta); snprintf (tmp, sizeof (tmp)-1, " ; %s+%d", flag->name, delta);
else snprintf (tmp, sizeof (tmp), " ; %s", flag->name); else snprintf (tmp, sizeof (tmp)-1, " ; %s", flag->name);
} }
} else { } else {
if (delta) if (delta)
snprintf (tmp, sizeof (tmp), " ; %s+%d", flag->name, delta); snprintf (tmp, sizeof (tmp)-1, " ; %s+%d", flag->name, delta);
else snprintf (tmp, sizeof (tmp), " ; %s", flag->name); else snprintf (tmp, sizeof (tmp)-1, " ; %s", flag->name);
} }
} }
if (f) { if (f) {
@ -1455,10 +1474,14 @@ static void handle_print_cc_update (RCore *core, RDisasmState *ds) {
} else { } else {
handle_set_pre (ds, " "); handle_set_pre (ds, " ");
} }
if (ds->show_color)
r_cons_printf ("\n%s%s"Color_RESET"%s%s"Color_RESET" %s%s"Color_RESET, if (ds->show_calls) {
ds->color_fline, ds->pre, ds->color_flow, ds->refline, ccstr, tmp); const char *sn = ds->show_section? getSectionName (core, ds->at): "";
else r_cons_printf ("\n%s%s %s%s", ds->pre, ds->refline, ccstr, tmp); if (ds->show_color)
r_cons_printf ("\n%s%s"Color_RESET"%s%s%s"Color_RESET" %s%s"Color_RESET,
ds->color_fline, ds->pre, ds->color_flow, sn, ds->refline, ccstr, tmp);
else r_cons_printf ("\n%s%s%s %s%s", ds->pre, sn, ds->refline, ccstr, tmp);
}
free (ccstr); free (ccstr);
} }
} }
@ -1470,8 +1493,9 @@ static void handle_print_cc_update (RCore *core, RDisasmState *ds) {
static void handle_comment_align (RCore *core, RDisasmState *ds) { static void handle_comment_align (RCore *core, RDisasmState *ds) {
const int cmtcol = ds->cmtcol; const int cmtcol = ds->cmtcol;
char *ll; char *ll;
if (!ds->show_comment_right_default) if (!ds->show_comment_right_default) {
return; return;
}
ll = r_cons_lastline (); ll = r_cons_lastline ();
if (ll) { if (ll) {
int cols = r_cons_get_size (NULL); int cols = r_cons_get_size (NULL);