Message type for PM_SIG{RETURN,SUSPEND,PROCMASK}

Change-Id: Id20352db47892eb6b870ea64ba52b3b1a293cbaa
This commit is contained in:
Lionel Sambuc 2014-05-13 18:29:11 +02:00
parent 6495d409d6
commit 9a4c1520cf
7 changed files with 35 additions and 24 deletions

View file

@ -68,13 +68,6 @@
#define PM_SIG_OACT m1_p2 /* struct sigaction * */ #define PM_SIG_OACT m1_p2 /* struct sigaction * */
#define PM_SIG_RET m1_p3 /* int (*)(void) */ #define PM_SIG_RET m1_p3 /* int (*)(void) */
/* Field names for the remaining sigpending(2), sigprocmask(2), sigreturn(2),
* sigsuspend(2) calls.
*/
#define PM_SIG_HOW m2_i1 /* int */
#define PM_SIG_SET m2_sigset /* sigset_t */
#define PM_SIG_CTX m2_p1 /* struct sigcontext * */
/*===========================================================================* /*===========================================================================*
* Calls to VFS * * Calls to VFS *
*===========================================================================*/ *===========================================================================*/

View file

@ -251,6 +251,22 @@ typedef struct {
} mess_lc_pm_sysuname; } mess_lc_pm_sysuname;
_ASSERT_MSG_SIZE(mess_lc_pm_sysuname); _ASSERT_MSG_SIZE(mess_lc_pm_sysuname);
typedef struct {
int how;
vir_bytes ctx;
sigset_t set;
uint8_t padding[32];
} mess_lc_pm_sigset;
_ASSERT_MSG_SIZE(mess_lc_pm_sigset);
typedef struct {
sigset_t set;
uint8_t padding[40];
} mess_pm_lc_sigset;
_ASSERT_MSG_SIZE(mess_pm_lc_sigset);
typedef struct { typedef struct {
time_t sec; time_t sec;
@ -1093,6 +1109,7 @@ typedef struct {
mess_lc_pm_reboot m_lc_pm_reboot; mess_lc_pm_reboot m_lc_pm_reboot;
mess_lc_pm_setgid m_lc_pm_setgid; mess_lc_pm_setgid m_lc_pm_setgid;
mess_lc_pm_setuid m_lc_pm_setuid; mess_lc_pm_setuid m_lc_pm_setuid;
mess_lc_pm_sigset m_lc_pm_sigset;
mess_lc_pm_sysuname m_lc_pm_sysuname; mess_lc_pm_sysuname m_lc_pm_sysuname;
mess_lc_pm_time m_lc_pm_time; mess_lc_pm_time m_lc_pm_time;
mess_lc_pm_waitpid m_lc_pm_waitpid; mess_lc_pm_waitpid m_lc_pm_waitpid;
@ -1138,6 +1155,7 @@ typedef struct {
mess_pm_lc_getpid m_pm_lc_getpid; mess_pm_lc_getpid m_pm_lc_getpid;
mess_pm_lc_getuid m_pm_lc_getuid; mess_pm_lc_getuid m_pm_lc_getuid;
mess_pm_lc_ptrace m_pm_lc_ptrace; mess_pm_lc_ptrace m_pm_lc_ptrace;
mess_pm_lc_sigset m_pm_lc_sigset;
mess_pm_lc_time m_pm_lc_time; mess_pm_lc_time m_pm_lc_time;
mess_pm_lc_waitpid m_pm_lc_waitpid; mess_pm_lc_waitpid m_pm_lc_waitpid;

View file

@ -12,7 +12,7 @@ sigset_t *set;
memset(&m, 0, sizeof(m)); memset(&m, 0, sizeof(m));
if (_syscall(PM_PROC_NR, PM_SIGPENDING, &m) < 0) return(-1); if (_syscall(PM_PROC_NR, PM_SIGPENDING, &m) < 0) return(-1);
*set = m.PM_SIG_SET; *set = m.m_pm_lc_sigset.set;
return(m.m_type); return(m.m_type);
} }

View file

@ -18,14 +18,14 @@ sigset_t *oset;
memset(&m, 0, sizeof(m)); memset(&m, 0, sizeof(m));
if (set == (sigset_t *) NULL) { if (set == (sigset_t *) NULL) {
m.PM_SIG_HOW = SIG_INQUIRE; m.m_lc_pm_sigset.how = SIG_INQUIRE;
sigemptyset(&m.PM_SIG_SET); sigemptyset(&m.m_lc_pm_sigset.set);
} else { } else {
m.PM_SIG_HOW = how; m.m_lc_pm_sigset.how = how;
m.PM_SIG_SET = *set; m.m_lc_pm_sigset.set = *set;
} }
if (_syscall(PM_PROC_NR, PM_SIGPROCMASK, &m) < 0) return(-1); if (_syscall(PM_PROC_NR, PM_SIGPROCMASK, &m) < 0) return(-1);
if (oset != (sigset_t *) NULL) *oset = m.PM_SIG_SET; if (oset != NULL) *oset = m.m_pm_lc_sigset.set;
return(m.m_type); return(m.m_type);
} }

View file

@ -23,10 +23,10 @@ int sigreturn(struct sigcontext *scp)
/* Protect against race conditions by blocking all interrupts. */ /* Protect against race conditions by blocking all interrupts. */
sigfillset(&set); /* splhi */ sigfillset(&set); /* splhi */
sigprocmask(SIG_SETMASK, &set, (sigset_t *) NULL); sigprocmask(SIG_SETMASK, &set, NULL);
memset(&m, 0, sizeof(m)); memset(&m, 0, sizeof(m));
m.PM_SIG_SET = scp->sc_mask; m.m_lc_pm_sigset.set = scp->sc_mask;
m.PM_SIG_CTX = (char *) scp; m.m_lc_pm_sigset.ctx = (vir_bytes)scp;
return(_syscall(PM_PROC_NR, PM_SIGRETURN, &m)); /* normally doesn't return */ return(_syscall(PM_PROC_NR, PM_SIGRETURN, &m)); /* normally doesn't return */
} }

View file

@ -11,7 +11,7 @@ const sigset_t *set;
message m; message m;
memset(&m, 0, sizeof(m)); memset(&m, 0, sizeof(m));
m.PM_SIG_SET = *set; m.m_lc_pm_sigset.set = *set;
return(_syscall(PM_PROC_NR, PM_SIGSUSPEND, &m)); return(_syscall(PM_PROC_NR, PM_SIGSUSPEND, &m));
} }

View file

@ -92,7 +92,7 @@ int do_sigpending(void)
{ {
assert(!(mp->mp_flags & (PROC_STOPPED | VFS_CALL | UNPAUSED))); assert(!(mp->mp_flags & (PROC_STOPPED | VFS_CALL | UNPAUSED)));
mp->mp_reply.PM_SIG_SET = mp->mp_sigpending; mp->mp_reply.m_pm_lc_sigset.set = mp->mp_sigpending;
return OK; return OK;
} }
@ -116,10 +116,10 @@ int do_sigprocmask(void)
assert(!(mp->mp_flags & (PROC_STOPPED | VFS_CALL | UNPAUSED))); assert(!(mp->mp_flags & (PROC_STOPPED | VFS_CALL | UNPAUSED)));
set = m_in.PM_SIG_SET; set = m_in.m_lc_pm_sigset.set;
mp->mp_reply.PM_SIG_SET = mp->mp_sigmask; mp->mp_reply.m_pm_lc_sigset.set = mp->mp_sigmask;
switch (m_in.PM_SIG_HOW) { switch (m_in.m_lc_pm_sigset.how) {
case SIG_BLOCK: case SIG_BLOCK:
sigdelset(&set, SIGKILL); sigdelset(&set, SIGKILL);
sigdelset(&set, SIGSTOP); sigdelset(&set, SIGSTOP);
@ -162,7 +162,7 @@ int do_sigsuspend(void)
assert(!(mp->mp_flags & (PROC_STOPPED | VFS_CALL | UNPAUSED))); assert(!(mp->mp_flags & (PROC_STOPPED | VFS_CALL | UNPAUSED)));
mp->mp_sigmask2 = mp->mp_sigmask; /* save the old mask */ mp->mp_sigmask2 = mp->mp_sigmask; /* save the old mask */
mp->mp_sigmask = m_in.PM_SIG_SET; mp->mp_sigmask = m_in.m_lc_pm_sigset.set;
sigdelset(&mp->mp_sigmask, SIGKILL); sigdelset(&mp->mp_sigmask, SIGKILL);
sigdelset(&mp->mp_sigmask, SIGSTOP); sigdelset(&mp->mp_sigmask, SIGSTOP);
mp->mp_flags |= SIGSUSPENDED; mp->mp_flags |= SIGSUSPENDED;
@ -182,11 +182,11 @@ int do_sigreturn(void)
assert(!(mp->mp_flags & (PROC_STOPPED | VFS_CALL | UNPAUSED))); assert(!(mp->mp_flags & (PROC_STOPPED | VFS_CALL | UNPAUSED)));
mp->mp_sigmask = m_in.PM_SIG_SET; mp->mp_sigmask = m_in.m_lc_pm_sigset.set;
sigdelset(&mp->mp_sigmask, SIGKILL); sigdelset(&mp->mp_sigmask, SIGKILL);
sigdelset(&mp->mp_sigmask, SIGSTOP); sigdelset(&mp->mp_sigmask, SIGSTOP);
r = sys_sigreturn(who_e, (struct sigmsg *) m_in.PM_SIG_CTX); r = sys_sigreturn(who_e, (struct sigmsg *)m_in.m_lc_pm_sigset.ctx);
check_pending(mp); check_pending(mp);
return(r); return(r);
} }