mirror of
https://github.com/radareorg/radare2.git
synced 2025-01-17 03:13:16 +00:00
Add asm.calls and fix asm.section indentation issue in pd
This commit is contained in:
parent
0131f257f8
commit
3c1300a915
@ -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");
|
||||||
|
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user