signal.c: move sigaltstack parser to a separate file

* sigaltstack.c: New file.
* Makefile.am (strace_SOURCES): Add it.
* signal.c (print_stack_t, sys_sigaltstack): Move to sigaltstack.c.
* xlat/sigaltstack_flags.in: Add default values.
This commit is contained in:
Дмитрий Левин 2015-03-26 13:03:25 +00:00
parent b6ef71b6f4
commit 174bb2b36e
4 changed files with 56 additions and 61 deletions

View File

@ -92,6 +92,7 @@ strace_SOURCES = \
sched.c \
scsi.c \
seccomp.c \
sigaltstack.c \
signal.c \
sigreturn.c \
sock.c \

53
sigaltstack.c Normal file
View File

@ -0,0 +1,53 @@
#include "defs.h"
#include "xlat/sigaltstack_flags.h"
static void
print_stack_t(struct tcb *tcp, unsigned long addr)
{
stack_t ss;
int r;
if (!addr) {
tprints("NULL");
return;
}
#if SUPPORTED_PERSONALITIES > 1 && SIZEOF_LONG > 4
if (current_wordsize != sizeof(ss.ss_sp) && current_wordsize == 4) {
struct {
uint32_t ss_sp;
int32_t ss_flags;
uint32_t ss_size;
} ss32;
r = umove(tcp, addr, &ss32);
if (r >= 0) {
memset(&ss, 0, sizeof(ss));
ss.ss_sp = (void*)(unsigned long) ss32.ss_sp;
ss.ss_flags = ss32.ss_flags;
ss.ss_size = (unsigned long) ss32.ss_size;
}
} else
#endif
{
r = umove(tcp, addr, &ss);
}
if (r < 0) {
tprintf("%#lx", addr);
} else {
tprintf("{ss_sp=%#lx, ss_flags=", (unsigned long) ss.ss_sp);
printflags(sigaltstack_flags, ss.ss_flags, "SS_???");
tprintf(", ss_size=%lu}", (unsigned long) ss.ss_size);
}
}
int
sys_sigaltstack(struct tcb *tcp)
{
if (entering(tcp)) {
print_stack_t(tcp, tcp->u_arg[0]);
} else {
tprints(", ");
print_stack_t(tcp, tcp->u_arg[1]);
}
return 0;
}

View File

@ -681,65 +681,6 @@ sys_sigsuspend(struct tcb *tcp)
return 0;
}
#if !defined SS_ONSTACK
#define SS_ONSTACK 1
#define SS_DISABLE 2
#endif
#include "xlat/sigaltstack_flags.h"
static void
print_stack_t(struct tcb *tcp, unsigned long addr)
{
stack_t ss;
int r;
if (!addr) {
tprints("NULL");
return;
}
#if SUPPORTED_PERSONALITIES > 1 && SIZEOF_LONG > 4
if (current_wordsize != sizeof(ss.ss_sp) && current_wordsize == 4) {
struct {
uint32_t ss_sp;
int32_t ss_flags;
uint32_t ss_size;
} ss32;
r = umove(tcp, addr, &ss32);
if (r >= 0) {
memset(&ss, 0, sizeof(ss));
ss.ss_sp = (void*)(unsigned long) ss32.ss_sp;
ss.ss_flags = ss32.ss_flags;
ss.ss_size = (unsigned long) ss32.ss_size;
}
} else
#endif
{
r = umove(tcp, addr, &ss);
}
if (r < 0) {
tprintf("%#lx", addr);
} else {
tprintf("{ss_sp=%#lx, ss_flags=", (unsigned long) ss.ss_sp);
printflags(sigaltstack_flags, ss.ss_flags, "SS_???");
tprintf(", ss_size=%lu}", (unsigned long) ss.ss_size);
}
}
int
sys_sigaltstack(struct tcb *tcp)
{
if (entering(tcp)) {
print_stack_t(tcp, tcp->u_arg[0]);
}
else {
tprints(", ");
print_stack_t(tcp, tcp->u_arg[1]);
}
return 0;
}
#ifdef HAVE_SIGACTION
/* "Old" sigprocmask, which operates with word-sized signal masks */

View File

@ -1,2 +1,2 @@
SS_ONSTACK
SS_DISABLE
SS_ONSTACK 1
SS_DISABLE 2