diff options
author | Roland McGrath <roland@gnu.org> | 1995-02-25 11:33:49 +0000 |
---|---|---|
committer | Roland McGrath <roland@gnu.org> | 1995-02-25 11:33:49 +0000 |
commit | 3c46a92d403c3c72ab99169e056efdb04ddc4f15 (patch) | |
tree | de6037f8a16fd71ce7900312a0990d75ebecfc50 /sysdeps/mach | |
parent | 22a1292a42facff7597f3336a91eea57db9709e6 (diff) | |
download | glibc-3c46a92d403c3c72ab99169e056efdb04ddc4f15.zip glibc-3c46a92d403c3c72ab99169e056efdb04ddc4f15.tar.gz glibc-3c46a92d403c3c72ab99169e056efdb04ddc4f15.tar.bz2 |
Sat Feb 25 02:17:52 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu>
* sysdeps/mach/hurd/kill.c: When the process has no message port
registered and we have its task port, translate a few signals to
task_suspend/task_resume/task_terminate.
Diffstat (limited to 'sysdeps/mach')
-rw-r--r-- | sysdeps/mach/hurd/kill.c | 50 |
1 files changed, 44 insertions, 6 deletions
diff --git a/sysdeps/mach/hurd/kill.c b/sysdeps/mach/hurd/kill.c index 0d4af62..a6abdc5 100644 --- a/sysdeps/mach/hurd/kill.c +++ b/sysdeps/mach/hurd/kill.c @@ -37,6 +37,8 @@ __kill (pid_t pid, int sig) inline void kill_pid (pid_t pid) /* Kill one PID. */ { + + /* SIGKILL is not delivered as a normal signal. Sending SIGKILL to a process means to terminate its task. */ if (sig == SIGKILL) @@ -58,12 +60,48 @@ __kill (pid_t pid, int sig) } while (err == MACH_SEND_INVALID_DEST || err == MIG_SERVER_DIED); else - err = HURD_MSGPORT_RPC (__proc_getmsgport (proc, pid, &msgport), - __proc_pid2task (proc, pid, &refport) ? - __proc_getsidport (proc, &refport) : 0, 1, - /* If no msgport, we cannot send a signal. */ - msgport == MACH_PORT_NULL ? EPERM : - __msg_sig_post (msgport, sig, refport)); + { + error_t taskerr; + error_t kill_port (mach_port_t msgport, mach_port_t refport) + { + if (msgport != MACH_PORT_NULL) + /* Send a signal message to his message port. */ + return __msg_sig_post (msgport, sig, refport); + + /* The process has no message port. Perhaps try direct + frobnication of the task. */ + + if (taskerr) + /* If we could not get the task port, we can do nothing. */ + return taskerr; + + /* For user convenience in the case of a task that has + not registered any message port with the proc server, + translate a few signals to direct task operations. */ + switch (sig) + { + /* The only signals that really make sense for an + unregistered task are kill, suspend, and continue. */ + case SIGSTOP: + case SIGTSTP: + return __task_suspend (refport); + case SIGCONT: + return __task_resume (refport); + case SIGQUIT: + case SIGINT: + return __task_terminate (refport); + default: + /* We have full permission to send signals, but there is + no meaningful way to express this signal. */ + return EPERM; + } + } + err = HURD_MSGPORT_RPC (__proc_getmsgport (proc, pid, &msgport), + (taskerr = __proc_pid2task (proc, pid, + &refport)) ? + __proc_getsidport (proc, &refport) : 0, 1, + kill_port (msgport, refport)); + } if (! err) delivered = 1; } |