signal: SIGSYS: decode si_syscall & si_arch fields
When receiving SIGSYS, the si_syscall & si_arch fields are set to known values, so make sure we decode their values into the symbol settings. This makes stracing seccomp failures much easier. * defs.h (syscall_name): New prototype. * printsiginfo.c: Include linux/audit.h and xlat/audit_arch.h. (print_si_info): Decode si_syscall & si_arch for SIGSYS. * syscall.c (undefined_scno_name): Delete. (syscall_name): New function. (trace_syscall_entering): Change undefined_scno_name to syscall_name. (trace_syscall_exiting): Likewise. * xlat/audit_arch.in: New file.
This commit is contained in:
parent
4d2c8a2cf7
commit
d2eaf67486
1
defs.h
1
defs.h
@ -465,6 +465,7 @@ extern void call_summary(FILE *);
|
|||||||
extern void clear_regs(void);
|
extern void clear_regs(void);
|
||||||
extern void get_regs(pid_t pid);
|
extern void get_regs(pid_t pid);
|
||||||
extern int get_scno(struct tcb *tcp);
|
extern int get_scno(struct tcb *tcp);
|
||||||
|
extern const char *syscall_name(long scno);
|
||||||
|
|
||||||
extern int umoven(struct tcb *, long, unsigned int, void *);
|
extern int umoven(struct tcb *, long, unsigned int, void *);
|
||||||
#define umove(pid, addr, objp) \
|
#define umove(pid, addr, objp) \
|
||||||
|
@ -1,9 +1,11 @@
|
|||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
|
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
|
#include <linux/audit.h>
|
||||||
|
|
||||||
#include "printsiginfo.h"
|
#include "printsiginfo.h"
|
||||||
|
|
||||||
|
#include "xlat/audit_arch.h"
|
||||||
#include "xlat/sigbus_codes.h"
|
#include "xlat/sigbus_codes.h"
|
||||||
#include "xlat/sigchld_codes.h"
|
#include "xlat/sigchld_codes.h"
|
||||||
#include "xlat/sigfpe_codes.h"
|
#include "xlat/sigfpe_codes.h"
|
||||||
@ -154,9 +156,10 @@ print_si_info(const siginfo_t *sip, bool verbose)
|
|||||||
break;
|
break;
|
||||||
#ifdef HAVE_SIGINFO_T_SI_SYSCALL
|
#ifdef HAVE_SIGINFO_T_SI_SYSCALL
|
||||||
case SIGSYS:
|
case SIGSYS:
|
||||||
tprintf(", si_call_addr=%#lx, si_syscall=%d, si_arch=%u",
|
tprintf(", si_call_addr=%#lx, si_syscall=__NR_%s, si_arch=",
|
||||||
(unsigned long) sip->si_call_addr,
|
(unsigned long) sip->si_call_addr,
|
||||||
sip->si_syscall, sip->si_arch);
|
syscall_name(sip->si_syscall));
|
||||||
|
printxval(audit_arch, sip->si_arch, "AUDIT_ARCH_???");
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
|
18
syscall.c
18
syscall.c
@ -745,13 +745,17 @@ shuffle_scno(unsigned long scno)
|
|||||||
# define shuffle_scno(scno) ((long)(scno))
|
# define shuffle_scno(scno) ((long)(scno))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static char*
|
const char *
|
||||||
undefined_scno_name(struct tcb *tcp)
|
syscall_name(long scno)
|
||||||
{
|
{
|
||||||
static char buf[sizeof("syscall_%lu") + sizeof(long)*3];
|
static char buf[sizeof("syscall_%lu") + sizeof(long)*3];
|
||||||
|
|
||||||
sprintf(buf, "syscall_%lu", shuffle_scno(tcp->scno));
|
if (SCNO_IS_VALID(scno))
|
||||||
return buf;
|
return sysent[scno].sys_name;
|
||||||
|
else {
|
||||||
|
sprintf(buf, "syscall_%lu", shuffle_scno(scno));
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static long get_regs_error;
|
static long get_regs_error;
|
||||||
@ -781,7 +785,7 @@ trace_syscall_entering(struct tcb *tcp)
|
|||||||
if (scno_good != 1)
|
if (scno_good != 1)
|
||||||
tprints("????" /* anti-trigraph gap */ "(");
|
tprints("????" /* anti-trigraph gap */ "(");
|
||||||
else if (tcp->qual_flg & UNDEFINED_SCNO)
|
else if (tcp->qual_flg & UNDEFINED_SCNO)
|
||||||
tprintf("%s(", undefined_scno_name(tcp));
|
tprintf("%s(", syscall_name(tcp->scno));
|
||||||
else
|
else
|
||||||
tprintf("%s(", tcp->s_ent->sys_name);
|
tprintf("%s(", tcp->s_ent->sys_name);
|
||||||
/*
|
/*
|
||||||
@ -843,7 +847,7 @@ trace_syscall_entering(struct tcb *tcp)
|
|||||||
|
|
||||||
printleader(tcp);
|
printleader(tcp);
|
||||||
if (tcp->qual_flg & UNDEFINED_SCNO)
|
if (tcp->qual_flg & UNDEFINED_SCNO)
|
||||||
tprintf("%s(", undefined_scno_name(tcp));
|
tprintf("%s(", syscall_name(tcp->scno));
|
||||||
else
|
else
|
||||||
tprintf("%s(", tcp->s_ent->sys_name);
|
tprintf("%s(", tcp->s_ent->sys_name);
|
||||||
if ((tcp->qual_flg & QUAL_RAW) && SEN_exit != tcp->s_ent->sen)
|
if ((tcp->qual_flg & QUAL_RAW) && SEN_exit != tcp->s_ent->sen)
|
||||||
@ -907,7 +911,7 @@ trace_syscall_exiting(struct tcb *tcp)
|
|||||||
tcp->flags &= ~TCB_REPRINT;
|
tcp->flags &= ~TCB_REPRINT;
|
||||||
printleader(tcp);
|
printleader(tcp);
|
||||||
if (tcp->qual_flg & UNDEFINED_SCNO)
|
if (tcp->qual_flg & UNDEFINED_SCNO)
|
||||||
tprintf("<... %s resumed> ", undefined_scno_name(tcp));
|
tprintf("<... %s resumed> ", syscall_name(tcp->scno));
|
||||||
else
|
else
|
||||||
tprintf("<... %s resumed> ", tcp->s_ent->sys_name);
|
tprintf("<... %s resumed> ", tcp->s_ent->sys_name);
|
||||||
}
|
}
|
||||||
|
35
xlat/audit_arch.in
Normal file
35
xlat/audit_arch.in
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
AUDIT_ARCH_AARCH64
|
||||||
|
AUDIT_ARCH_ALPHA
|
||||||
|
AUDIT_ARCH_ARM
|
||||||
|
AUDIT_ARCH_ARMEB
|
||||||
|
AUDIT_ARCH_CRIS
|
||||||
|
AUDIT_ARCH_FRV
|
||||||
|
AUDIT_ARCH_I386
|
||||||
|
AUDIT_ARCH_IA64
|
||||||
|
AUDIT_ARCH_M32R
|
||||||
|
AUDIT_ARCH_M68K
|
||||||
|
/* Linux had broken linux/elf-em.h for a while. */
|
||||||
|
#ifdef EM_MICROBLAZE
|
||||||
|
AUDIT_ARCH_MICROBLAZE
|
||||||
|
#endif
|
||||||
|
AUDIT_ARCH_MIPS
|
||||||
|
AUDIT_ARCH_MIPS64
|
||||||
|
AUDIT_ARCH_MIPS64N32
|
||||||
|
AUDIT_ARCH_MIPSEL
|
||||||
|
AUDIT_ARCH_MIPSEL64
|
||||||
|
AUDIT_ARCH_MIPSEL64N32
|
||||||
|
AUDIT_ARCH_OPENRISC
|
||||||
|
AUDIT_ARCH_PARISC
|
||||||
|
AUDIT_ARCH_PARISC64
|
||||||
|
AUDIT_ARCH_PPC
|
||||||
|
AUDIT_ARCH_PPC64
|
||||||
|
AUDIT_ARCH_PPC64LE
|
||||||
|
AUDIT_ARCH_S390
|
||||||
|
AUDIT_ARCH_S390X
|
||||||
|
AUDIT_ARCH_SH
|
||||||
|
AUDIT_ARCH_SH64
|
||||||
|
AUDIT_ARCH_SHEL
|
||||||
|
AUDIT_ARCH_SHEL64
|
||||||
|
AUDIT_ARCH_SPARC
|
||||||
|
AUDIT_ARCH_SPARC64
|
||||||
|
AUDIT_ARCH_X86_64
|
Loading…
x
Reference in New Issue
Block a user