diff options
Diffstat (limited to 'usr.bin/truss/ia64-fbsd.c')
-rw-r--r-- | usr.bin/truss/ia64-fbsd.c | 21 |
1 files changed, 9 insertions, 12 deletions
diff --git a/usr.bin/truss/ia64-fbsd.c b/usr.bin/truss/ia64-fbsd.c index c7d61b9..55af8d7 100644 --- a/usr.bin/truss/ia64-fbsd.c +++ b/usr.bin/truss/ia64-fbsd.c @@ -257,11 +257,12 @@ ia64_syscall_entry(struct trussinfo *trussinfo, int nargs) { * the sytem call number instead of, say, an error status). */ -int -ia64_syscall_exit(struct trussinfo *trussinfo, int syscall_num __unused) { +long +ia64_syscall_exit(struct trussinfo *trussinfo, int syscall_num __unused) +{ char buf[32]; struct reg regs; - int retval; + long retval; int i; int errorp; struct syscall *sc; @@ -291,10 +292,8 @@ ia64_syscall_exit(struct trussinfo *trussinfo, int syscall_num __unused) { sc = fsc.sc; if (!sc) { - for (i = 0; i < fsc.nargs; i++) { - fsc.s_args[i] = malloc(12); - sprintf(fsc.s_args[i], "0x%lx", fsc.args[i]); - } + for (i = 0; i < fsc.nargs; i++) + asprintf(&fsc.s_args[i], "0x%lx", fsc.args[i]); } else { /* * Here, we only look for arguments that have OUT masked in -- @@ -307,12 +306,10 @@ ia64_syscall_exit(struct trussinfo *trussinfo, int syscall_num __unused) { * If an error occurred, than don't bothe getting the data; * it may not be valid. */ - if (errorp) { - temp = malloc(12); - sprintf(temp, "0x%lx", fsc.args[sc->args[i].offset]); - } else { + if (errorp) + asprintf(&temp, "0x%lx", fsc.args[sc->args[i].offset]); + else temp = print_arg(Procfd, &sc->args[i], fsc.args); - } fsc.s_args[i] = temp; } } |