c3fc9df84a
* Also change _orig to _intr for clarity * Cleaned up {IPC,KER}VEC * Renamed _minix_kernel_info_struct to get_minix_kerninfo * Merged _senda.S into _ipc.S * Moved into separate files get_minix_kerninfo and _do_kernel_call * Adapted do_kernel_call to follow same _ convention as ipc functions * Drop patches in libc/net/send.c and libc/include/namespace.h Change-Id: If4ea21ecb65435170d7d87de6c826328e84c18d0
33 lines
895 B
C
33 lines
895 B
C
#include <sys/cdefs.h>
|
|
#include <lib.h>
|
|
#include "namespace.h"
|
|
|
|
#include <string.h>
|
|
#include <signal.h>
|
|
#include <sys/signal.h>
|
|
|
|
#ifdef __weak_alias
|
|
__weak_alias(sigreturn, _sigreturn)
|
|
#endif
|
|
|
|
int sigreturn(scp)
|
|
register struct sigcontext *scp;
|
|
{
|
|
sigset_t set;
|
|
|
|
/* The message can't be on the stack, because the stack will vanish out
|
|
* from under us. The send part of ipc_sendrec will succeed, but when
|
|
* a message is sent to restart the current process, who knows what will
|
|
* be in the place formerly occupied by the message?
|
|
*/
|
|
static message m;
|
|
|
|
/* Protect against race conditions by blocking all interrupts. */
|
|
sigfillset(&set); /* splhi */
|
|
sigprocmask(SIG_SETMASK, &set, (sigset_t *) NULL);
|
|
|
|
memset(&m, 0, sizeof(m));
|
|
m.PM_SIG_SET = scp->sc_mask;
|
|
m.PM_SIG_CTX = (char *) scp;
|
|
return(_syscall(PM_PROC_NR, PM_SIGRETURN, &m)); /* normally doesn't return */
|
|
}
|