提交 2bd61579 编写于 作者: T Trond Myklebust

SUNRPC: Ensure that SIGKILL will always terminate a synchronous RPC call.

 ...and make sure that the "intr" flag also enables SIGHUP and SIGTERM to
 interrupt RPC calls too (as per the Solaris implementation).
Signed-off-by: NTrond Myklebust <Trond.Myklebust@netapp.com>
上级 fe650407
...@@ -178,6 +178,8 @@ lockd(struct svc_rqst *rqstp) ...@@ -178,6 +178,8 @@ lockd(struct svc_rqst *rqstp)
} }
flush_signals(current);
/* /*
* Check whether there's a new lockd process before * Check whether there's a new lockd process before
* shutting down the hosts and clearing the slot. * shutting down the hosts and clearing the slot.
...@@ -192,8 +194,6 @@ lockd(struct svc_rqst *rqstp) ...@@ -192,8 +194,6 @@ lockd(struct svc_rqst *rqstp)
"lockd: new process, skipping host shutdown\n"); "lockd: new process, skipping host shutdown\n");
wake_up(&lockd_exit); wake_up(&lockd_exit);
flush_signals(current);
/* Exit the RPC thread */ /* Exit the RPC thread */
svc_exit_thread(rqstp); svc_exit_thread(rqstp);
......
...@@ -386,11 +386,11 @@ static const struct rpc_call_ops rpc_default_ops = { ...@@ -386,11 +386,11 @@ static const struct rpc_call_ops rpc_default_ops = {
* Export the signal mask handling for synchronous code that * Export the signal mask handling for synchronous code that
* sleeps on RPC calls * sleeps on RPC calls
*/ */
#define RPC_INTR_SIGNALS (sigmask(SIGINT) | sigmask(SIGQUIT) | sigmask(SIGKILL)) #define RPC_INTR_SIGNALS (sigmask(SIGHUP) | sigmask(SIGINT) | sigmask(SIGQUIT) | sigmask(SIGTERM))
static void rpc_save_sigmask(sigset_t *oldset, int intr) static void rpc_save_sigmask(sigset_t *oldset, int intr)
{ {
unsigned long sigallow = 0; unsigned long sigallow = sigmask(SIGKILL);
sigset_t sigmask; sigset_t sigmask;
/* Block all signals except those listed in sigallow */ /* Block all signals except those listed in sigallow */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部