blob: 9ca8e5278c8e74bcc1d8f8cbcc91dc399a489e4b [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/kernel/signal.c
3 *
4 * Copyright (C) 1991, 1992 Linus Torvalds
5 *
6 * 1997-11-02 Modified for POSIX.1b signals by Richard Henderson
7 *
8 * 2003-06-02 Jim Houston - Concurrent Computer Corp.
9 * Changes to use preallocated sigqueue structures
10 * to allow signals to be sent reliably.
11 */
12
Linus Torvalds1da177e2005-04-16 15:20:36 -070013#include <linux/slab.h>
Paul Gortmaker9984de12011-05-23 14:51:41 -040014#include <linux/export.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070015#include <linux/init.h>
Ingo Molnar589ee622017-02-04 00:16:44 +010016#include <linux/sched/mm.h>
Ingo Molnar8703e8a2017-02-08 18:51:30 +010017#include <linux/sched/user.h>
Ingo Molnarb17b0152017-02-08 18:51:35 +010018#include <linux/sched/debug.h>
Ingo Molnar29930022017-02-08 18:51:36 +010019#include <linux/sched/task.h>
Ingo Molnar68db0cf2017-02-08 18:51:37 +010020#include <linux/sched/task_stack.h>
Ingo Molnar32ef5512017-02-05 11:48:36 +010021#include <linux/sched/cputime.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070022#include <linux/fs.h>
23#include <linux/tty.h>
24#include <linux/binfmts.h>
Alex Kelly179899f2012-10-04 17:15:24 -070025#include <linux/coredump.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070026#include <linux/security.h>
27#include <linux/syscalls.h>
28#include <linux/ptrace.h>
Jesper Juhl7ed20e12005-05-01 08:59:14 -070029#include <linux/signal.h>
Davide Libenzifba2afa2007-05-10 22:23:13 -070030#include <linux/signalfd.h>
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +090031#include <linux/ratelimit.h>
Roland McGrath35de2542008-07-25 19:45:51 -070032#include <linux/tracehook.h>
Randy.Dunlapc59ede72006-01-11 12:17:46 -080033#include <linux/capability.h>
Nigel Cunningham7dfb7102006-12-06 20:34:23 -080034#include <linux/freezer.h>
Sukadev Bhattiprolu84d73782006-12-08 02:38:01 -080035#include <linux/pid_namespace.h>
36#include <linux/nsproxy.h>
Serge E. Hallyn6b550f92012-01-10 15:11:37 -080037#include <linux/user_namespace.h>
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +053038#include <linux/uprobes.h>
Al Viro90268432012-12-14 14:47:53 -050039#include <linux/compat.h>
Jesper Derehag2b5faa42013-03-19 20:50:05 +000040#include <linux/cn_proc.h>
Gideon Israel Dsouza52f5684c2014-04-07 15:39:20 -070041#include <linux/compiler.h>
Christoph Hellwig31ea70e2017-06-03 21:01:00 +020042#include <linux/posix-timers.h>
Miroslav Benes43347d52017-11-15 14:50:13 +010043#include <linux/livepatch.h>
Gideon Israel Dsouza52f5684c2014-04-07 15:39:20 -070044
Masami Hiramatsud1eb6502009-11-24 16:56:45 -050045#define CREATE_TRACE_POINTS
46#include <trace/events/signal.h>
Sukadev Bhattiprolu84d73782006-12-08 02:38:01 -080047
Linus Torvalds1da177e2005-04-16 15:20:36 -070048#include <asm/param.h>
Linus Torvalds7c0f6ba2016-12-24 11:46:01 -080049#include <linux/uaccess.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070050#include <asm/unistd.h>
51#include <asm/siginfo.h>
David Howellsd550bbd2012-03-28 18:30:03 +010052#include <asm/cacheflush.h>
Al Viroe1396062006-05-25 10:19:47 -040053#include "audit.h" /* audit_signal_info() */
Linus Torvalds1da177e2005-04-16 15:20:36 -070054
55/*
56 * SLAB caches for signal bits.
57 */
58
Christoph Lametere18b8902006-12-06 20:33:20 -080059static struct kmem_cache *sigqueue_cachep;
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +090061int print_fatal_signals __read_mostly;
62
Roland McGrath35de2542008-07-25 19:45:51 -070063static void __user *sig_handler(struct task_struct *t, int sig)
Pavel Emelyanov93585ee2008-04-30 00:52:39 -070064{
Roland McGrath35de2542008-07-25 19:45:51 -070065 return t->sighand->action[sig - 1].sa.sa_handler;
66}
Pavel Emelyanov93585ee2008-04-30 00:52:39 -070067
Christian Braunere4a8b4e2018-08-21 22:00:15 -070068static inline bool sig_handler_ignored(void __user *handler, int sig)
Roland McGrath35de2542008-07-25 19:45:51 -070069{
Pavel Emelyanov93585ee2008-04-30 00:52:39 -070070 /* Is it explicitly or implicitly ignored? */
Pavel Emelyanov93585ee2008-04-30 00:52:39 -070071 return handler == SIG_IGN ||
Christian Braunere4a8b4e2018-08-21 22:00:15 -070072 (handler == SIG_DFL && sig_kernel_ignore(sig));
Pavel Emelyanov93585ee2008-04-30 00:52:39 -070073}
Linus Torvalds1da177e2005-04-16 15:20:36 -070074
Christian Brauner41aaa482018-08-21 22:00:19 -070075static bool sig_task_ignored(struct task_struct *t, int sig, bool force)
Linus Torvalds1da177e2005-04-16 15:20:36 -070076{
Roland McGrath35de2542008-07-25 19:45:51 -070077 void __user *handler;
Linus Torvalds1da177e2005-04-16 15:20:36 -070078
Oleg Nesterovf008faf2009-04-02 16:58:02 -070079 handler = sig_handler(t, sig);
80
Eric W. Biederman86989c42018-07-19 19:47:27 -050081 /* SIGKILL and SIGSTOP may not be sent to the global init */
82 if (unlikely(is_global_init(t) && sig_kernel_only(sig)))
83 return true;
84
Oleg Nesterovf008faf2009-04-02 16:58:02 -070085 if (unlikely(t->signal->flags & SIGNAL_UNKILLABLE) &&
Oleg Nesterovac253852017-11-17 15:30:04 -080086 handler == SIG_DFL && !(force && sig_kernel_only(sig)))
Christian Brauner41aaa482018-08-21 22:00:19 -070087 return true;
Oleg Nesterovf008faf2009-04-02 16:58:02 -070088
89 return sig_handler_ignored(handler, sig);
90}
91
Christian Brauner6a0cdcd2018-08-21 22:00:23 -070092static bool sig_ignored(struct task_struct *t, int sig, bool force)
Oleg Nesterovf008faf2009-04-02 16:58:02 -070093{
Linus Torvalds1da177e2005-04-16 15:20:36 -070094 /*
95 * Blocked signals are never ignored, since the
96 * signal handler may change by the time it is
97 * unblocked.
98 */
Roland McGrath325d22d2007-11-12 15:41:55 -080099 if (sigismember(&t->blocked, sig) || sigismember(&t->real_blocked, sig))
Christian Brauner6a0cdcd2018-08-21 22:00:23 -0700100 return false;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700101
Oleg Nesterov628c1bc2017-11-17 15:30:01 -0800102 /*
103 * Tracers may want to know about even ignored signal unless it
104 * is SIGKILL which can't be reported anyway but can be ignored
105 * by SIGNAL_UNKILLABLE task.
106 */
107 if (t->ptrace && sig != SIGKILL)
Christian Brauner6a0cdcd2018-08-21 22:00:23 -0700108 return false;
Roland McGrath35de2542008-07-25 19:45:51 -0700109
Oleg Nesterov628c1bc2017-11-17 15:30:01 -0800110 return sig_task_ignored(t, sig, force);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700111}
112
113/*
114 * Re-calculate pending state from the set of locally pending
115 * signals, globally pending signals, and blocked signals.
116 */
Christian Brauner938696a2018-08-21 22:00:27 -0700117static inline bool has_pending_signals(sigset_t *signal, sigset_t *blocked)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700118{
119 unsigned long ready;
120 long i;
121
122 switch (_NSIG_WORDS) {
123 default:
124 for (i = _NSIG_WORDS, ready = 0; --i >= 0 ;)
125 ready |= signal->sig[i] &~ blocked->sig[i];
126 break;
127
128 case 4: ready = signal->sig[3] &~ blocked->sig[3];
129 ready |= signal->sig[2] &~ blocked->sig[2];
130 ready |= signal->sig[1] &~ blocked->sig[1];
131 ready |= signal->sig[0] &~ blocked->sig[0];
132 break;
133
134 case 2: ready = signal->sig[1] &~ blocked->sig[1];
135 ready |= signal->sig[0] &~ blocked->sig[0];
136 break;
137
138 case 1: ready = signal->sig[0] &~ blocked->sig[0];
139 }
140 return ready != 0;
141}
142
143#define PENDING(p,b) has_pending_signals(&(p)->signal, (b))
144
Christian Brauner09ae8542018-08-21 22:00:30 -0700145static bool recalc_sigpending_tsk(struct task_struct *t)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700146{
Tejun Heo3759a0d2011-06-02 11:14:00 +0200147 if ((t->jobctl & JOBCTL_PENDING_MASK) ||
Linus Torvalds1da177e2005-04-16 15:20:36 -0700148 PENDING(&t->pending, &t->blocked) ||
Roland McGrath7bb44ad2007-05-23 13:57:44 -0700149 PENDING(&t->signal->shared_pending, &t->blocked)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700150 set_tsk_thread_flag(t, TIF_SIGPENDING);
Christian Brauner09ae8542018-08-21 22:00:30 -0700151 return true;
Roland McGrath7bb44ad2007-05-23 13:57:44 -0700152 }
Christian Brauner09ae8542018-08-21 22:00:30 -0700153
Roland McGrathb74d0de2007-06-06 03:59:00 -0700154 /*
155 * We must never clear the flag in another thread, or in current
156 * when it's possible the current syscall is returning -ERESTART*.
157 * So we don't clear it here, and only callers who know they should do.
158 */
Christian Brauner09ae8542018-08-21 22:00:30 -0700159 return false;
Roland McGrath7bb44ad2007-05-23 13:57:44 -0700160}
161
162/*
163 * After recalculating TIF_SIGPENDING, we need to make sure the task wakes up.
164 * This is superfluous when called on current, the wakeup is a harmless no-op.
165 */
166void recalc_sigpending_and_wake(struct task_struct *t)
167{
168 if (recalc_sigpending_tsk(t))
169 signal_wake_up(t, 0);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700170}
171
172void recalc_sigpending(void)
173{
Miroslav Benes43347d52017-11-15 14:50:13 +0100174 if (!recalc_sigpending_tsk(current) && !freezing(current) &&
175 !klp_patch_pending(current))
Roland McGrathb74d0de2007-06-06 03:59:00 -0700176 clear_thread_flag(TIF_SIGPENDING);
177
Linus Torvalds1da177e2005-04-16 15:20:36 -0700178}
Eric W. Biedermanfb50f5a2018-09-13 19:26:35 +0200179EXPORT_SYMBOL(recalc_sigpending);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700180
Eric W. Biederman088fe472018-07-23 17:26:49 -0500181void calculate_sigpending(void)
182{
183 /* Have any signals or users of TIF_SIGPENDING been delayed
184 * until after fork?
185 */
186 spin_lock_irq(&current->sighand->siglock);
187 set_tsk_thread_flag(current, TIF_SIGPENDING);
188 recalc_sigpending();
189 spin_unlock_irq(&current->sighand->siglock);
190}
191
Linus Torvalds1da177e2005-04-16 15:20:36 -0700192/* Given the mask, find the first available signal that should be serviced. */
193
Linus Torvaldsa27341c2010-03-02 08:36:46 -0800194#define SYNCHRONOUS_MASK \
195 (sigmask(SIGSEGV) | sigmask(SIGBUS) | sigmask(SIGILL) | \
Will Drewrya0727e82012-04-12 16:48:00 -0500196 sigmask(SIGTRAP) | sigmask(SIGFPE) | sigmask(SIGSYS))
Linus Torvaldsa27341c2010-03-02 08:36:46 -0800197
Davide Libenzifba2afa2007-05-10 22:23:13 -0700198int next_signal(struct sigpending *pending, sigset_t *mask)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700199{
200 unsigned long i, *s, *m, x;
201 int sig = 0;
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +0900202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700203 s = pending->signal.sig;
204 m = mask->sig;
Linus Torvaldsa27341c2010-03-02 08:36:46 -0800205
206 /*
207 * Handle the first word specially: it contains the
208 * synchronous signals that need to be dequeued first.
209 */
210 x = *s &~ *m;
211 if (x) {
212 if (x & SYNCHRONOUS_MASK)
213 x &= SYNCHRONOUS_MASK;
214 sig = ffz(~x) + 1;
215 return sig;
216 }
217
Linus Torvalds1da177e2005-04-16 15:20:36 -0700218 switch (_NSIG_WORDS) {
219 default:
Linus Torvaldsa27341c2010-03-02 08:36:46 -0800220 for (i = 1; i < _NSIG_WORDS; ++i) {
221 x = *++s &~ *++m;
222 if (!x)
223 continue;
224 sig = ffz(~x) + i*_NSIG_BPW + 1;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700225 break;
Linus Torvaldsa27341c2010-03-02 08:36:46 -0800226 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700227 break;
228
Linus Torvaldsa27341c2010-03-02 08:36:46 -0800229 case 2:
230 x = s[1] &~ m[1];
231 if (!x)
232 break;
233 sig = ffz(~x) + _NSIG_BPW + 1;
234 break;
235
236 case 1:
237 /* Nothing to do */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700238 break;
239 }
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +0900240
Linus Torvalds1da177e2005-04-16 15:20:36 -0700241 return sig;
242}
243
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +0900244static inline void print_dropped_signal(int sig)
245{
246 static DEFINE_RATELIMIT_STATE(ratelimit_state, 5 * HZ, 10);
247
248 if (!print_fatal_signals)
249 return;
250
251 if (!__ratelimit(&ratelimit_state))
252 return;
253
Wang Xiaoqiang747800e2016-05-23 16:23:59 -0700254 pr_info("%s/%d: reached RLIMIT_SIGPENDING, dropped signal %d\n",
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +0900255 current->comm, current->pid, sig);
256}
257
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100258/**
Tejun Heo7dd3db52011-06-02 11:14:00 +0200259 * task_set_jobctl_pending - set jobctl pending bits
260 * @task: target task
261 * @mask: pending bits to set
262 *
263 * Clear @mask from @task->jobctl. @mask must be subset of
264 * %JOBCTL_PENDING_MASK | %JOBCTL_STOP_CONSUME | %JOBCTL_STOP_SIGMASK |
265 * %JOBCTL_TRAPPING. If stop signo is being set, the existing signo is
266 * cleared. If @task is already being killed or exiting, this function
267 * becomes noop.
268 *
269 * CONTEXT:
270 * Must be called with @task->sighand->siglock held.
271 *
272 * RETURNS:
273 * %true if @mask is set, %false if made noop because @task was dying.
274 */
Palmer Dabbeltb76808e2015-04-30 21:19:57 -0700275bool task_set_jobctl_pending(struct task_struct *task, unsigned long mask)
Tejun Heo7dd3db52011-06-02 11:14:00 +0200276{
277 BUG_ON(mask & ~(JOBCTL_PENDING_MASK | JOBCTL_STOP_CONSUME |
278 JOBCTL_STOP_SIGMASK | JOBCTL_TRAPPING));
279 BUG_ON((mask & JOBCTL_TRAPPING) && !(mask & JOBCTL_PENDING_MASK));
280
281 if (unlikely(fatal_signal_pending(task) || (task->flags & PF_EXITING)))
282 return false;
283
284 if (mask & JOBCTL_STOP_SIGMASK)
285 task->jobctl &= ~JOBCTL_STOP_SIGMASK;
286
287 task->jobctl |= mask;
288 return true;
289}
290
291/**
Tejun Heoa8f072c2011-06-02 11:13:59 +0200292 * task_clear_jobctl_trapping - clear jobctl trapping bit
Tejun Heod79fdd62011-03-23 10:37:00 +0100293 * @task: target task
294 *
Tejun Heoa8f072c2011-06-02 11:13:59 +0200295 * If JOBCTL_TRAPPING is set, a ptracer is waiting for us to enter TRACED.
296 * Clear it and wake up the ptracer. Note that we don't need any further
297 * locking. @task->siglock guarantees that @task->parent points to the
298 * ptracer.
Tejun Heod79fdd62011-03-23 10:37:00 +0100299 *
300 * CONTEXT:
301 * Must be called with @task->sighand->siglock held.
302 */
Tejun Heo73ddff22011-06-14 11:20:14 +0200303void task_clear_jobctl_trapping(struct task_struct *task)
Tejun Heod79fdd62011-03-23 10:37:00 +0100304{
Tejun Heoa8f072c2011-06-02 11:13:59 +0200305 if (unlikely(task->jobctl & JOBCTL_TRAPPING)) {
306 task->jobctl &= ~JOBCTL_TRAPPING;
Oleg Nesterov650226b2014-06-06 14:36:44 -0700307 smp_mb(); /* advised by wake_up_bit() */
Tejun Heo62c124f2011-06-02 11:14:00 +0200308 wake_up_bit(&task->jobctl, JOBCTL_TRAPPING_BIT);
Tejun Heod79fdd62011-03-23 10:37:00 +0100309 }
310}
311
312/**
Tejun Heo3759a0d2011-06-02 11:14:00 +0200313 * task_clear_jobctl_pending - clear jobctl pending bits
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100314 * @task: target task
Tejun Heo3759a0d2011-06-02 11:14:00 +0200315 * @mask: pending bits to clear
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100316 *
Tejun Heo3759a0d2011-06-02 11:14:00 +0200317 * Clear @mask from @task->jobctl. @mask must be subset of
318 * %JOBCTL_PENDING_MASK. If %JOBCTL_STOP_PENDING is being cleared, other
319 * STOP bits are cleared together.
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100320 *
Tejun Heo6dfca322011-06-02 11:14:00 +0200321 * If clearing of @mask leaves no stop or trap pending, this function calls
322 * task_clear_jobctl_trapping().
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100323 *
324 * CONTEXT:
325 * Must be called with @task->sighand->siglock held.
326 */
Palmer Dabbeltb76808e2015-04-30 21:19:57 -0700327void task_clear_jobctl_pending(struct task_struct *task, unsigned long mask)
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100328{
Tejun Heo3759a0d2011-06-02 11:14:00 +0200329 BUG_ON(mask & ~JOBCTL_PENDING_MASK);
330
331 if (mask & JOBCTL_STOP_PENDING)
332 mask |= JOBCTL_STOP_CONSUME | JOBCTL_STOP_DEQUEUED;
333
334 task->jobctl &= ~mask;
Tejun Heo6dfca322011-06-02 11:14:00 +0200335
336 if (!(task->jobctl & JOBCTL_PENDING_MASK))
337 task_clear_jobctl_trapping(task);
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100338}
339
340/**
341 * task_participate_group_stop - participate in a group stop
342 * @task: task participating in a group stop
343 *
Tejun Heoa8f072c2011-06-02 11:13:59 +0200344 * @task has %JOBCTL_STOP_PENDING set and is participating in a group stop.
Tejun Heo39efa3e2011-03-23 10:37:00 +0100345 * Group stop states are cleared and the group stop count is consumed if
Tejun Heoa8f072c2011-06-02 11:13:59 +0200346 * %JOBCTL_STOP_CONSUME was set. If the consumption completes the group
Tejun Heo39efa3e2011-03-23 10:37:00 +0100347 * stop, the appropriate %SIGNAL_* flags are set.
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100348 *
349 * CONTEXT:
350 * Must be called with @task->sighand->siglock held.
Tejun Heo244056f2011-03-23 10:37:01 +0100351 *
352 * RETURNS:
353 * %true if group stop completion should be notified to the parent, %false
354 * otherwise.
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100355 */
356static bool task_participate_group_stop(struct task_struct *task)
357{
358 struct signal_struct *sig = task->signal;
Tejun Heoa8f072c2011-06-02 11:13:59 +0200359 bool consume = task->jobctl & JOBCTL_STOP_CONSUME;
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100360
Tejun Heoa8f072c2011-06-02 11:13:59 +0200361 WARN_ON_ONCE(!(task->jobctl & JOBCTL_STOP_PENDING));
Tejun Heo39efa3e2011-03-23 10:37:00 +0100362
Tejun Heo3759a0d2011-06-02 11:14:00 +0200363 task_clear_jobctl_pending(task, JOBCTL_STOP_PENDING);
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100364
365 if (!consume)
366 return false;
367
368 if (!WARN_ON_ONCE(sig->group_stop_count == 0))
369 sig->group_stop_count--;
370
Tejun Heo244056f2011-03-23 10:37:01 +0100371 /*
372 * Tell the caller to notify completion iff we are entering into a
373 * fresh group stop. Read comment in do_signal_stop() for details.
374 */
375 if (!sig->group_stop_count && !(sig->flags & SIGNAL_STOP_STOPPED)) {
Jamie Iles2d39b3c2017-01-10 16:57:54 -0800376 signal_set_stop_flags(sig, SIGNAL_STOP_STOPPED);
Tejun Heoe5c1902e2011-03-23 10:37:00 +0100377 return true;
378 }
379 return false;
380}
381
Eric W. Biederman924de3b2018-07-23 13:38:00 -0500382void task_join_group_stop(struct task_struct *task)
383{
384 /* Have the new thread join an on-going signal group stop */
385 unsigned long jobctl = current->jobctl;
386 if (jobctl & JOBCTL_STOP_PENDING) {
387 struct signal_struct *sig = current->signal;
388 unsigned long signr = jobctl & JOBCTL_STOP_SIGMASK;
389 unsigned long gstop = JOBCTL_STOP_PENDING | JOBCTL_STOP_CONSUME;
390 if (task_set_jobctl_pending(task, signr | gstop)) {
391 sig->group_stop_count++;
392 }
393 }
394}
395
David Howellsc69e8d92008-11-14 10:39:19 +1100396/*
397 * allocate a new signal queue record
398 * - this may be called without locks if and only if t == current, otherwise an
Randy Dunlap5aba0852011-04-04 14:59:31 -0700399 * appropriate lock must be held to stop the target task from exiting
David Howellsc69e8d92008-11-14 10:39:19 +1100400 */
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +0900401static struct sigqueue *
402__sigqueue_alloc(int sig, struct task_struct *t, gfp_t flags, int override_rlimit)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700403{
404 struct sigqueue *q = NULL;
Linus Torvalds10b1fbd2006-11-04 13:03:00 -0800405 struct user_struct *user;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700406
Linus Torvalds10b1fbd2006-11-04 13:03:00 -0800407 /*
Thomas Gleixner7cf7db82009-12-10 00:53:21 +0000408 * Protect access to @t credentials. This can go away when all
409 * callers hold rcu read lock.
Linus Torvalds10b1fbd2006-11-04 13:03:00 -0800410 */
Thomas Gleixner7cf7db82009-12-10 00:53:21 +0000411 rcu_read_lock();
David Howellsd84f4f92008-11-14 10:39:23 +1100412 user = get_uid(__task_cred(t)->user);
Linus Torvalds10b1fbd2006-11-04 13:03:00 -0800413 atomic_inc(&user->sigpending);
Thomas Gleixner7cf7db82009-12-10 00:53:21 +0000414 rcu_read_unlock();
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +0900415
Linus Torvalds1da177e2005-04-16 15:20:36 -0700416 if (override_rlimit ||
Linus Torvalds10b1fbd2006-11-04 13:03:00 -0800417 atomic_read(&user->sigpending) <=
Jiri Slaby78d7d402010-03-05 13:42:54 -0800418 task_rlimit(t, RLIMIT_SIGPENDING)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700419 q = kmem_cache_alloc(sigqueue_cachep, flags);
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +0900420 } else {
421 print_dropped_signal(sig);
422 }
423
Linus Torvalds1da177e2005-04-16 15:20:36 -0700424 if (unlikely(q == NULL)) {
Linus Torvalds10b1fbd2006-11-04 13:03:00 -0800425 atomic_dec(&user->sigpending);
David Howellsd84f4f92008-11-14 10:39:23 +1100426 free_uid(user);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700427 } else {
428 INIT_LIST_HEAD(&q->list);
429 q->flags = 0;
David Howellsd84f4f92008-11-14 10:39:23 +1100430 q->user = user;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700431 }
David Howellsd84f4f92008-11-14 10:39:23 +1100432
433 return q;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700434}
435
Andrew Morton514a01b2006-02-03 03:04:41 -0800436static void __sigqueue_free(struct sigqueue *q)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700437{
438 if (q->flags & SIGQUEUE_PREALLOC)
439 return;
440 atomic_dec(&q->user->sigpending);
441 free_uid(q->user);
442 kmem_cache_free(sigqueue_cachep, q);
443}
444
Oleg Nesterov6a14c5c2006-03-28 16:11:18 -0800445void flush_sigqueue(struct sigpending *queue)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700446{
447 struct sigqueue *q;
448
449 sigemptyset(&queue->signal);
450 while (!list_empty(&queue->list)) {
451 q = list_entry(queue->list.next, struct sigqueue , list);
452 list_del_init(&q->list);
453 __sigqueue_free(q);
454 }
455}
456
457/*
Oleg Nesterov9e7c8f82015-06-04 16:22:16 -0400458 * Flush all pending signals for this kthread.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700459 */
Oleg Nesterovc81addc2006-03-28 16:11:17 -0800460void flush_signals(struct task_struct *t)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700461{
462 unsigned long flags;
463
464 spin_lock_irqsave(&t->sighand->siglock, flags);
Oleg Nesterov9e7c8f82015-06-04 16:22:16 -0400465 clear_tsk_thread_flag(t, TIF_SIGPENDING);
466 flush_sigqueue(&t->pending);
467 flush_sigqueue(&t->signal->shared_pending);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700468 spin_unlock_irqrestore(&t->sighand->siglock, flags);
469}
Eric W. Biedermanfb50f5a2018-09-13 19:26:35 +0200470EXPORT_SYMBOL(flush_signals);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700471
Nicolas Pitrebaa73d92016-11-11 00:10:10 -0500472#ifdef CONFIG_POSIX_TIMERS
Oleg Nesterovcbaffba2008-05-26 20:55:42 +0400473static void __flush_itimer_signals(struct sigpending *pending)
474{
475 sigset_t signal, retain;
476 struct sigqueue *q, *n;
477
478 signal = pending->signal;
479 sigemptyset(&retain);
480
481 list_for_each_entry_safe(q, n, &pending->list, list) {
482 int sig = q->info.si_signo;
483
484 if (likely(q->info.si_code != SI_TIMER)) {
485 sigaddset(&retain, sig);
486 } else {
487 sigdelset(&signal, sig);
488 list_del_init(&q->list);
489 __sigqueue_free(q);
490 }
491 }
492
493 sigorsets(&pending->signal, &signal, &retain);
494}
495
496void flush_itimer_signals(void)
497{
498 struct task_struct *tsk = current;
499 unsigned long flags;
500
501 spin_lock_irqsave(&tsk->sighand->siglock, flags);
502 __flush_itimer_signals(&tsk->pending);
503 __flush_itimer_signals(&tsk->signal->shared_pending);
504 spin_unlock_irqrestore(&tsk->sighand->siglock, flags);
505}
Nicolas Pitrebaa73d92016-11-11 00:10:10 -0500506#endif
Oleg Nesterovcbaffba2008-05-26 20:55:42 +0400507
Oleg Nesterov10ab8252007-05-09 02:34:37 -0700508void ignore_signals(struct task_struct *t)
509{
510 int i;
511
512 for (i = 0; i < _NSIG; ++i)
513 t->sighand->action[i].sa.sa_handler = SIG_IGN;
514
515 flush_signals(t);
516}
517
Linus Torvalds1da177e2005-04-16 15:20:36 -0700518/*
Linus Torvalds1da177e2005-04-16 15:20:36 -0700519 * Flush all handlers for a task.
520 */
521
522void
523flush_signal_handlers(struct task_struct *t, int force_default)
524{
525 int i;
526 struct k_sigaction *ka = &t->sighand->action[0];
527 for (i = _NSIG ; i != 0 ; i--) {
528 if (force_default || ka->sa.sa_handler != SIG_IGN)
529 ka->sa.sa_handler = SIG_DFL;
530 ka->sa.sa_flags = 0;
Andrew Morton522cff12013-03-13 14:59:34 -0700531#ifdef __ARCH_HAS_SA_RESTORER
Kees Cook2ca39522013-03-13 14:59:33 -0700532 ka->sa.sa_restorer = NULL;
533#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -0700534 sigemptyset(&ka->sa.sa_mask);
535 ka++;
536 }
537}
538
Christian Brauner67a48a22018-08-21 22:00:34 -0700539bool unhandled_signal(struct task_struct *tsk, int sig)
Masoud Asgharifard Sharbianiabd4f752007-07-22 11:12:28 +0200540{
Roland McGrath445a91d2008-07-25 19:45:52 -0700541 void __user *handler = tsk->sighand->action[sig-1].sa.sa_handler;
Serge E. Hallynb460cbc2007-10-18 23:39:52 -0700542 if (is_global_init(tsk))
Christian Brauner67a48a22018-08-21 22:00:34 -0700543 return true;
544
Roland McGrath445a91d2008-07-25 19:45:52 -0700545 if (handler != SIG_IGN && handler != SIG_DFL)
Christian Brauner67a48a22018-08-21 22:00:34 -0700546 return false;
547
Tejun Heoa288eec2011-06-17 16:50:37 +0200548 /* if ptraced, let the tracer determine */
549 return !tsk->ptrace;
Masoud Asgharifard Sharbianiabd4f752007-07-22 11:12:28 +0200550}
551
Eric W. Biedermanae7795b2018-09-25 11:27:20 +0200552static void collect_signal(int sig, struct sigpending *list, kernel_siginfo_t *info,
Eric W. Biederman57db7e42017-06-13 04:31:16 -0500553 bool *resched_timer)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700554{
555 struct sigqueue *q, *first = NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700556
Linus Torvalds1da177e2005-04-16 15:20:36 -0700557 /*
558 * Collect the siginfo appropriate to this signal. Check if
559 * there is another siginfo for the same signal.
560 */
561 list_for_each_entry(q, &list->list, list) {
562 if (q->info.si_signo == sig) {
Oleg Nesterovd4434202008-07-25 01:47:28 -0700563 if (first)
564 goto still_pending;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700565 first = q;
566 }
567 }
Oleg Nesterovd4434202008-07-25 01:47:28 -0700568
569 sigdelset(&list->signal, sig);
570
Linus Torvalds1da177e2005-04-16 15:20:36 -0700571 if (first) {
Oleg Nesterovd4434202008-07-25 01:47:28 -0700572still_pending:
Linus Torvalds1da177e2005-04-16 15:20:36 -0700573 list_del_init(&first->list);
574 copy_siginfo(info, &first->info);
Eric W. Biederman57db7e42017-06-13 04:31:16 -0500575
576 *resched_timer =
577 (first->flags & SIGQUEUE_PREALLOC) &&
578 (info->si_code == SI_TIMER) &&
579 (info->si_sys_private);
580
Linus Torvalds1da177e2005-04-16 15:20:36 -0700581 __sigqueue_free(first);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700582 } else {
Randy Dunlap5aba0852011-04-04 14:59:31 -0700583 /*
584 * Ok, it wasn't in the queue. This must be
585 * a fast-pathed signal or we must have been
586 * out of queue space. So zero out the info.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700587 */
Eric W. Biedermanfaf1f222018-01-05 17:27:42 -0600588 clear_siginfo(info);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700589 info->si_signo = sig;
590 info->si_errno = 0;
Oleg Nesterov7486e5d2009-12-15 16:47:24 -0800591 info->si_code = SI_USER;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700592 info->si_pid = 0;
593 info->si_uid = 0;
594 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700595}
596
597static int __dequeue_signal(struct sigpending *pending, sigset_t *mask,
Eric W. Biedermanae7795b2018-09-25 11:27:20 +0200598 kernel_siginfo_t *info, bool *resched_timer)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700599{
Roland McGrath27d91e02006-09-29 02:00:31 -0700600 int sig = next_signal(pending, mask);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700601
Oleg Nesterov2e01fab2015-11-06 16:32:19 -0800602 if (sig)
Eric W. Biederman57db7e42017-06-13 04:31:16 -0500603 collect_signal(sig, pending, info, resched_timer);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700604 return sig;
605}
606
607/*
Randy Dunlap5aba0852011-04-04 14:59:31 -0700608 * Dequeue a signal and return the element to the caller, which is
Linus Torvalds1da177e2005-04-16 15:20:36 -0700609 * expected to free it.
610 *
611 * All callers have to hold the siglock.
612 */
Eric W. Biedermanae7795b2018-09-25 11:27:20 +0200613int dequeue_signal(struct task_struct *tsk, sigset_t *mask, kernel_siginfo_t *info)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700614{
Eric W. Biederman57db7e42017-06-13 04:31:16 -0500615 bool resched_timer = false;
Pavel Emelyanovc5363d02008-04-30 00:52:40 -0700616 int signr;
Benjamin Herrenschmidtcaec4e82007-06-12 08:16:18 +1000617
618 /* We only dequeue private signals from ourselves, we don't let
619 * signalfd steal them
620 */
Eric W. Biederman57db7e42017-06-13 04:31:16 -0500621 signr = __dequeue_signal(&tsk->pending, mask, info, &resched_timer);
Thomas Gleixner8bfd9a72007-02-16 01:28:12 -0800622 if (!signr) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700623 signr = __dequeue_signal(&tsk->signal->shared_pending,
Eric W. Biederman57db7e42017-06-13 04:31:16 -0500624 mask, info, &resched_timer);
Nicolas Pitrebaa73d92016-11-11 00:10:10 -0500625#ifdef CONFIG_POSIX_TIMERS
Thomas Gleixner8bfd9a72007-02-16 01:28:12 -0800626 /*
627 * itimer signal ?
628 *
629 * itimers are process shared and we restart periodic
630 * itimers in the signal delivery path to prevent DoS
631 * attacks in the high resolution timer case. This is
Randy Dunlap5aba0852011-04-04 14:59:31 -0700632 * compliant with the old way of self-restarting
Thomas Gleixner8bfd9a72007-02-16 01:28:12 -0800633 * itimers, as the SIGALRM is a legacy signal and only
634 * queued once. Changing the restart behaviour to
635 * restart the timer in the signal dequeue path is
636 * reducing the timer noise on heavy loaded !highres
637 * systems too.
638 */
639 if (unlikely(signr == SIGALRM)) {
640 struct hrtimer *tmr = &tsk->signal->real_timer;
641
642 if (!hrtimer_is_queued(tmr) &&
Thomas Gleixner2456e852016-12-25 11:38:40 +0100643 tsk->signal->it_real_incr != 0) {
Thomas Gleixner8bfd9a72007-02-16 01:28:12 -0800644 hrtimer_forward(tmr, tmr->base->get_time(),
645 tsk->signal->it_real_incr);
646 hrtimer_restart(tmr);
647 }
648 }
Nicolas Pitrebaa73d92016-11-11 00:10:10 -0500649#endif
Thomas Gleixner8bfd9a72007-02-16 01:28:12 -0800650 }
Pavel Emelyanovc5363d02008-04-30 00:52:40 -0700651
Davide Libenzib8fceee2007-09-20 12:40:16 -0700652 recalc_sigpending();
Pavel Emelyanovc5363d02008-04-30 00:52:40 -0700653 if (!signr)
654 return 0;
655
656 if (unlikely(sig_kernel_stop(signr))) {
Thomas Gleixner8bfd9a72007-02-16 01:28:12 -0800657 /*
658 * Set a marker that we have dequeued a stop signal. Our
659 * caller might release the siglock and then the pending
660 * stop signal it is about to process is no longer in the
661 * pending bitmasks, but must still be cleared by a SIGCONT
662 * (and overruled by a SIGKILL). So those cases clear this
663 * shared flag after we've set it. Note that this flag may
664 * remain set after the signal we return is ignored or
665 * handled. That doesn't matter because its only purpose
666 * is to alert stop-signal processing code when another
667 * processor has come along and cleared the flag.
668 */
Tejun Heoa8f072c2011-06-02 11:13:59 +0200669 current->jobctl |= JOBCTL_STOP_DEQUEUED;
Thomas Gleixner8bfd9a72007-02-16 01:28:12 -0800670 }
Nicolas Pitrebaa73d92016-11-11 00:10:10 -0500671#ifdef CONFIG_POSIX_TIMERS
Eric W. Biederman57db7e42017-06-13 04:31:16 -0500672 if (resched_timer) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700673 /*
674 * Release the siglock to ensure proper locking order
675 * of timer locks outside of siglocks. Note, we leave
676 * irqs disabled here, since the posix-timers code is
677 * about to disable them again anyway.
678 */
679 spin_unlock(&tsk->sighand->siglock);
Thomas Gleixner96fe3b02017-05-30 23:15:46 +0200680 posixtimer_rearm(info);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700681 spin_lock(&tsk->sighand->siglock);
Eric W. Biederman9943d3a2017-07-24 14:53:03 -0500682
683 /* Don't expose the si_sys_private value to userspace */
684 info->si_sys_private = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700685 }
Nicolas Pitrebaa73d92016-11-11 00:10:10 -0500686#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -0700687 return signr;
688}
Eric W. Biedermanfb50f5a2018-09-13 19:26:35 +0200689EXPORT_SYMBOL_GPL(dequeue_signal);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700690
691/*
692 * Tell a process that it has a new active signal..
693 *
694 * NOTE! we rely on the previous spin_lock to
695 * lock interrupts for us! We can only be called with
696 * "siglock" held, and the local interrupt must
697 * have been disabled when that got acquired!
698 *
699 * No need to set need_resched since signal event passing
700 * goes through ->blocked
701 */
Oleg Nesterov910ffdb2013-01-21 20:47:41 +0100702void signal_wake_up_state(struct task_struct *t, unsigned int state)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700703{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700704 set_tsk_thread_flag(t, TIF_SIGPENDING);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700705 /*
Oleg Nesterov910ffdb2013-01-21 20:47:41 +0100706 * TASK_WAKEKILL also means wake it up in the stopped/traced/killable
Matthew Wilcoxf021a3c2007-12-06 11:13:16 -0500707 * case. We don't check t->state here because there is a race with it
Linus Torvalds1da177e2005-04-16 15:20:36 -0700708 * executing another processor and just now entering stopped state.
709 * By using wake_up_state, we ensure the process will wake up and
710 * handle its death signal.
711 */
Oleg Nesterov910ffdb2013-01-21 20:47:41 +0100712 if (!wake_up_state(t, state | TASK_INTERRUPTIBLE))
Linus Torvalds1da177e2005-04-16 15:20:36 -0700713 kick_process(t);
714}
715
716/*
717 * Remove signals in mask from the pending set and queue.
718 * Returns 1 if any signals were found.
719 *
720 * All callers must be holding the siglock.
George Anzinger71fabd52006-01-08 01:02:48 -0800721 */
Christian Brauner8f113512018-08-21 22:00:38 -0700722static void flush_sigqueue_mask(sigset_t *mask, struct sigpending *s)
George Anzinger71fabd52006-01-08 01:02:48 -0800723{
724 struct sigqueue *q, *n;
725 sigset_t m;
726
727 sigandsets(&m, mask, &s->signal);
728 if (sigisemptyset(&m))
Christian Brauner8f113512018-08-21 22:00:38 -0700729 return;
George Anzinger71fabd52006-01-08 01:02:48 -0800730
Oleg Nesterov702a5072011-04-27 22:01:27 +0200731 sigandnsets(&s->signal, &s->signal, mask);
George Anzinger71fabd52006-01-08 01:02:48 -0800732 list_for_each_entry_safe(q, n, &s->list, list) {
733 if (sigismember(mask, q->info.si_signo)) {
734 list_del_init(&q->list);
735 __sigqueue_free(q);
736 }
737 }
George Anzinger71fabd52006-01-08 01:02:48 -0800738}
Linus Torvalds1da177e2005-04-16 15:20:36 -0700739
Eric W. Biedermanae7795b2018-09-25 11:27:20 +0200740static inline int is_si_special(const struct kernel_siginfo *info)
Oleg Nesterov614c5172009-12-15 16:47:22 -0800741{
Eric W. Biederman4ff4c312018-09-03 10:39:04 +0200742 return info <= SEND_SIG_PRIV;
Oleg Nesterov614c5172009-12-15 16:47:22 -0800743}
744
Eric W. Biedermanae7795b2018-09-25 11:27:20 +0200745static inline bool si_fromuser(const struct kernel_siginfo *info)
Oleg Nesterov614c5172009-12-15 16:47:22 -0800746{
747 return info == SEND_SIG_NOINFO ||
748 (!is_si_special(info) && SI_FROMUSER(info));
749}
750
Linus Torvalds1da177e2005-04-16 15:20:36 -0700751/*
Serge E. Hallyn39fd3392011-03-23 16:43:19 -0700752 * called with RCU read lock from check_kill_permission()
753 */
Christian Brauner2a9b9092018-08-21 22:00:11 -0700754static bool kill_ok_by_cred(struct task_struct *t)
Serge E. Hallyn39fd3392011-03-23 16:43:19 -0700755{
756 const struct cred *cred = current_cred();
757 const struct cred *tcred = __task_cred(t);
758
Christian Brauner2a9b9092018-08-21 22:00:11 -0700759 return uid_eq(cred->euid, tcred->suid) ||
760 uid_eq(cred->euid, tcred->uid) ||
761 uid_eq(cred->uid, tcred->suid) ||
762 uid_eq(cred->uid, tcred->uid) ||
763 ns_capable(tcred->user_ns, CAP_KILL);
Serge E. Hallyn39fd3392011-03-23 16:43:19 -0700764}
765
766/*
Linus Torvalds1da177e2005-04-16 15:20:36 -0700767 * Bad permissions for sending the signal
David Howells694f6902010-08-04 16:59:14 +0100768 * - the caller must hold the RCU read lock
Linus Torvalds1da177e2005-04-16 15:20:36 -0700769 */
Eric W. Biedermanae7795b2018-09-25 11:27:20 +0200770static int check_kill_permission(int sig, struct kernel_siginfo *info,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700771 struct task_struct *t)
772{
Oleg Nesterov2e2ba222008-04-30 00:53:01 -0700773 struct pid *sid;
Oleg Nesterov3b5e9e52008-04-30 00:52:42 -0700774 int error;
775
Jesper Juhl7ed20e12005-05-01 08:59:14 -0700776 if (!valid_signal(sig))
Oleg Nesterov3b5e9e52008-04-30 00:52:42 -0700777 return -EINVAL;
778
Oleg Nesterov614c5172009-12-15 16:47:22 -0800779 if (!si_fromuser(info))
Oleg Nesterov3b5e9e52008-04-30 00:52:42 -0700780 return 0;
781
782 error = audit_signal_info(sig, t); /* Let audit system see the signal */
783 if (error)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700784 return error;
Amy Griffise54dc242007-03-29 18:01:04 -0400785
Oleg Nesterov065add32010-05-26 14:42:54 -0700786 if (!same_thread_group(current, t) &&
Serge E. Hallyn39fd3392011-03-23 16:43:19 -0700787 !kill_ok_by_cred(t)) {
Oleg Nesterov2e2ba222008-04-30 00:53:01 -0700788 switch (sig) {
789 case SIGCONT:
Oleg Nesterov2e2ba222008-04-30 00:53:01 -0700790 sid = task_session(t);
Oleg Nesterov2e2ba222008-04-30 00:53:01 -0700791 /*
792 * We don't return the error if sid == NULL. The
793 * task was unhashed, the caller must notice this.
794 */
795 if (!sid || sid == task_session(current))
796 break;
797 default:
798 return -EPERM;
799 }
800 }
Steve Grubbc2f0c7c2005-05-06 12:38:39 +0100801
Stephen Smalley6b4f3d02017-09-08 12:40:01 -0400802 return security_task_kill(t, info, sig, NULL);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700803}
804
Tejun Heofb1d9102011-06-14 11:20:17 +0200805/**
806 * ptrace_trap_notify - schedule trap to notify ptracer
807 * @t: tracee wanting to notify tracer
808 *
809 * This function schedules sticky ptrace trap which is cleared on the next
810 * TRAP_STOP to notify ptracer of an event. @t must have been seized by
811 * ptracer.
812 *
Tejun Heo544b2c92011-06-14 11:20:18 +0200813 * If @t is running, STOP trap will be taken. If trapped for STOP and
814 * ptracer is listening for events, tracee is woken up so that it can
815 * re-trap for the new event. If trapped otherwise, STOP trap will be
816 * eventually taken without returning to userland after the existing traps
817 * are finished by PTRACE_CONT.
Tejun Heofb1d9102011-06-14 11:20:17 +0200818 *
819 * CONTEXT:
820 * Must be called with @task->sighand->siglock held.
821 */
822static void ptrace_trap_notify(struct task_struct *t)
823{
824 WARN_ON_ONCE(!(t->ptrace & PT_SEIZED));
825 assert_spin_locked(&t->sighand->siglock);
826
827 task_set_jobctl_pending(t, JOBCTL_TRAP_NOTIFY);
Oleg Nesterov910ffdb2013-01-21 20:47:41 +0100828 ptrace_signal_wake_up(t, t->jobctl & JOBCTL_LISTENING);
Tejun Heofb1d9102011-06-14 11:20:17 +0200829}
830
Linus Torvalds1da177e2005-04-16 15:20:36 -0700831/*
Oleg Nesterov7e695a52008-04-30 00:52:59 -0700832 * Handle magic process-wide effects of stop/continue signals. Unlike
833 * the signal actions, these happen immediately at signal-generation
Linus Torvalds1da177e2005-04-16 15:20:36 -0700834 * time regardless of blocking, ignoring, or handling. This does the
835 * actual continuing for SIGCONT, but not the actual stopping for stop
Oleg Nesterov7e695a52008-04-30 00:52:59 -0700836 * signals. The process stop is done as a signal action for SIG_DFL.
837 *
838 * Returns true if the signal should be actually delivered, otherwise
839 * it should be dropped.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700840 */
Oleg Nesterov403bad72013-04-30 15:28:10 -0700841static bool prepare_signal(int sig, struct task_struct *p, bool force)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700842{
Oleg Nesterovad16a4602008-04-30 00:52:46 -0700843 struct signal_struct *signal = p->signal;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700844 struct task_struct *t;
Oleg Nesterov9490592f2014-06-06 14:36:48 -0700845 sigset_t flush;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700846
Oleg Nesterov403bad72013-04-30 15:28:10 -0700847 if (signal->flags & (SIGNAL_GROUP_EXIT | SIGNAL_GROUP_COREDUMP)) {
Oleg Nesterov5fa534c2015-11-06 16:32:31 -0800848 if (!(signal->flags & SIGNAL_GROUP_EXIT))
Oleg Nesterov403bad72013-04-30 15:28:10 -0700849 return sig == SIGKILL;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700850 /*
Oleg Nesterov7e695a52008-04-30 00:52:59 -0700851 * The process is in the middle of dying, nothing to do.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700852 */
Oleg Nesterov7e695a52008-04-30 00:52:59 -0700853 } else if (sig_kernel_stop(sig)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700854 /*
855 * This is a stop signal. Remove SIGCONT from all queues.
856 */
Oleg Nesterov9490592f2014-06-06 14:36:48 -0700857 siginitset(&flush, sigmask(SIGCONT));
Oleg Nesterovc09c1442014-06-06 14:36:50 -0700858 flush_sigqueue_mask(&flush, &signal->shared_pending);
Oleg Nesterov9490592f2014-06-06 14:36:48 -0700859 for_each_thread(p, t)
Oleg Nesterovc09c1442014-06-06 14:36:50 -0700860 flush_sigqueue_mask(&flush, &t->pending);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700861 } else if (sig == SIGCONT) {
Oleg Nesterovfc321d22008-04-30 00:52:46 -0700862 unsigned int why;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700863 /*
Oleg Nesterov1deac632011-04-01 20:11:50 +0200864 * Remove all stop signals from all queues, wake all threads.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700865 */
Oleg Nesterov9490592f2014-06-06 14:36:48 -0700866 siginitset(&flush, SIG_KERNEL_STOP_MASK);
Oleg Nesterovc09c1442014-06-06 14:36:50 -0700867 flush_sigqueue_mask(&flush, &signal->shared_pending);
Oleg Nesterov9490592f2014-06-06 14:36:48 -0700868 for_each_thread(p, t) {
Oleg Nesterovc09c1442014-06-06 14:36:50 -0700869 flush_sigqueue_mask(&flush, &t->pending);
Tejun Heo3759a0d2011-06-02 11:14:00 +0200870 task_clear_jobctl_pending(t, JOBCTL_STOP_PENDING);
Tejun Heofb1d9102011-06-14 11:20:17 +0200871 if (likely(!(t->ptrace & PT_SEIZED)))
872 wake_up_state(t, __TASK_STOPPED);
873 else
874 ptrace_trap_notify(t);
Oleg Nesterov9490592f2014-06-06 14:36:48 -0700875 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700876
Oleg Nesterovfc321d22008-04-30 00:52:46 -0700877 /*
878 * Notify the parent with CLD_CONTINUED if we were stopped.
879 *
880 * If we were in the middle of a group stop, we pretend it
881 * was already finished, and then continued. Since SIGCHLD
882 * doesn't queue we report only CLD_STOPPED, as if the next
883 * CLD_CONTINUED was dropped.
884 */
885 why = 0;
Oleg Nesterovad16a4602008-04-30 00:52:46 -0700886 if (signal->flags & SIGNAL_STOP_STOPPED)
Oleg Nesterovfc321d22008-04-30 00:52:46 -0700887 why |= SIGNAL_CLD_CONTINUED;
Oleg Nesterovad16a4602008-04-30 00:52:46 -0700888 else if (signal->group_stop_count)
Oleg Nesterovfc321d22008-04-30 00:52:46 -0700889 why |= SIGNAL_CLD_STOPPED;
890
891 if (why) {
Oleg Nesterov021e1ae2008-04-30 00:53:00 -0700892 /*
Roland McGrathae6d2ed2009-09-23 15:56:53 -0700893 * The first thread which returns from do_signal_stop()
Oleg Nesterov021e1ae2008-04-30 00:53:00 -0700894 * will take ->siglock, notice SIGNAL_CLD_MASK, and
Weikang Shi2e58f572018-10-30 15:07:05 -0700895 * notify its parent. See get_signal().
Oleg Nesterov021e1ae2008-04-30 00:53:00 -0700896 */
Jamie Iles2d39b3c2017-01-10 16:57:54 -0800897 signal_set_stop_flags(signal, why | SIGNAL_STOP_CONTINUED);
Oleg Nesterovad16a4602008-04-30 00:52:46 -0700898 signal->group_stop_count = 0;
899 signal->group_exit_code = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700900 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700901 }
Oleg Nesterov7e695a52008-04-30 00:52:59 -0700902
Oleg Nesterovdef8cf72012-03-23 15:02:45 -0700903 return !sig_ignored(p, sig, force);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700904}
905
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700906/*
907 * Test if P wants to take SIG. After we've checked all threads with this,
908 * it's equivalent to finding no threads not blocking SIG. Any threads not
909 * blocking SIG were ruled out because they are not running and already
910 * have pending signals. Such threads will dequeue from the shared queue
911 * as soon as they're available, so putting the signal on the shared queue
912 * will be equivalent to sending it to one such thread.
913 */
Christian Brauneracd14e62018-08-21 22:00:42 -0700914static inline bool wants_signal(int sig, struct task_struct *p)
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700915{
916 if (sigismember(&p->blocked, sig))
Christian Brauneracd14e62018-08-21 22:00:42 -0700917 return false;
918
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700919 if (p->flags & PF_EXITING)
Christian Brauneracd14e62018-08-21 22:00:42 -0700920 return false;
921
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700922 if (sig == SIGKILL)
Christian Brauneracd14e62018-08-21 22:00:42 -0700923 return true;
924
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700925 if (task_is_stopped_or_traced(p))
Christian Brauneracd14e62018-08-21 22:00:42 -0700926 return false;
927
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700928 return task_curr(p) || !signal_pending(p);
929}
930
Eric W. Biederman07296142018-07-13 21:39:13 -0500931static void complete_signal(int sig, struct task_struct *p, enum pid_type type)
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700932{
933 struct signal_struct *signal = p->signal;
934 struct task_struct *t;
935
936 /*
937 * Now find a thread we can wake up to take the signal off the queue.
938 *
939 * If the main thread wants the signal, it gets first crack.
940 * Probably the least surprising to the average bear.
941 */
942 if (wants_signal(sig, p))
943 t = p;
Eric W. Biederman07296142018-07-13 21:39:13 -0500944 else if ((type == PIDTYPE_PID) || thread_group_empty(p))
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700945 /*
946 * There is just one thread and it does not need to be woken.
947 * It will dequeue unblocked signals before it runs again.
948 */
949 return;
950 else {
951 /*
952 * Otherwise try to find a suitable thread.
953 */
954 t = signal->curr_target;
955 while (!wants_signal(sig, t)) {
956 t = next_thread(t);
957 if (t == signal->curr_target)
958 /*
959 * No thread needs to be woken.
960 * Any eligible threads will see
961 * the signal in the queue soon.
962 */
963 return;
964 }
965 signal->curr_target = t;
966 }
967
968 /*
969 * Found a killable thread. If the signal will be fatal,
970 * then start taking the whole group down immediately.
971 */
Oleg Nesterovfae5fa42008-04-30 00:53:03 -0700972 if (sig_fatal(p, sig) &&
Oleg Nesterov42691572017-11-17 15:30:08 -0800973 !(signal->flags & SIGNAL_GROUP_EXIT) &&
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700974 !sigismember(&t->real_blocked, sig) &&
Oleg Nesterov42691572017-11-17 15:30:08 -0800975 (sig == SIGKILL || !p->ptrace)) {
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700976 /*
977 * This signal will be fatal to the whole group.
978 */
979 if (!sig_kernel_coredump(sig)) {
980 /*
981 * Start a group exit and wake everybody up.
982 * This way we don't have other threads
983 * running and doing things after a slower
984 * thread has the fatal signal pending.
985 */
986 signal->flags = SIGNAL_GROUP_EXIT;
987 signal->group_exit_code = sig;
988 signal->group_stop_count = 0;
989 t = p;
990 do {
Tejun Heo6dfca322011-06-02 11:14:00 +0200991 task_clear_jobctl_pending(t, JOBCTL_PENDING_MASK);
Oleg Nesterov71f11dc2008-04-30 00:52:53 -0700992 sigaddset(&t->pending.signal, SIGKILL);
993 signal_wake_up(t, 1);
994 } while_each_thread(p, t);
995 return;
996 }
997 }
998
999 /*
1000 * The signal is already in the shared-pending queue.
1001 * Tell the chosen thread to wake up and dequeue it.
1002 */
1003 signal_wake_up(t, sig == SIGKILL);
1004 return;
1005}
1006
Christian Braunera19e2c02018-08-21 22:00:46 -07001007static inline bool legacy_queue(struct sigpending *signals, int sig)
Pavel Emelyanovaf7fff92008-04-30 00:52:34 -07001008{
1009 return (sig < SIGRTMIN) && sigismember(&signals->signal, sig);
1010}
1011
Serge E. Hallyn6b550f92012-01-10 15:11:37 -08001012#ifdef CONFIG_USER_NS
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001013static inline void userns_fixup_signal_uid(struct kernel_siginfo *info, struct task_struct *t)
Serge E. Hallyn6b550f92012-01-10 15:11:37 -08001014{
1015 if (current_user_ns() == task_cred_xxx(t, user_ns))
1016 return;
1017
1018 if (SI_FROMKERNEL(info))
1019 return;
1020
Eric W. Biederman078de5f2012-02-08 07:00:08 -08001021 rcu_read_lock();
1022 info->si_uid = from_kuid_munged(task_cred_xxx(t, user_ns),
1023 make_kuid(current_user_ns(), info->si_uid));
1024 rcu_read_unlock();
Serge E. Hallyn6b550f92012-01-10 15:11:37 -08001025}
1026#else
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001027static inline void userns_fixup_signal_uid(struct kernel_siginfo *info, struct task_struct *t)
Serge E. Hallyn6b550f92012-01-10 15:11:37 -08001028{
1029 return;
1030}
1031#endif
1032
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001033static int __send_signal(int sig, struct kernel_siginfo *info, struct task_struct *t,
Eric W. Biederman5a883ce2018-07-13 19:26:27 -05001034 enum pid_type type, int from_ancestor_ns)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001035{
Oleg Nesterov2ca35152008-04-30 00:52:54 -07001036 struct sigpending *pending;
Oleg Nesterov6e65acb2008-04-30 00:52:50 -07001037 struct sigqueue *q;
Vegard Nossum7a0aeb12009-05-16 11:28:33 +02001038 int override_rlimit;
Oleg Nesterov6c303d32011-11-22 21:13:48 +01001039 int ret = 0, result;
Mathieu Desnoyers0a16b602008-07-18 12:16:17 -04001040
Oleg Nesterov6e65acb2008-04-30 00:52:50 -07001041 assert_spin_locked(&t->sighand->siglock);
Sukadev Bhattiprolu921cf9f2009-04-02 16:58:05 -07001042
Oleg Nesterov6c303d32011-11-22 21:13:48 +01001043 result = TRACE_SIGNAL_IGNORED;
Oleg Nesterov629d3622012-03-23 15:02:44 -07001044 if (!prepare_signal(sig, t,
Eric W. Biederman4ff4c312018-09-03 10:39:04 +02001045 from_ancestor_ns || (info == SEND_SIG_PRIV)))
Oleg Nesterov6c303d32011-11-22 21:13:48 +01001046 goto ret;
Oleg Nesterov2ca35152008-04-30 00:52:54 -07001047
Eric W. Biederman5a883ce2018-07-13 19:26:27 -05001048 pending = (type != PIDTYPE_PID) ? &t->signal->shared_pending : &t->pending;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001049 /*
Pavel Emelyanov2acb0242008-04-30 00:52:35 -07001050 * Short-circuit ignored signals and support queuing
1051 * exactly one non-rt signal, so that we can get more
1052 * detailed information about the cause of the signal.
1053 */
Oleg Nesterov6c303d32011-11-22 21:13:48 +01001054 result = TRACE_SIGNAL_ALREADY_PENDING;
Oleg Nesterov7e695a52008-04-30 00:52:59 -07001055 if (legacy_queue(pending, sig))
Oleg Nesterov6c303d32011-11-22 21:13:48 +01001056 goto ret;
1057
1058 result = TRACE_SIGNAL_DELIVERED;
Davide Libenzifba2afa2007-05-10 22:23:13 -07001059 /*
Eric W. Biedermana6929332019-02-05 07:19:11 -06001060 * Skip useless siginfo allocation for SIGKILL and kernel threads.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001061 */
Eric W. Biedermana6929332019-02-05 07:19:11 -06001062 if ((sig == SIGKILL) || (t->flags & PF_KTHREAD))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001063 goto out_set;
1064
Randy Dunlap5aba0852011-04-04 14:59:31 -07001065 /*
1066 * Real-time signals must be queued if sent by sigqueue, or
1067 * some other real-time mechanism. It is implementation
1068 * defined whether kill() does so. We attempt to do so, on
1069 * the principle of least surprise, but since kill is not
1070 * allowed to fail with EAGAIN when low on memory we just
1071 * make sure at least one signal gets delivered and don't
1072 * pass on the info struct.
1073 */
Vegard Nossum7a0aeb12009-05-16 11:28:33 +02001074 if (sig < SIGRTMIN)
1075 override_rlimit = (is_si_special(info) || info->si_code >= 0);
1076 else
1077 override_rlimit = 0;
1078
Levin, Alexander (Sasha Levin)75f296d2017-11-15 17:35:54 -08001079 q = __sigqueue_alloc(sig, t, GFP_ATOMIC, override_rlimit);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001080 if (q) {
Oleg Nesterov2ca35152008-04-30 00:52:54 -07001081 list_add_tail(&q->list, &pending->list);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001082 switch ((unsigned long) info) {
Oleg Nesterovb67a1b92005-10-30 15:03:44 -08001083 case (unsigned long) SEND_SIG_NOINFO:
Eric W. Biedermanfaf1f222018-01-05 17:27:42 -06001084 clear_siginfo(&q->info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001085 q->info.si_signo = sig;
1086 q->info.si_errno = 0;
1087 q->info.si_code = SI_USER;
Sukadev Bhattiprolu9cd4fd12009-01-06 14:42:46 -08001088 q->info.si_pid = task_tgid_nr_ns(current,
Sukadev Bhattiprolu09bca052009-01-06 14:42:45 -08001089 task_active_pid_ns(t));
Eric W. Biederman078de5f2012-02-08 07:00:08 -08001090 q->info.si_uid = from_kuid_munged(current_user_ns(), current_uid());
Linus Torvalds1da177e2005-04-16 15:20:36 -07001091 break;
Oleg Nesterovb67a1b92005-10-30 15:03:44 -08001092 case (unsigned long) SEND_SIG_PRIV:
Eric W. Biedermanfaf1f222018-01-05 17:27:42 -06001093 clear_siginfo(&q->info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001094 q->info.si_signo = sig;
1095 q->info.si_errno = 0;
1096 q->info.si_code = SI_KERNEL;
1097 q->info.si_pid = 0;
1098 q->info.si_uid = 0;
1099 break;
1100 default:
1101 copy_siginfo(&q->info, info);
Sukadev Bhattiprolu6588c1e2009-04-02 16:58:09 -07001102 if (from_ancestor_ns)
1103 q->info.si_pid = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001104 break;
1105 }
Serge E. Hallyn6b550f92012-01-10 15:11:37 -08001106
1107 userns_fixup_signal_uid(&q->info, t);
1108
Oleg Nesterov621d3122005-10-30 15:03:45 -08001109 } else if (!is_si_special(info)) {
Masami Hiramatsuba005e12009-11-24 16:56:58 -05001110 if (sig >= SIGRTMIN && info->si_code != SI_USER) {
1111 /*
1112 * Queue overflow, abort. We may abort if the
1113 * signal was rt and sent by user using something
1114 * other than kill().
1115 */
Oleg Nesterov6c303d32011-11-22 21:13:48 +01001116 result = TRACE_SIGNAL_OVERFLOW_FAIL;
1117 ret = -EAGAIN;
1118 goto ret;
Masami Hiramatsuba005e12009-11-24 16:56:58 -05001119 } else {
1120 /*
1121 * This is a silent loss of information. We still
1122 * send the signal, but the *info bits are lost.
1123 */
Oleg Nesterov6c303d32011-11-22 21:13:48 +01001124 result = TRACE_SIGNAL_LOSE_INFO;
Masami Hiramatsuba005e12009-11-24 16:56:58 -05001125 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001126 }
1127
1128out_set:
Oleg Nesterov53c30332008-04-30 00:53:00 -07001129 signalfd_notify(t, sig);
Oleg Nesterov2ca35152008-04-30 00:52:54 -07001130 sigaddset(&pending->signal, sig);
Eric W. Biedermanc3ad2c32018-07-23 15:20:37 -05001131
1132 /* Let multiprocess signals appear after on-going forks */
1133 if (type > PIDTYPE_TGID) {
1134 struct multiprocess_signals *delayed;
1135 hlist_for_each_entry(delayed, &t->signal->multiprocess, node) {
1136 sigset_t *signal = &delayed->signal;
1137 /* Can't queue both a stop and a continue signal */
1138 if (sig == SIGCONT)
1139 sigdelsetmask(signal, SIG_KERNEL_STOP_MASK);
1140 else if (sig_kernel_stop(sig))
1141 sigdelset(signal, SIGCONT);
1142 sigaddset(signal, sig);
1143 }
1144 }
1145
Eric W. Biederman07296142018-07-13 21:39:13 -05001146 complete_signal(sig, t, type);
Oleg Nesterov6c303d32011-11-22 21:13:48 +01001147ret:
Eric W. Biederman5a883ce2018-07-13 19:26:27 -05001148 trace_signal_generate(sig, info, t, type != PIDTYPE_PID, result);
Oleg Nesterov6c303d32011-11-22 21:13:48 +01001149 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001150}
1151
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001152static int send_signal(int sig, struct kernel_siginfo *info, struct task_struct *t,
Eric W. Biedermanb2139842018-07-20 15:49:17 -05001153 enum pid_type type)
Sukadev Bhattiprolu7978b562009-04-02 16:58:04 -07001154{
Sukadev Bhattiprolu921cf9f2009-04-02 16:58:05 -07001155 int from_ancestor_ns = 0;
1156
1157#ifdef CONFIG_PID_NS
Oleg Nesterovdd342002009-12-15 16:47:24 -08001158 from_ancestor_ns = si_fromuser(info) &&
1159 !task_pid_nr_ns(current, task_active_pid_ns(t));
Sukadev Bhattiprolu921cf9f2009-04-02 16:58:05 -07001160#endif
1161
Eric W. Biederman5a883ce2018-07-13 19:26:27 -05001162 return __send_signal(sig, info, t, type, from_ancestor_ns);
Sukadev Bhattiprolu7978b562009-04-02 16:58:04 -07001163}
1164
Al Viro4aaefee2012-11-05 13:09:56 -05001165static void print_fatal_signal(int signr)
Ingo Molnar45807a12007-07-15 23:40:10 -07001166{
Al Viro4aaefee2012-11-05 13:09:56 -05001167 struct pt_regs *regs = signal_pt_regs();
Wang Xiaoqiang747800e2016-05-23 16:23:59 -07001168 pr_info("potentially unexpected fatal signal %d.\n", signr);
Ingo Molnar45807a12007-07-15 23:40:10 -07001169
Al Viroca5cd872007-10-29 04:31:16 +00001170#if defined(__i386__) && !defined(__arch_um__)
Wang Xiaoqiang747800e2016-05-23 16:23:59 -07001171 pr_info("code at %08lx: ", regs->ip);
Ingo Molnar45807a12007-07-15 23:40:10 -07001172 {
1173 int i;
1174 for (i = 0; i < 16; i++) {
1175 unsigned char insn;
1176
Andi Kleenb45c6e72010-01-08 14:42:52 -08001177 if (get_user(insn, (unsigned char *)(regs->ip + i)))
1178 break;
Wang Xiaoqiang747800e2016-05-23 16:23:59 -07001179 pr_cont("%02x ", insn);
Ingo Molnar45807a12007-07-15 23:40:10 -07001180 }
1181 }
Wang Xiaoqiang747800e2016-05-23 16:23:59 -07001182 pr_cont("\n");
Ingo Molnar45807a12007-07-15 23:40:10 -07001183#endif
Ed Swierk3a9f84d2009-01-26 15:33:31 -08001184 preempt_disable();
Ingo Molnar45807a12007-07-15 23:40:10 -07001185 show_regs(regs);
Ed Swierk3a9f84d2009-01-26 15:33:31 -08001186 preempt_enable();
Ingo Molnar45807a12007-07-15 23:40:10 -07001187}
1188
1189static int __init setup_print_fatal_signals(char *str)
1190{
1191 get_option (&str, &print_fatal_signals);
1192
1193 return 1;
1194}
1195
1196__setup("print-fatal-signals=", setup_print_fatal_signals);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001197
Pavel Emelyanov4cd4b6d2008-04-30 00:52:55 -07001198int
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001199__group_send_sig_info(int sig, struct kernel_siginfo *info, struct task_struct *p)
Pavel Emelyanov4cd4b6d2008-04-30 00:52:55 -07001200{
Eric W. Biedermanb2139842018-07-20 15:49:17 -05001201 return send_signal(sig, info, p, PIDTYPE_TGID);
Pavel Emelyanov4cd4b6d2008-04-30 00:52:55 -07001202}
1203
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001204int do_send_sig_info(int sig, struct kernel_siginfo *info, struct task_struct *p,
Eric W. Biederman40b3b022018-07-21 10:45:15 -05001205 enum pid_type type)
Oleg Nesterov4a30deb2009-09-23 15:57:00 -07001206{
1207 unsigned long flags;
1208 int ret = -ESRCH;
1209
1210 if (lock_task_sighand(p, &flags)) {
Eric W. Biedermanb2139842018-07-20 15:49:17 -05001211 ret = send_signal(sig, info, p, type);
Oleg Nesterov4a30deb2009-09-23 15:57:00 -07001212 unlock_task_sighand(p, &flags);
1213 }
1214
1215 return ret;
1216}
1217
Linus Torvalds1da177e2005-04-16 15:20:36 -07001218/*
1219 * Force a signal that the process can't ignore: if necessary
1220 * we unblock the signal and change any SIG_IGN to SIG_DFL.
Linus Torvaldsae74c3b2006-08-02 20:17:49 -07001221 *
1222 * Note: If we unblock the signal, we always reset it to SIG_DFL,
1223 * since we do not want to have a signal handler that was blocked
1224 * be invoked when user space had explicitly blocked it.
1225 *
Oleg Nesterov80fe7282008-04-30 00:53:05 -07001226 * We don't want to have recursive SIGSEGV's etc, for example,
1227 * that is why we also clear SIGNAL_UNKILLABLE.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001228 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001229int
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001230force_sig_info(int sig, struct kernel_siginfo *info, struct task_struct *t)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001231{
1232 unsigned long int flags;
Linus Torvaldsae74c3b2006-08-02 20:17:49 -07001233 int ret, blocked, ignored;
1234 struct k_sigaction *action;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001235
1236 spin_lock_irqsave(&t->sighand->siglock, flags);
Linus Torvaldsae74c3b2006-08-02 20:17:49 -07001237 action = &t->sighand->action[sig-1];
1238 ignored = action->sa.sa_handler == SIG_IGN;
1239 blocked = sigismember(&t->blocked, sig);
1240 if (blocked || ignored) {
1241 action->sa.sa_handler = SIG_DFL;
1242 if (blocked) {
1243 sigdelset(&t->blocked, sig);
Roland McGrath7bb44ad2007-05-23 13:57:44 -07001244 recalc_sigpending_and_wake(t);
Linus Torvaldsae74c3b2006-08-02 20:17:49 -07001245 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001246 }
Jamie Ileseb61b592017-08-18 15:16:18 -07001247 /*
1248 * Don't clear SIGNAL_UNKILLABLE for traced tasks, users won't expect
1249 * debugging to leave init killable.
1250 */
1251 if (action->sa.sa_handler == SIG_DFL && !t->ptrace)
Oleg Nesterov80fe7282008-04-30 00:53:05 -07001252 t->signal->flags &= ~SIGNAL_UNKILLABLE;
Eric W. Biedermanb21c5bd2018-07-21 11:34:03 -05001253 ret = send_signal(sig, info, t, PIDTYPE_PID);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001254 spin_unlock_irqrestore(&t->sighand->siglock, flags);
1255
1256 return ret;
1257}
1258
Linus Torvalds1da177e2005-04-16 15:20:36 -07001259/*
1260 * Nuke all other threads in the group.
1261 */
Oleg Nesterov09faef12010-05-26 14:43:11 -07001262int zap_other_threads(struct task_struct *p)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001263{
Oleg Nesterov09faef12010-05-26 14:43:11 -07001264 struct task_struct *t = p;
1265 int count = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001266
Linus Torvalds1da177e2005-04-16 15:20:36 -07001267 p->signal->group_stop_count = 0;
1268
Oleg Nesterov09faef12010-05-26 14:43:11 -07001269 while_each_thread(p, t) {
Tejun Heo6dfca322011-06-02 11:14:00 +02001270 task_clear_jobctl_pending(t, JOBCTL_PENDING_MASK);
Oleg Nesterov09faef12010-05-26 14:43:11 -07001271 count++;
1272
1273 /* Don't bother with already dead threads */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001274 if (t->exit_state)
1275 continue;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001276 sigaddset(&t->pending.signal, SIGKILL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001277 signal_wake_up(t, 1);
1278 }
Oleg Nesterov09faef12010-05-26 14:43:11 -07001279
1280 return count;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001281}
1282
Namhyung Kimb8ed3742010-10-27 15:34:06 -07001283struct sighand_struct *__lock_task_sighand(struct task_struct *tsk,
1284 unsigned long *flags)
Oleg Nesterovf63ee722006-03-28 16:11:13 -08001285{
1286 struct sighand_struct *sighand;
1287
Anna-Maria Gleixner59dc6f32018-05-25 11:05:07 +02001288 rcu_read_lock();
Oleg Nesterovf63ee722006-03-28 16:11:13 -08001289 for (;;) {
1290 sighand = rcu_dereference(tsk->sighand);
Anna-Maria Gleixner59dc6f32018-05-25 11:05:07 +02001291 if (unlikely(sighand == NULL))
Oleg Nesterovf63ee722006-03-28 16:11:13 -08001292 break;
Anna-Maria Gleixner59dc6f32018-05-25 11:05:07 +02001293
Oleg Nesterov392809b2014-09-28 23:44:18 +02001294 /*
1295 * This sighand can be already freed and even reused, but
Paul E. McKenney5f0d5a32017-01-18 02:53:44 -08001296 * we rely on SLAB_TYPESAFE_BY_RCU and sighand_ctor() which
Oleg Nesterov392809b2014-09-28 23:44:18 +02001297 * initializes ->siglock: this slab can't go away, it has
1298 * the same object type, ->siglock can't be reinitialized.
1299 *
1300 * We need to ensure that tsk->sighand is still the same
1301 * after we take the lock, we can race with de_thread() or
1302 * __exit_signal(). In the latter case the next iteration
1303 * must see ->sighand == NULL.
1304 */
Anna-Maria Gleixner59dc6f32018-05-25 11:05:07 +02001305 spin_lock_irqsave(&sighand->siglock, *flags);
1306 if (likely(sighand == tsk->sighand))
Oleg Nesterovf63ee722006-03-28 16:11:13 -08001307 break;
Anna-Maria Gleixner59dc6f32018-05-25 11:05:07 +02001308 spin_unlock_irqrestore(&sighand->siglock, *flags);
Oleg Nesterovf63ee722006-03-28 16:11:13 -08001309 }
Anna-Maria Gleixner59dc6f32018-05-25 11:05:07 +02001310 rcu_read_unlock();
Oleg Nesterovf63ee722006-03-28 16:11:13 -08001311
1312 return sighand;
1313}
1314
David Howellsc69e8d92008-11-14 10:39:19 +11001315/*
1316 * send signal info to all the members of a group
David Howellsc69e8d92008-11-14 10:39:19 +11001317 */
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001318int group_send_sig_info(int sig, struct kernel_siginfo *info,
1319 struct task_struct *p, enum pid_type type)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001320{
David Howells694f6902010-08-04 16:59:14 +01001321 int ret;
1322
1323 rcu_read_lock();
1324 ret = check_kill_permission(sig, info, p);
1325 rcu_read_unlock();
Linus Torvalds1da177e2005-04-16 15:20:36 -07001326
Oleg Nesterov4a30deb2009-09-23 15:57:00 -07001327 if (!ret && sig)
Eric W. Biederman40b3b022018-07-21 10:45:15 -05001328 ret = do_send_sig_info(sig, info, p, type);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001329
1330 return ret;
1331}
1332
1333/*
Pavel Emelyanov146a5052008-02-08 04:19:22 -08001334 * __kill_pgrp_info() sends a signal to a process group: this is what the tty
Linus Torvalds1da177e2005-04-16 15:20:36 -07001335 * control characters do (^C, ^Z etc)
David Howellsc69e8d92008-11-14 10:39:19 +11001336 * - the caller must hold at least a readlock on tasklist_lock
Linus Torvalds1da177e2005-04-16 15:20:36 -07001337 */
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001338int __kill_pgrp_info(int sig, struct kernel_siginfo *info, struct pid *pgrp)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001339{
1340 struct task_struct *p = NULL;
1341 int retval, success;
1342
Linus Torvalds1da177e2005-04-16 15:20:36 -07001343 success = 0;
1344 retval = -ESRCH;
Eric W. Biedermanc4b92fc2006-10-02 02:17:10 -07001345 do_each_pid_task(pgrp, PIDTYPE_PGID, p) {
Eric W. Biederman01024982018-07-13 18:40:57 -05001346 int err = group_send_sig_info(sig, info, p, PIDTYPE_PGID);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001347 success |= !err;
1348 retval = err;
Eric W. Biedermanc4b92fc2006-10-02 02:17:10 -07001349 } while_each_pid_task(pgrp, PIDTYPE_PGID, p);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001350 return success ? 0 : retval;
1351}
1352
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001353int kill_pid_info(int sig, struct kernel_siginfo *info, struct pid *pid)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001354{
Oleg Nesterovd36174b2008-02-08 04:19:18 -08001355 int error = -ESRCH;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001356 struct task_struct *p;
1357
Paul E. McKenneyeca1a082014-10-23 11:41:22 -07001358 for (;;) {
1359 rcu_read_lock();
1360 p = pid_task(pid, PIDTYPE_PID);
1361 if (p)
Eric W. Biederman01024982018-07-13 18:40:57 -05001362 error = group_send_sig_info(sig, info, p, PIDTYPE_TGID);
Paul E. McKenneyeca1a082014-10-23 11:41:22 -07001363 rcu_read_unlock();
1364 if (likely(!p || error != -ESRCH))
1365 return error;
Oleg Nesterov6ca25b52008-04-30 00:52:45 -07001366
Paul E. McKenneyeca1a082014-10-23 11:41:22 -07001367 /*
1368 * The task was unhashed in between, try again. If it
1369 * is dead, pid_task() will return NULL, if we race with
1370 * de_thread() it will find the new leader.
1371 */
1372 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001373}
1374
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001375static int kill_proc_info(int sig, struct kernel_siginfo *info, pid_t pid)
Eric W. Biedermanc4b92fc2006-10-02 02:17:10 -07001376{
1377 int error;
1378 rcu_read_lock();
Pavel Emelyanovb4888932007-10-18 23:40:14 -07001379 error = kill_pid_info(sig, info, find_vpid(pid));
Eric W. Biedermanc4b92fc2006-10-02 02:17:10 -07001380 rcu_read_unlock();
1381 return error;
1382}
1383
Christian Braunerbb17fcc2018-08-21 21:59:55 -07001384static inline bool kill_as_cred_perm(const struct cred *cred,
1385 struct task_struct *target)
Serge Hallynd178bc32011-09-26 10:45:18 -05001386{
1387 const struct cred *pcred = __task_cred(target);
Christian Braunerbb17fcc2018-08-21 21:59:55 -07001388
1389 return uid_eq(cred->euid, pcred->suid) ||
1390 uid_eq(cred->euid, pcred->uid) ||
1391 uid_eq(cred->uid, pcred->suid) ||
1392 uid_eq(cred->uid, pcred->uid);
Serge Hallynd178bc32011-09-26 10:45:18 -05001393}
1394
Eric W. Biederman2425c082006-10-02 02:17:28 -07001395/* like kill_pid_info(), but doesn't use uid/euid of "current" */
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001396int kill_pid_info_as_cred(int sig, struct kernel_siginfo *info, struct pid *pid,
Stephen Smalley6b4f3d02017-09-08 12:40:01 -04001397 const struct cred *cred)
Harald Welte46113832005-10-10 19:44:29 +02001398{
1399 int ret = -EINVAL;
1400 struct task_struct *p;
Thomas Gleixner14d8c9f2009-12-10 00:53:17 +00001401 unsigned long flags;
Harald Welte46113832005-10-10 19:44:29 +02001402
1403 if (!valid_signal(sig))
1404 return ret;
1405
Thomas Gleixner14d8c9f2009-12-10 00:53:17 +00001406 rcu_read_lock();
Eric W. Biederman2425c082006-10-02 02:17:28 -07001407 p = pid_task(pid, PIDTYPE_PID);
Harald Welte46113832005-10-10 19:44:29 +02001408 if (!p) {
1409 ret = -ESRCH;
1410 goto out_unlock;
1411 }
Serge Hallynd178bc32011-09-26 10:45:18 -05001412 if (si_fromuser(info) && !kill_as_cred_perm(cred, p)) {
Harald Welte46113832005-10-10 19:44:29 +02001413 ret = -EPERM;
1414 goto out_unlock;
1415 }
Stephen Smalley6b4f3d02017-09-08 12:40:01 -04001416 ret = security_task_kill(p, info, sig, cred);
David Quigley8f95dc52006-06-30 01:55:47 -07001417 if (ret)
1418 goto out_unlock;
Thomas Gleixner14d8c9f2009-12-10 00:53:17 +00001419
1420 if (sig) {
1421 if (lock_task_sighand(p, &flags)) {
Eric W. Biederman5a883ce2018-07-13 19:26:27 -05001422 ret = __send_signal(sig, info, p, PIDTYPE_TGID, 0);
Thomas Gleixner14d8c9f2009-12-10 00:53:17 +00001423 unlock_task_sighand(p, &flags);
1424 } else
1425 ret = -ESRCH;
Harald Welte46113832005-10-10 19:44:29 +02001426 }
1427out_unlock:
Thomas Gleixner14d8c9f2009-12-10 00:53:17 +00001428 rcu_read_unlock();
Harald Welte46113832005-10-10 19:44:29 +02001429 return ret;
1430}
Serge Hallynd178bc32011-09-26 10:45:18 -05001431EXPORT_SYMBOL_GPL(kill_pid_info_as_cred);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001432
1433/*
1434 * kill_something_info() interprets pid in interesting ways just like kill(2).
1435 *
1436 * POSIX specifies that kill(-1,sig) is unspecified, but what we have
1437 * is probably wrong. Should make it like BSD or SYSV.
1438 */
1439
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001440static int kill_something_info(int sig, struct kernel_siginfo *info, pid_t pid)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001441{
Eric W. Biederman8d42db182007-02-12 00:52:55 -08001442 int ret;
Pavel Emelyanovd5df7632008-02-08 04:19:22 -08001443
1444 if (pid > 0) {
1445 rcu_read_lock();
1446 ret = kill_pid_info(sig, info, find_vpid(pid));
1447 rcu_read_unlock();
1448 return ret;
1449 }
1450
zhongjiang4ea77012017-07-10 15:52:57 -07001451 /* -INT_MIN is undefined. Exclude this case to avoid a UBSAN warning */
1452 if (pid == INT_MIN)
1453 return -ESRCH;
1454
Pavel Emelyanovd5df7632008-02-08 04:19:22 -08001455 read_lock(&tasklist_lock);
1456 if (pid != -1) {
1457 ret = __kill_pgrp_info(sig, info,
1458 pid ? find_vpid(-pid) : task_pgrp(current));
1459 } else {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001460 int retval = 0, count = 0;
1461 struct task_struct * p;
1462
Linus Torvalds1da177e2005-04-16 15:20:36 -07001463 for_each_process(p) {
Sukadev Bhattiprolud25141a2008-10-29 14:01:11 -07001464 if (task_pid_vnr(p) > 1 &&
1465 !same_thread_group(p, current)) {
Eric W. Biederman01024982018-07-13 18:40:57 -05001466 int err = group_send_sig_info(sig, info, p,
1467 PIDTYPE_MAX);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001468 ++count;
1469 if (err != -EPERM)
1470 retval = err;
1471 }
1472 }
Eric W. Biederman8d42db182007-02-12 00:52:55 -08001473 ret = count ? retval : -ESRCH;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001474 }
Pavel Emelyanovd5df7632008-02-08 04:19:22 -08001475 read_unlock(&tasklist_lock);
1476
Eric W. Biederman8d42db182007-02-12 00:52:55 -08001477 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001478}
1479
1480/*
1481 * These are for backward compatibility with the rest of the kernel source.
1482 */
1483
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001484int send_sig_info(int sig, struct kernel_siginfo *info, struct task_struct *p)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001485{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001486 /*
1487 * Make sure legacy kernel users don't send in bad values
1488 * (normal paths check this in check_kill_permission).
1489 */
Jesper Juhl7ed20e12005-05-01 08:59:14 -07001490 if (!valid_signal(sig))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001491 return -EINVAL;
1492
Eric W. Biederman40b3b022018-07-21 10:45:15 -05001493 return do_send_sig_info(sig, info, p, PIDTYPE_PID);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001494}
Eric W. Biedermanfb50f5a2018-09-13 19:26:35 +02001495EXPORT_SYMBOL(send_sig_info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001496
Oleg Nesterovb67a1b92005-10-30 15:03:44 -08001497#define __si_special(priv) \
1498 ((priv) ? SEND_SIG_PRIV : SEND_SIG_NOINFO)
1499
Linus Torvalds1da177e2005-04-16 15:20:36 -07001500int
1501send_sig(int sig, struct task_struct *p, int priv)
1502{
Oleg Nesterovb67a1b92005-10-30 15:03:44 -08001503 return send_sig_info(sig, __si_special(priv), p);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001504}
Eric W. Biedermanfb50f5a2018-09-13 19:26:35 +02001505EXPORT_SYMBOL(send_sig);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001506
Christian Brauner52cba1a2018-08-21 21:59:51 -07001507void force_sig(int sig, struct task_struct *p)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001508{
Oleg Nesterovb67a1b92005-10-30 15:03:44 -08001509 force_sig_info(sig, SEND_SIG_PRIV, p);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001510}
Eric W. Biedermanfb50f5a2018-09-13 19:26:35 +02001511EXPORT_SYMBOL(force_sig);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001512
1513/*
1514 * When things go south during signal handling, we
1515 * will force a SIGSEGV. And if the signal that caused
1516 * the problem was already a SIGSEGV, we'll want to
1517 * make sure we don't even try to deliver the signal..
1518 */
Christian Brauner52cba1a2018-08-21 21:59:51 -07001519void force_sigsegv(int sig, struct task_struct *p)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001520{
1521 if (sig == SIGSEGV) {
1522 unsigned long flags;
1523 spin_lock_irqsave(&p->sighand->siglock, flags);
1524 p->sighand->action[sig - 1].sa.sa_handler = SIG_DFL;
1525 spin_unlock_irqrestore(&p->sighand->siglock, flags);
1526 }
1527 force_sig(SIGSEGV, p);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001528}
1529
Eric W. Biedermanf8ec6602018-01-18 14:54:54 -06001530int force_sig_fault(int sig, int code, void __user *addr
1531 ___ARCH_SI_TRAPNO(int trapno)
1532 ___ARCH_SI_IA64(int imm, unsigned int flags, unsigned long isr)
1533 , struct task_struct *t)
1534{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001535 struct kernel_siginfo info;
Eric W. Biedermanf8ec6602018-01-18 14:54:54 -06001536
1537 clear_siginfo(&info);
1538 info.si_signo = sig;
1539 info.si_errno = 0;
1540 info.si_code = code;
1541 info.si_addr = addr;
1542#ifdef __ARCH_SI_TRAPNO
1543 info.si_trapno = trapno;
1544#endif
1545#ifdef __ia64__
1546 info.si_imm = imm;
1547 info.si_flags = flags;
1548 info.si_isr = isr;
1549#endif
1550 return force_sig_info(info.si_signo, &info, t);
1551}
1552
1553int send_sig_fault(int sig, int code, void __user *addr
1554 ___ARCH_SI_TRAPNO(int trapno)
1555 ___ARCH_SI_IA64(int imm, unsigned int flags, unsigned long isr)
1556 , struct task_struct *t)
1557{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001558 struct kernel_siginfo info;
Eric W. Biedermanf8ec6602018-01-18 14:54:54 -06001559
1560 clear_siginfo(&info);
1561 info.si_signo = sig;
1562 info.si_errno = 0;
1563 info.si_code = code;
1564 info.si_addr = addr;
1565#ifdef __ARCH_SI_TRAPNO
1566 info.si_trapno = trapno;
1567#endif
1568#ifdef __ia64__
1569 info.si_imm = imm;
1570 info.si_flags = flags;
1571 info.si_isr = isr;
1572#endif
1573 return send_sig_info(info.si_signo, &info, t);
1574}
1575
Eric W. Biederman38246732018-01-18 18:54:31 -06001576int force_sig_mceerr(int code, void __user *addr, short lsb, struct task_struct *t)
1577{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001578 struct kernel_siginfo info;
Eric W. Biederman38246732018-01-18 18:54:31 -06001579
1580 WARN_ON((code != BUS_MCEERR_AO) && (code != BUS_MCEERR_AR));
1581 clear_siginfo(&info);
1582 info.si_signo = SIGBUS;
1583 info.si_errno = 0;
1584 info.si_code = code;
1585 info.si_addr = addr;
1586 info.si_addr_lsb = lsb;
1587 return force_sig_info(info.si_signo, &info, t);
1588}
1589
1590int send_sig_mceerr(int code, void __user *addr, short lsb, struct task_struct *t)
1591{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001592 struct kernel_siginfo info;
Eric W. Biederman38246732018-01-18 18:54:31 -06001593
1594 WARN_ON((code != BUS_MCEERR_AO) && (code != BUS_MCEERR_AR));
1595 clear_siginfo(&info);
1596 info.si_signo = SIGBUS;
1597 info.si_errno = 0;
1598 info.si_code = code;
1599 info.si_addr = addr;
1600 info.si_addr_lsb = lsb;
1601 return send_sig_info(info.si_signo, &info, t);
1602}
1603EXPORT_SYMBOL(send_sig_mceerr);
Eric W. Biederman38246732018-01-18 18:54:31 -06001604
Eric W. Biederman38246732018-01-18 18:54:31 -06001605int force_sig_bnderr(void __user *addr, void __user *lower, void __user *upper)
1606{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001607 struct kernel_siginfo info;
Eric W. Biederman38246732018-01-18 18:54:31 -06001608
1609 clear_siginfo(&info);
1610 info.si_signo = SIGSEGV;
1611 info.si_errno = 0;
1612 info.si_code = SEGV_BNDERR;
1613 info.si_addr = addr;
1614 info.si_lower = lower;
1615 info.si_upper = upper;
1616 return force_sig_info(info.si_signo, &info, current);
1617}
Eric W. Biederman38246732018-01-18 18:54:31 -06001618
1619#ifdef SEGV_PKUERR
1620int force_sig_pkuerr(void __user *addr, u32 pkey)
1621{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001622 struct kernel_siginfo info;
Eric W. Biederman38246732018-01-18 18:54:31 -06001623
1624 clear_siginfo(&info);
1625 info.si_signo = SIGSEGV;
1626 info.si_errno = 0;
1627 info.si_code = SEGV_PKUERR;
1628 info.si_addr = addr;
1629 info.si_pkey = pkey;
1630 return force_sig_info(info.si_signo, &info, current);
1631}
1632#endif
Eric W. Biedermanf8ec6602018-01-18 14:54:54 -06001633
Eric W. Biedermanf71dd7d2018-01-22 14:37:25 -06001634/* For the crazy architectures that include trap information in
1635 * the errno field, instead of an actual errno value.
1636 */
1637int force_sig_ptrace_errno_trap(int errno, void __user *addr)
1638{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001639 struct kernel_siginfo info;
Eric W. Biedermanf71dd7d2018-01-22 14:37:25 -06001640
1641 clear_siginfo(&info);
1642 info.si_signo = SIGTRAP;
1643 info.si_errno = errno;
1644 info.si_code = TRAP_HWBKPT;
1645 info.si_addr = addr;
1646 return force_sig_info(info.si_signo, &info, current);
1647}
1648
Eric W. Biedermanc4b92fc2006-10-02 02:17:10 -07001649int kill_pgrp(struct pid *pid, int sig, int priv)
1650{
Pavel Emelyanov146a5052008-02-08 04:19:22 -08001651 int ret;
1652
1653 read_lock(&tasklist_lock);
1654 ret = __kill_pgrp_info(sig, __si_special(priv), pid);
1655 read_unlock(&tasklist_lock);
1656
1657 return ret;
Eric W. Biedermanc4b92fc2006-10-02 02:17:10 -07001658}
1659EXPORT_SYMBOL(kill_pgrp);
1660
1661int kill_pid(struct pid *pid, int sig, int priv)
1662{
1663 return kill_pid_info(sig, __si_special(priv), pid);
1664}
1665EXPORT_SYMBOL(kill_pid);
1666
Linus Torvalds1da177e2005-04-16 15:20:36 -07001667/*
1668 * These functions support sending signals using preallocated sigqueue
1669 * structures. This is needed "because realtime applications cannot
1670 * afford to lose notifications of asynchronous events, like timer
Randy Dunlap5aba0852011-04-04 14:59:31 -07001671 * expirations or I/O completions". In the case of POSIX Timers
Linus Torvalds1da177e2005-04-16 15:20:36 -07001672 * we allocate the sigqueue structure from the timer_create. If this
1673 * allocation fails we are able to report the failure to the application
1674 * with an EAGAIN error.
1675 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001676struct sigqueue *sigqueue_alloc(void)
1677{
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +09001678 struct sigqueue *q = __sigqueue_alloc(-1, current, GFP_KERNEL, 0);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001679
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +09001680 if (q)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001681 q->flags |= SIGQUEUE_PREALLOC;
Naohiro Ooiwaf84d49b2009-11-09 00:46:42 +09001682
1683 return q;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001684}
1685
1686void sigqueue_free(struct sigqueue *q)
1687{
1688 unsigned long flags;
Oleg Nesterov60187d22007-08-30 23:56:35 -07001689 spinlock_t *lock = &current->sighand->siglock;
1690
Linus Torvalds1da177e2005-04-16 15:20:36 -07001691 BUG_ON(!(q->flags & SIGQUEUE_PREALLOC));
1692 /*
Oleg Nesterovc8e85b4f2008-05-26 20:55:42 +04001693 * We must hold ->siglock while testing q->list
1694 * to serialize with collect_signal() or with
Oleg Nesterovda7978b2008-05-23 13:04:41 -07001695 * __exit_signal()->flush_sigqueue().
Linus Torvalds1da177e2005-04-16 15:20:36 -07001696 */
Oleg Nesterov60187d22007-08-30 23:56:35 -07001697 spin_lock_irqsave(lock, flags);
Oleg Nesterovc8e85b4f2008-05-26 20:55:42 +04001698 q->flags &= ~SIGQUEUE_PREALLOC;
1699 /*
1700 * If it is queued it will be freed when dequeued,
1701 * like the "regular" sigqueue.
1702 */
Oleg Nesterov60187d22007-08-30 23:56:35 -07001703 if (!list_empty(&q->list))
Oleg Nesterovc8e85b4f2008-05-26 20:55:42 +04001704 q = NULL;
Oleg Nesterov60187d22007-08-30 23:56:35 -07001705 spin_unlock_irqrestore(lock, flags);
1706
Oleg Nesterovc8e85b4f2008-05-26 20:55:42 +04001707 if (q)
1708 __sigqueue_free(q);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001709}
1710
Eric W. Biederman24122c72018-07-20 14:30:23 -05001711int send_sigqueue(struct sigqueue *q, struct pid *pid, enum pid_type type)
Pavel Emelyanov9e3bd6c2008-04-30 00:52:41 -07001712{
Oleg Nesterove62e6652008-04-30 00:52:56 -07001713 int sig = q->info.si_signo;
Oleg Nesterov2ca35152008-04-30 00:52:54 -07001714 struct sigpending *pending;
Eric W. Biederman24122c72018-07-20 14:30:23 -05001715 struct task_struct *t;
Oleg Nesterove62e6652008-04-30 00:52:56 -07001716 unsigned long flags;
Oleg Nesterov163566f2011-11-22 21:37:41 +01001717 int ret, result;
Oleg Nesterov2ca35152008-04-30 00:52:54 -07001718
Pavel Emelyanov4cd4b6d2008-04-30 00:52:55 -07001719 BUG_ON(!(q->flags & SIGQUEUE_PREALLOC));
Oleg Nesterove62e6652008-04-30 00:52:56 -07001720
1721 ret = -1;
Eric W. Biederman24122c72018-07-20 14:30:23 -05001722 rcu_read_lock();
1723 t = pid_task(pid, type);
1724 if (!t || !likely(lock_task_sighand(t, &flags)))
Oleg Nesterove62e6652008-04-30 00:52:56 -07001725 goto ret;
1726
Oleg Nesterov7e695a52008-04-30 00:52:59 -07001727 ret = 1; /* the signal is ignored */
Oleg Nesterov163566f2011-11-22 21:37:41 +01001728 result = TRACE_SIGNAL_IGNORED;
Oleg Nesterovdef8cf72012-03-23 15:02:45 -07001729 if (!prepare_signal(sig, t, false))
Oleg Nesterove62e6652008-04-30 00:52:56 -07001730 goto out;
1731
1732 ret = 0;
Pavel Emelyanov9e3bd6c2008-04-30 00:52:41 -07001733 if (unlikely(!list_empty(&q->list))) {
1734 /*
1735 * If an SI_TIMER entry is already queue just increment
1736 * the overrun count.
1737 */
Pavel Emelyanov9e3bd6c2008-04-30 00:52:41 -07001738 BUG_ON(q->info.si_code != SI_TIMER);
1739 q->info.si_overrun++;
Oleg Nesterov163566f2011-11-22 21:37:41 +01001740 result = TRACE_SIGNAL_ALREADY_PENDING;
Oleg Nesterove62e6652008-04-30 00:52:56 -07001741 goto out;
Pavel Emelyanov9e3bd6c2008-04-30 00:52:41 -07001742 }
Oleg Nesterovba661292008-07-23 20:52:05 +04001743 q->info.si_overrun = 0;
Pavel Emelyanov9e3bd6c2008-04-30 00:52:41 -07001744
Pavel Emelyanov9e3bd6c2008-04-30 00:52:41 -07001745 signalfd_notify(t, sig);
Eric W. Biederman24122c72018-07-20 14:30:23 -05001746 pending = (type != PIDTYPE_PID) ? &t->signal->shared_pending : &t->pending;
Pavel Emelyanov9e3bd6c2008-04-30 00:52:41 -07001747 list_add_tail(&q->list, &pending->list);
1748 sigaddset(&pending->signal, sig);
Eric W. Biederman07296142018-07-13 21:39:13 -05001749 complete_signal(sig, t, type);
Oleg Nesterov163566f2011-11-22 21:37:41 +01001750 result = TRACE_SIGNAL_DELIVERED;
Oleg Nesterove62e6652008-04-30 00:52:56 -07001751out:
Eric W. Biederman24122c72018-07-20 14:30:23 -05001752 trace_signal_generate(sig, &q->info, t, type != PIDTYPE_PID, result);
Oleg Nesterove62e6652008-04-30 00:52:56 -07001753 unlock_task_sighand(t, &flags);
1754ret:
Eric W. Biederman24122c72018-07-20 14:30:23 -05001755 rcu_read_unlock();
Oleg Nesterove62e6652008-04-30 00:52:56 -07001756 return ret;
Pavel Emelyanov9e3bd6c2008-04-30 00:52:41 -07001757}
1758
Linus Torvalds1da177e2005-04-16 15:20:36 -07001759/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07001760 * Let a parent know about the death of a child.
1761 * For a stopped/continued status change, use do_notify_parent_cldstop instead.
Roland McGrath2b2a1ff2008-07-25 19:45:54 -07001762 *
Oleg Nesterov53c8f9f2011-06-22 23:08:18 +02001763 * Returns true if our parent ignored us and so we've switched to
1764 * self-reaping.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001765 */
Oleg Nesterov53c8f9f2011-06-22 23:08:18 +02001766bool do_notify_parent(struct task_struct *tsk, int sig)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001767{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001768 struct kernel_siginfo info;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001769 unsigned long flags;
1770 struct sighand_struct *psig;
Oleg Nesterov53c8f9f2011-06-22 23:08:18 +02001771 bool autoreap = false;
Frederic Weisbeckerbde82852017-01-31 04:09:31 +01001772 u64 utime, stime;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001773
1774 BUG_ON(sig == -1);
1775
1776 /* do_notify_parent_cldstop should have been called instead. */
Matthew Wilcoxe1abb392007-12-06 11:07:35 -05001777 BUG_ON(task_is_stopped_or_traced(tsk));
Linus Torvalds1da177e2005-04-16 15:20:36 -07001778
Tejun Heod21142e2011-06-17 16:50:34 +02001779 BUG_ON(!tsk->ptrace &&
Linus Torvalds1da177e2005-04-16 15:20:36 -07001780 (tsk->group_leader != tsk || !thread_group_empty(tsk)));
1781
Oleg Nesterovb6e238d2012-03-19 17:03:41 +01001782 if (sig != SIGCHLD) {
1783 /*
1784 * This is only possible if parent == real_parent.
1785 * Check if it has changed security domain.
1786 */
1787 if (tsk->parent_exec_id != tsk->parent->self_exec_id)
1788 sig = SIGCHLD;
1789 }
1790
Eric W. Biedermanfaf1f222018-01-05 17:27:42 -06001791 clear_siginfo(&info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001792 info.si_signo = sig;
1793 info.si_errno = 0;
Pavel Emelyanovb4888932007-10-18 23:40:14 -07001794 /*
Eric W. Biederman32084502012-05-31 16:26:39 -07001795 * We are under tasklist_lock here so our parent is tied to
1796 * us and cannot change.
Pavel Emelyanovb4888932007-10-18 23:40:14 -07001797 *
Eric W. Biederman32084502012-05-31 16:26:39 -07001798 * task_active_pid_ns will always return the same pid namespace
1799 * until a task passes through release_task.
Pavel Emelyanovb4888932007-10-18 23:40:14 -07001800 *
1801 * write_lock() currently calls preempt_disable() which is the
1802 * same as rcu_read_lock(), but according to Oleg, this is not
1803 * correct to rely on this
1804 */
1805 rcu_read_lock();
Eric W. Biederman32084502012-05-31 16:26:39 -07001806 info.si_pid = task_pid_nr_ns(tsk, task_active_pid_ns(tsk->parent));
Eric W. Biederman54ba47e2012-03-13 16:04:35 -07001807 info.si_uid = from_kuid_munged(task_cred_xxx(tsk->parent, user_ns),
1808 task_uid(tsk));
Pavel Emelyanovb4888932007-10-18 23:40:14 -07001809 rcu_read_unlock();
1810
Frederic Weisbeckerbde82852017-01-31 04:09:31 +01001811 task_cputime(tsk, &utime, &stime);
1812 info.si_utime = nsec_to_clock_t(utime + tsk->signal->utime);
1813 info.si_stime = nsec_to_clock_t(stime + tsk->signal->stime);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001814
1815 info.si_status = tsk->exit_code & 0x7f;
1816 if (tsk->exit_code & 0x80)
1817 info.si_code = CLD_DUMPED;
1818 else if (tsk->exit_code & 0x7f)
1819 info.si_code = CLD_KILLED;
1820 else {
1821 info.si_code = CLD_EXITED;
1822 info.si_status = tsk->exit_code >> 8;
1823 }
1824
1825 psig = tsk->parent->sighand;
1826 spin_lock_irqsave(&psig->siglock, flags);
Tejun Heod21142e2011-06-17 16:50:34 +02001827 if (!tsk->ptrace && sig == SIGCHLD &&
Linus Torvalds1da177e2005-04-16 15:20:36 -07001828 (psig->action[SIGCHLD-1].sa.sa_handler == SIG_IGN ||
1829 (psig->action[SIGCHLD-1].sa.sa_flags & SA_NOCLDWAIT))) {
1830 /*
1831 * We are exiting and our parent doesn't care. POSIX.1
1832 * defines special semantics for setting SIGCHLD to SIG_IGN
1833 * or setting the SA_NOCLDWAIT flag: we should be reaped
1834 * automatically and not left for our parent's wait4 call.
1835 * Rather than having the parent do it as a magic kind of
1836 * signal handler, we just set this to tell do_exit that we
1837 * can be cleaned up without becoming a zombie. Note that
1838 * we still call __wake_up_parent in this case, because a
1839 * blocked sys_wait4 might now return -ECHILD.
1840 *
1841 * Whether we send SIGCHLD or not for SA_NOCLDWAIT
1842 * is implementation-defined: we do (if you don't want
1843 * it, just use SIG_IGN instead).
1844 */
Oleg Nesterov53c8f9f2011-06-22 23:08:18 +02001845 autoreap = true;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001846 if (psig->action[SIGCHLD-1].sa.sa_handler == SIG_IGN)
Oleg Nesterov53c8f9f2011-06-22 23:08:18 +02001847 sig = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001848 }
Oleg Nesterov53c8f9f2011-06-22 23:08:18 +02001849 if (valid_signal(sig) && sig)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001850 __group_send_sig_info(sig, &info, tsk->parent);
1851 __wake_up_parent(tsk, tsk->parent);
1852 spin_unlock_irqrestore(&psig->siglock, flags);
Roland McGrath2b2a1ff2008-07-25 19:45:54 -07001853
Oleg Nesterov53c8f9f2011-06-22 23:08:18 +02001854 return autoreap;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001855}
1856
Tejun Heo75b95952011-03-23 10:37:01 +01001857/**
1858 * do_notify_parent_cldstop - notify parent of stopped/continued state change
1859 * @tsk: task reporting the state change
1860 * @for_ptracer: the notification is for ptracer
1861 * @why: CLD_{CONTINUED|STOPPED|TRAPPED} to report
1862 *
1863 * Notify @tsk's parent that the stopped/continued state has changed. If
1864 * @for_ptracer is %false, @tsk's group leader notifies to its real parent.
1865 * If %true, @tsk reports to @tsk->parent which should be the ptracer.
1866 *
1867 * CONTEXT:
1868 * Must be called with tasklist_lock at least read locked.
1869 */
1870static void do_notify_parent_cldstop(struct task_struct *tsk,
1871 bool for_ptracer, int why)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001872{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001873 struct kernel_siginfo info;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001874 unsigned long flags;
Oleg Nesterovbc505a42005-09-06 15:17:32 -07001875 struct task_struct *parent;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001876 struct sighand_struct *sighand;
Frederic Weisbeckerbde82852017-01-31 04:09:31 +01001877 u64 utime, stime;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001878
Tejun Heo75b95952011-03-23 10:37:01 +01001879 if (for_ptracer) {
Oleg Nesterovbc505a42005-09-06 15:17:32 -07001880 parent = tsk->parent;
Tejun Heo75b95952011-03-23 10:37:01 +01001881 } else {
Oleg Nesterovbc505a42005-09-06 15:17:32 -07001882 tsk = tsk->group_leader;
1883 parent = tsk->real_parent;
1884 }
1885
Eric W. Biedermanfaf1f222018-01-05 17:27:42 -06001886 clear_siginfo(&info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001887 info.si_signo = SIGCHLD;
1888 info.si_errno = 0;
Pavel Emelyanovb4888932007-10-18 23:40:14 -07001889 /*
Randy Dunlap5aba0852011-04-04 14:59:31 -07001890 * see comment in do_notify_parent() about the following 4 lines
Pavel Emelyanovb4888932007-10-18 23:40:14 -07001891 */
1892 rcu_read_lock();
Eric W. Biederman17cf22c2010-03-02 14:51:53 -08001893 info.si_pid = task_pid_nr_ns(tsk, task_active_pid_ns(parent));
Eric W. Biederman54ba47e2012-03-13 16:04:35 -07001894 info.si_uid = from_kuid_munged(task_cred_xxx(parent, user_ns), task_uid(tsk));
Pavel Emelyanovb4888932007-10-18 23:40:14 -07001895 rcu_read_unlock();
1896
Frederic Weisbeckerbde82852017-01-31 04:09:31 +01001897 task_cputime(tsk, &utime, &stime);
1898 info.si_utime = nsec_to_clock_t(utime);
1899 info.si_stime = nsec_to_clock_t(stime);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001900
1901 info.si_code = why;
1902 switch (why) {
1903 case CLD_CONTINUED:
1904 info.si_status = SIGCONT;
1905 break;
1906 case CLD_STOPPED:
1907 info.si_status = tsk->signal->group_exit_code & 0x7f;
1908 break;
1909 case CLD_TRAPPED:
1910 info.si_status = tsk->exit_code & 0x7f;
1911 break;
1912 default:
1913 BUG();
1914 }
1915
1916 sighand = parent->sighand;
1917 spin_lock_irqsave(&sighand->siglock, flags);
1918 if (sighand->action[SIGCHLD-1].sa.sa_handler != SIG_IGN &&
1919 !(sighand->action[SIGCHLD-1].sa.sa_flags & SA_NOCLDSTOP))
1920 __group_send_sig_info(SIGCHLD, &info, parent);
1921 /*
1922 * Even if SIGCHLD is not generated, we must wake up wait4 calls.
1923 */
1924 __wake_up_parent(tsk, parent);
1925 spin_unlock_irqrestore(&sighand->siglock, flags);
1926}
1927
Christian Brauner6527de92018-08-21 21:59:59 -07001928static inline bool may_ptrace_stop(void)
Oleg Nesterovd5f70c02006-06-26 00:26:07 -07001929{
Tejun Heod21142e2011-06-17 16:50:34 +02001930 if (!likely(current->ptrace))
Christian Brauner6527de92018-08-21 21:59:59 -07001931 return false;
Oleg Nesterovd5f70c02006-06-26 00:26:07 -07001932 /*
1933 * Are we in the middle of do_coredump?
1934 * If so and our tracer is also part of the coredump stopping
1935 * is a deadlock situation, and pointless because our tracer
1936 * is dead so don't allow us to stop.
1937 * If SIGKILL was already sent before the caller unlocked
Oleg Nesterov999d9fc2008-07-25 01:47:41 -07001938 * ->siglock we must see ->core_state != NULL. Otherwise it
Oleg Nesterovd5f70c02006-06-26 00:26:07 -07001939 * is safe to enter schedule().
Oleg Nesterov9899d112013-01-21 20:48:00 +01001940 *
1941 * This is almost outdated, a task with the pending SIGKILL can't
1942 * block in TASK_TRACED. But PTRACE_EVENT_EXIT can be reported
1943 * after SIGKILL was already dequeued.
Oleg Nesterovd5f70c02006-06-26 00:26:07 -07001944 */
Oleg Nesterov999d9fc2008-07-25 01:47:41 -07001945 if (unlikely(current->mm->core_state) &&
Oleg Nesterovd5f70c02006-06-26 00:26:07 -07001946 unlikely(current->mm == current->parent->mm))
Christian Brauner6527de92018-08-21 21:59:59 -07001947 return false;
Oleg Nesterovd5f70c02006-06-26 00:26:07 -07001948
Christian Brauner6527de92018-08-21 21:59:59 -07001949 return true;
Oleg Nesterovd5f70c02006-06-26 00:26:07 -07001950}
1951
Linus Torvalds1da177e2005-04-16 15:20:36 -07001952/*
Randy Dunlap5aba0852011-04-04 14:59:31 -07001953 * Return non-zero if there is a SIGKILL that should be waking us up.
Roland McGrath1a669c22008-02-06 01:37:37 -08001954 * Called with the siglock held.
1955 */
Christian Braunerf99e9d82018-08-21 22:00:50 -07001956static bool sigkill_pending(struct task_struct *tsk)
Roland McGrath1a669c22008-02-06 01:37:37 -08001957{
Christian Braunerf99e9d82018-08-21 22:00:50 -07001958 return sigismember(&tsk->pending.signal, SIGKILL) ||
1959 sigismember(&tsk->signal->shared_pending.signal, SIGKILL);
Roland McGrath1a669c22008-02-06 01:37:37 -08001960}
1961
1962/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07001963 * This must be called with current->sighand->siglock held.
1964 *
1965 * This should be the path for all ptrace stops.
1966 * We always set current->last_siginfo while stopped here.
1967 * That makes it a way to test a stopped process for
1968 * being ptrace-stopped vs being job-control-stopped.
1969 *
Oleg Nesterov20686a32008-02-08 04:19:03 -08001970 * If we actually decide not to stop at all because the tracer
1971 * is gone, we keep current->exit_code unless clear_code.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001972 */
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02001973static void ptrace_stop(int exit_code, int why, int clear_code, kernel_siginfo_t *info)
Namhyung Kimb8401152010-10-27 15:34:07 -07001974 __releases(&current->sighand->siglock)
1975 __acquires(&current->sighand->siglock)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001976{
Tejun Heoceb6bd62011-03-23 10:37:01 +01001977 bool gstop_done = false;
1978
Roland McGrath1a669c22008-02-06 01:37:37 -08001979 if (arch_ptrace_stop_needed(exit_code, info)) {
1980 /*
1981 * The arch code has something special to do before a
1982 * ptrace stop. This is allowed to block, e.g. for faults
1983 * on user stack pages. We can't keep the siglock while
1984 * calling arch_ptrace_stop, so we must release it now.
1985 * To preserve proper semantics, we must do this before
1986 * any signal bookkeeping like checking group_stop_count.
1987 * Meanwhile, a SIGKILL could come in before we retake the
1988 * siglock. That must prevent us from sleeping in TASK_TRACED.
1989 * So after regaining the lock, we must check for SIGKILL.
1990 */
1991 spin_unlock_irq(&current->sighand->siglock);
1992 arch_ptrace_stop(exit_code, info);
1993 spin_lock_irq(&current->sighand->siglock);
Oleg Nesterov3d749b92008-07-25 01:47:37 -07001994 if (sigkill_pending(current))
1995 return;
Roland McGrath1a669c22008-02-06 01:37:37 -08001996 }
1997
Peter Zijlstrab5bf9a92018-04-30 14:51:01 +02001998 set_special_state(TASK_TRACED);
1999
Linus Torvalds1da177e2005-04-16 15:20:36 -07002000 /*
Tejun Heo81be24b2011-06-02 11:13:59 +02002001 * We're committing to trapping. TRACED should be visible before
2002 * TRAPPING is cleared; otherwise, the tracer might fail do_wait().
2003 * Also, transition to TRACED and updates to ->jobctl should be
2004 * atomic with respect to siglock and should be done after the arch
2005 * hook as siglock is released and regrabbed across it.
Peter Zijlstrab5bf9a92018-04-30 14:51:01 +02002006 *
2007 * TRACER TRACEE
2008 *
2009 * ptrace_attach()
2010 * [L] wait_on_bit(JOBCTL_TRAPPING) [S] set_special_state(TRACED)
2011 * do_wait()
2012 * set_current_state() smp_wmb();
2013 * ptrace_do_wait()
2014 * wait_task_stopped()
2015 * task_stopped_code()
2016 * [L] task_is_traced() [S] task_clear_jobctl_trapping();
Linus Torvalds1da177e2005-04-16 15:20:36 -07002017 */
Peter Zijlstrab5bf9a92018-04-30 14:51:01 +02002018 smp_wmb();
Linus Torvalds1da177e2005-04-16 15:20:36 -07002019
2020 current->last_siginfo = info;
2021 current->exit_code = exit_code;
2022
Tejun Heod79fdd62011-03-23 10:37:00 +01002023 /*
Linus Torvalds1da177e2005-04-16 15:20:36 -07002024 * If @why is CLD_STOPPED, we're trapping to participate in a group
2025 * stop. Do the bookkeeping. Note that if SIGCONT was delievered
Tejun Heo73ddff22011-06-14 11:20:14 +02002026 * across siglock relocks since INTERRUPT was scheduled, PENDING
2027 * could be clear now. We act as if SIGCONT is received after
2028 * TASK_TRACED is entered - ignore it.
Tejun Heod79fdd62011-03-23 10:37:00 +01002029 */
Tejun Heoa8f072c2011-06-02 11:13:59 +02002030 if (why == CLD_STOPPED && (current->jobctl & JOBCTL_STOP_PENDING))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002031 gstop_done = task_participate_group_stop(current);
Tejun Heod79fdd62011-03-23 10:37:00 +01002032
Tejun Heofb1d9102011-06-14 11:20:17 +02002033 /* any trap clears pending STOP trap, STOP trap clears NOTIFY */
Tejun Heo73ddff22011-06-14 11:20:14 +02002034 task_clear_jobctl_pending(current, JOBCTL_TRAP_STOP);
Tejun Heofb1d9102011-06-14 11:20:17 +02002035 if (info && info->si_code >> 8 == PTRACE_EVENT_STOP)
2036 task_clear_jobctl_pending(current, JOBCTL_TRAP_NOTIFY);
Tejun Heo73ddff22011-06-14 11:20:14 +02002037
Tejun Heo81be24b2011-06-02 11:13:59 +02002038 /* entering a trap, clear TRAPPING */
Tejun Heoa8f072c2011-06-02 11:13:59 +02002039 task_clear_jobctl_trapping(current);
Tejun Heod79fdd62011-03-23 10:37:00 +01002040
Linus Torvalds1da177e2005-04-16 15:20:36 -07002041 spin_unlock_irq(&current->sighand->siglock);
2042 read_lock(&tasklist_lock);
Oleg Nesterov3d749b92008-07-25 01:47:37 -07002043 if (may_ptrace_stop()) {
Tejun Heoceb6bd62011-03-23 10:37:01 +01002044 /*
2045 * Notify parents of the stop.
2046 *
2047 * While ptraced, there are two parents - the ptracer and
2048 * the real_parent of the group_leader. The ptracer should
2049 * know about every stop while the real parent is only
2050 * interested in the completion of group stop. The states
2051 * for the two don't interact with each other. Notify
2052 * separately unless they're gonna be duplicates.
2053 */
2054 do_notify_parent_cldstop(current, true, why);
Oleg Nesterovbb3696d2011-06-24 17:34:23 +02002055 if (gstop_done && ptrace_reparented(current))
Tejun Heoceb6bd62011-03-23 10:37:01 +01002056 do_notify_parent_cldstop(current, false, why);
2057
Miklos Szeredi53da1d92009-03-23 16:07:24 +01002058 /*
2059 * Don't want to allow preemption here, because
2060 * sys_ptrace() needs this task to be inactive.
2061 *
2062 * XXX: implement read_unlock_no_resched().
2063 */
2064 preempt_disable();
Linus Torvalds1da177e2005-04-16 15:20:36 -07002065 read_unlock(&tasklist_lock);
Miklos Szeredi53da1d92009-03-23 16:07:24 +01002066 preempt_enable_no_resched();
Oleg Nesterov5d8f72b2012-10-26 19:46:06 +02002067 freezable_schedule();
Linus Torvalds1da177e2005-04-16 15:20:36 -07002068 } else {
2069 /*
2070 * By the time we got the lock, our tracer went away.
Oleg Nesterov6405f7f2008-02-08 04:19:00 -08002071 * Don't drop the lock yet, another tracer may come.
Tejun Heoceb6bd62011-03-23 10:37:01 +01002072 *
2073 * If @gstop_done, the ptracer went away between group stop
2074 * completion and here. During detach, it would have set
Tejun Heoa8f072c2011-06-02 11:13:59 +02002075 * JOBCTL_STOP_PENDING on us and we'll re-enter
2076 * TASK_STOPPED in do_signal_stop() on return, so notifying
2077 * the real parent of the group stop completion is enough.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002078 */
Tejun Heoceb6bd62011-03-23 10:37:01 +01002079 if (gstop_done)
2080 do_notify_parent_cldstop(current, false, why);
2081
Oleg Nesterov9899d112013-01-21 20:48:00 +01002082 /* tasklist protects us from ptrace_freeze_traced() */
Oleg Nesterov6405f7f2008-02-08 04:19:00 -08002083 __set_current_state(TASK_RUNNING);
Oleg Nesterov20686a32008-02-08 04:19:03 -08002084 if (clear_code)
2085 current->exit_code = 0;
Oleg Nesterov6405f7f2008-02-08 04:19:00 -08002086 read_unlock(&tasklist_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002087 }
2088
2089 /*
2090 * We are back. Now reacquire the siglock before touching
2091 * last_siginfo, so that we are sure to have synchronized with
2092 * any signal-sending on another CPU that wants to examine it.
2093 */
2094 spin_lock_irq(&current->sighand->siglock);
2095 current->last_siginfo = NULL;
2096
Tejun Heo544b2c92011-06-14 11:20:18 +02002097 /* LISTENING can be set only during STOP traps, clear it */
2098 current->jobctl &= ~JOBCTL_LISTENING;
2099
Linus Torvalds1da177e2005-04-16 15:20:36 -07002100 /*
2101 * Queued signals ignored us while we were stopped for tracing.
2102 * So check for any that we should take before resuming user mode.
Roland McGrathb74d0de2007-06-06 03:59:00 -07002103 * This sets TIF_SIGPENDING, but never clears it.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002104 */
Roland McGrathb74d0de2007-06-06 03:59:00 -07002105 recalc_sigpending_tsk(current);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002106}
2107
Tejun Heo3544d722011-06-14 11:20:15 +02002108static void ptrace_do_notify(int signr, int exit_code, int why)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002109{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02002110 kernel_siginfo_t info;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002111
Eric W. Biedermanfaf1f222018-01-05 17:27:42 -06002112 clear_siginfo(&info);
Tejun Heo3544d722011-06-14 11:20:15 +02002113 info.si_signo = signr;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002114 info.si_code = exit_code;
Pavel Emelyanovb4888932007-10-18 23:40:14 -07002115 info.si_pid = task_pid_vnr(current);
Eric W. Biederman078de5f2012-02-08 07:00:08 -08002116 info.si_uid = from_kuid_munged(current_user_ns(), current_uid());
Linus Torvalds1da177e2005-04-16 15:20:36 -07002117
2118 /* Let the debugger run. */
Tejun Heo3544d722011-06-14 11:20:15 +02002119 ptrace_stop(exit_code, why, 1, &info);
2120}
2121
2122void ptrace_notify(int exit_code)
2123{
2124 BUG_ON((exit_code & (0x7f | ~0xffff)) != SIGTRAP);
Oleg Nesterovf784e8a2012-08-26 21:12:17 +02002125 if (unlikely(current->task_works))
2126 task_work_run();
Tejun Heo3544d722011-06-14 11:20:15 +02002127
Linus Torvalds1da177e2005-04-16 15:20:36 -07002128 spin_lock_irq(&current->sighand->siglock);
Tejun Heo3544d722011-06-14 11:20:15 +02002129 ptrace_do_notify(SIGTRAP, exit_code, CLD_TRAPPED);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002130 spin_unlock_irq(&current->sighand->siglock);
2131}
2132
Tejun Heo73ddff22011-06-14 11:20:14 +02002133/**
2134 * do_signal_stop - handle group stop for SIGSTOP and other stop signals
2135 * @signr: signr causing group stop if initiating
2136 *
2137 * If %JOBCTL_STOP_PENDING is not set yet, initiate group stop with @signr
2138 * and participate in it. If already set, participate in the existing
2139 * group stop. If participated in a group stop (and thus slept), %true is
2140 * returned with siglock released.
2141 *
2142 * If ptraced, this function doesn't handle stop itself. Instead,
2143 * %JOBCTL_TRAP_STOP is scheduled and %false is returned with siglock
2144 * untouched. The caller must ensure that INTERRUPT trap handling takes
2145 * places afterwards.
2146 *
2147 * CONTEXT:
2148 * Must be called with @current->sighand->siglock held, which is released
2149 * on %true return.
2150 *
2151 * RETURNS:
2152 * %false if group stop is already cancelled or ptrace trap is scheduled.
2153 * %true if participated in group stop.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002154 */
Tejun Heo73ddff22011-06-14 11:20:14 +02002155static bool do_signal_stop(int signr)
2156 __releases(&current->sighand->siglock)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002157{
2158 struct signal_struct *sig = current->signal;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002159
Tejun Heoa8f072c2011-06-02 11:13:59 +02002160 if (!(current->jobctl & JOBCTL_STOP_PENDING)) {
Palmer Dabbeltb76808e2015-04-30 21:19:57 -07002161 unsigned long gstop = JOBCTL_STOP_PENDING | JOBCTL_STOP_CONSUME;
Oleg Nesterovf558b7e2008-02-04 22:27:24 -08002162 struct task_struct *t;
2163
Tejun Heoa8f072c2011-06-02 11:13:59 +02002164 /* signr will be recorded in task->jobctl for retries */
2165 WARN_ON_ONCE(signr & ~JOBCTL_STOP_SIGMASK);
Tejun Heod79fdd62011-03-23 10:37:00 +01002166
Tejun Heoa8f072c2011-06-02 11:13:59 +02002167 if (!likely(current->jobctl & JOBCTL_STOP_DEQUEUED) ||
Oleg Nesterov573cf9a2008-04-30 00:52:36 -07002168 unlikely(signal_group_exit(sig)))
Tejun Heo73ddff22011-06-14 11:20:14 +02002169 return false;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002170 /*
Tejun Heo408a37d2011-03-23 10:37:01 +01002171 * There is no group stop already in progress. We must
2172 * initiate one now.
2173 *
2174 * While ptraced, a task may be resumed while group stop is
2175 * still in effect and then receive a stop signal and
2176 * initiate another group stop. This deviates from the
2177 * usual behavior as two consecutive stop signals can't
Oleg Nesterov780006eac2011-04-01 20:12:16 +02002178 * cause two group stops when !ptraced. That is why we
2179 * also check !task_is_stopped(t) below.
Tejun Heo408a37d2011-03-23 10:37:01 +01002180 *
2181 * The condition can be distinguished by testing whether
2182 * SIGNAL_STOP_STOPPED is already set. Don't generate
2183 * group_exit_code in such case.
2184 *
2185 * This is not necessary for SIGNAL_STOP_CONTINUED because
2186 * an intervening stop signal is required to cause two
2187 * continued events regardless of ptrace.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002188 */
Tejun Heo408a37d2011-03-23 10:37:01 +01002189 if (!(sig->flags & SIGNAL_STOP_STOPPED))
2190 sig->group_exit_code = signr;
Oleg Nesterova122b342006-03-28 16:11:22 -08002191
Tejun Heo7dd3db52011-06-02 11:14:00 +02002192 sig->group_stop_count = 0;
2193
2194 if (task_set_jobctl_pending(current, signr | gstop))
2195 sig->group_stop_count++;
2196
Oleg Nesterov8d38f202014-01-23 15:55:56 -08002197 t = current;
2198 while_each_thread(current, t) {
Oleg Nesterova122b342006-03-28 16:11:22 -08002199 /*
2200 * Setting state to TASK_STOPPED for a group
2201 * stop is always done with the siglock held,
2202 * so this check has no races.
2203 */
Tejun Heo7dd3db52011-06-02 11:14:00 +02002204 if (!task_is_stopped(t) &&
2205 task_set_jobctl_pending(t, signr | gstop)) {
Roland McGrathae6d2ed2009-09-23 15:56:53 -07002206 sig->group_stop_count++;
Tejun Heofb1d9102011-06-14 11:20:17 +02002207 if (likely(!(t->ptrace & PT_SEIZED)))
2208 signal_wake_up(t, 0);
2209 else
2210 ptrace_trap_notify(t);
Oleg Nesterova122b342006-03-28 16:11:22 -08002211 }
Tejun Heod79fdd62011-03-23 10:37:00 +01002212 }
Roland McGrathae6d2ed2009-09-23 15:56:53 -07002213 }
Tejun Heo73ddff22011-06-14 11:20:14 +02002214
Tejun Heod21142e2011-06-17 16:50:34 +02002215 if (likely(!current->ptrace)) {
Tejun Heo5224fa32011-03-23 10:37:00 +01002216 int notify = 0;
2217
2218 /*
2219 * If there are no other threads in the group, or if there
2220 * is a group stop in progress and we are the last to stop,
2221 * report to the parent.
2222 */
2223 if (task_participate_group_stop(current))
2224 notify = CLD_STOPPED;
2225
Peter Zijlstrab5bf9a92018-04-30 14:51:01 +02002226 set_special_state(TASK_STOPPED);
Tejun Heo5224fa32011-03-23 10:37:00 +01002227 spin_unlock_irq(&current->sighand->siglock);
2228
Tejun Heo62bcf9d2011-03-23 10:37:01 +01002229 /*
2230 * Notify the parent of the group stop completion. Because
2231 * we're not holding either the siglock or tasklist_lock
2232 * here, ptracer may attach inbetween; however, this is for
2233 * group stop and should always be delivered to the real
2234 * parent of the group leader. The new ptracer will get
2235 * its notification when this task transitions into
2236 * TASK_TRACED.
2237 */
Tejun Heo5224fa32011-03-23 10:37:00 +01002238 if (notify) {
2239 read_lock(&tasklist_lock);
Tejun Heo62bcf9d2011-03-23 10:37:01 +01002240 do_notify_parent_cldstop(current, false, notify);
Tejun Heo5224fa32011-03-23 10:37:00 +01002241 read_unlock(&tasklist_lock);
2242 }
2243
2244 /* Now we don't run again until woken by SIGCONT or SIGKILL */
Oleg Nesterov5d8f72b2012-10-26 19:46:06 +02002245 freezable_schedule();
Tejun Heo73ddff22011-06-14 11:20:14 +02002246 return true;
Tejun Heod79fdd62011-03-23 10:37:00 +01002247 } else {
Tejun Heo73ddff22011-06-14 11:20:14 +02002248 /*
2249 * While ptraced, group stop is handled by STOP trap.
2250 * Schedule it and let the caller deal with it.
2251 */
2252 task_set_jobctl_pending(current, JOBCTL_TRAP_STOP);
2253 return false;
Roland McGrathae6d2ed2009-09-23 15:56:53 -07002254 }
Tejun Heo73ddff22011-06-14 11:20:14 +02002255}
Tejun Heod79fdd62011-03-23 10:37:00 +01002256
Tejun Heo73ddff22011-06-14 11:20:14 +02002257/**
2258 * do_jobctl_trap - take care of ptrace jobctl traps
2259 *
Tejun Heo3544d722011-06-14 11:20:15 +02002260 * When PT_SEIZED, it's used for both group stop and explicit
2261 * SEIZE/INTERRUPT traps. Both generate PTRACE_EVENT_STOP trap with
2262 * accompanying siginfo. If stopped, lower eight bits of exit_code contain
2263 * the stop signal; otherwise, %SIGTRAP.
2264 *
2265 * When !PT_SEIZED, it's used only for group stop trap with stop signal
2266 * number as exit_code and no siginfo.
Tejun Heo73ddff22011-06-14 11:20:14 +02002267 *
2268 * CONTEXT:
2269 * Must be called with @current->sighand->siglock held, which may be
2270 * released and re-acquired before returning with intervening sleep.
2271 */
2272static void do_jobctl_trap(void)
2273{
Tejun Heo3544d722011-06-14 11:20:15 +02002274 struct signal_struct *signal = current->signal;
Tejun Heo73ddff22011-06-14 11:20:14 +02002275 int signr = current->jobctl & JOBCTL_STOP_SIGMASK;
Tejun Heod79fdd62011-03-23 10:37:00 +01002276
Tejun Heo3544d722011-06-14 11:20:15 +02002277 if (current->ptrace & PT_SEIZED) {
2278 if (!signal->group_stop_count &&
2279 !(signal->flags & SIGNAL_STOP_STOPPED))
2280 signr = SIGTRAP;
2281 WARN_ON_ONCE(!signr);
2282 ptrace_do_notify(signr, signr | (PTRACE_EVENT_STOP << 8),
2283 CLD_STOPPED);
2284 } else {
2285 WARN_ON_ONCE(!signr);
2286 ptrace_stop(signr, CLD_STOPPED, 0, NULL);
Roland McGrathae6d2ed2009-09-23 15:56:53 -07002287 current->exit_code = 0;
2288 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07002289}
2290
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02002291static int ptrace_signal(int signr, kernel_siginfo_t *info)
Roland McGrath18c98b62008-04-17 18:44:38 -07002292{
Oleg Nesterov8a352412011-07-21 17:06:53 +02002293 /*
2294 * We do not check sig_kernel_stop(signr) but set this marker
2295 * unconditionally because we do not know whether debugger will
2296 * change signr. This flag has no meaning unless we are going
2297 * to stop after return from ptrace_stop(). In this case it will
2298 * be checked in do_signal_stop(), we should only stop if it was
2299 * not cleared by SIGCONT while we were sleeping. See also the
2300 * comment in dequeue_signal().
2301 */
2302 current->jobctl |= JOBCTL_STOP_DEQUEUED;
Tejun Heofe1bc6a2011-03-23 10:37:00 +01002303 ptrace_stop(signr, CLD_TRAPPED, 0, info);
Roland McGrath18c98b62008-04-17 18:44:38 -07002304
2305 /* We're back. Did the debugger cancel the sig? */
2306 signr = current->exit_code;
2307 if (signr == 0)
2308 return signr;
2309
2310 current->exit_code = 0;
2311
Randy Dunlap5aba0852011-04-04 14:59:31 -07002312 /*
2313 * Update the siginfo structure if the signal has
2314 * changed. If the debugger wanted something
2315 * specific in the siginfo structure then it should
2316 * have updated *info via PTRACE_SETSIGINFO.
2317 */
Roland McGrath18c98b62008-04-17 18:44:38 -07002318 if (signr != info->si_signo) {
Eric W. Biedermanfaf1f222018-01-05 17:27:42 -06002319 clear_siginfo(info);
Roland McGrath18c98b62008-04-17 18:44:38 -07002320 info->si_signo = signr;
2321 info->si_errno = 0;
2322 info->si_code = SI_USER;
Serge E. Hallyn6b550f92012-01-10 15:11:37 -08002323 rcu_read_lock();
Roland McGrath18c98b62008-04-17 18:44:38 -07002324 info->si_pid = task_pid_vnr(current->parent);
Eric W. Biederman54ba47e2012-03-13 16:04:35 -07002325 info->si_uid = from_kuid_munged(current_user_ns(),
2326 task_uid(current->parent));
Serge E. Hallyn6b550f92012-01-10 15:11:37 -08002327 rcu_read_unlock();
Roland McGrath18c98b62008-04-17 18:44:38 -07002328 }
2329
2330 /* If the (new) signal is now blocked, requeue it. */
2331 if (sigismember(&current->blocked, signr)) {
Eric W. Biedermanb21c5bd2018-07-21 11:34:03 -05002332 send_signal(signr, info, current, PIDTYPE_PID);
Roland McGrath18c98b62008-04-17 18:44:38 -07002333 signr = 0;
2334 }
2335
2336 return signr;
2337}
2338
Christian Brauner20ab7212018-08-21 22:00:54 -07002339bool get_signal(struct ksignal *ksig)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002340{
Oleg Nesterovf6b76d42008-04-30 00:52:47 -07002341 struct sighand_struct *sighand = current->sighand;
2342 struct signal_struct *signal = current->signal;
2343 int signr;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002344
Oleg Nesterovf784e8a2012-08-26 21:12:17 +02002345 if (unlikely(current->task_works))
2346 task_work_run();
Al Viro72667022012-07-15 14:10:52 +04002347
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +05302348 if (unlikely(uprobe_deny_signal()))
Christian Brauner20ab7212018-08-21 22:00:54 -07002349 return false;
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +05302350
Roland McGrath13b1c3d2008-03-03 20:22:05 -08002351 /*
Oleg Nesterov5d8f72b2012-10-26 19:46:06 +02002352 * Do this once, we can't return to user-mode if freezing() == T.
2353 * do_signal_stop() and ptrace_stop() do freezable_schedule() and
2354 * thus do not need another check after return.
Roland McGrath13b1c3d2008-03-03 20:22:05 -08002355 */
Rafael J. Wysockifc558a72006-03-23 03:00:05 -08002356 try_to_freeze();
2357
Oleg Nesterov5d8f72b2012-10-26 19:46:06 +02002358relock:
Oleg Nesterovf6b76d42008-04-30 00:52:47 -07002359 spin_lock_irq(&sighand->siglock);
Oleg Nesterov021e1ae2008-04-30 00:53:00 -07002360 /*
2361 * Every stopped thread goes here after wakeup. Check to see if
2362 * we should notify the parent, prepare_signal(SIGCONT) encodes
2363 * the CLD_ si_code into SIGNAL_CLD_MASK bits.
2364 */
Oleg Nesterovf6b76d42008-04-30 00:52:47 -07002365 if (unlikely(signal->flags & SIGNAL_CLD_MASK)) {
Tejun Heoc672af32011-03-23 10:36:59 +01002366 int why;
2367
2368 if (signal->flags & SIGNAL_CLD_CONTINUED)
2369 why = CLD_CONTINUED;
2370 else
2371 why = CLD_STOPPED;
2372
Oleg Nesterovf6b76d42008-04-30 00:52:47 -07002373 signal->flags &= ~SIGNAL_CLD_MASK;
Roland McGrathae6d2ed2009-09-23 15:56:53 -07002374
Oleg Nesterovf6b76d42008-04-30 00:52:47 -07002375 spin_unlock_irq(&sighand->siglock);
Oleg Nesterove4420552008-04-30 00:52:44 -07002376
Tejun Heoceb6bd62011-03-23 10:37:01 +01002377 /*
2378 * Notify the parent that we're continuing. This event is
2379 * always per-process and doesn't make whole lot of sense
2380 * for ptracers, who shouldn't consume the state via
2381 * wait(2) either, but, for backward compatibility, notify
2382 * the ptracer of the group leader too unless it's gonna be
2383 * a duplicate.
2384 */
Tejun Heoedf2ed12011-03-23 10:37:00 +01002385 read_lock(&tasklist_lock);
Tejun Heoceb6bd62011-03-23 10:37:01 +01002386 do_notify_parent_cldstop(current, false, why);
2387
Oleg Nesterovbb3696d2011-06-24 17:34:23 +02002388 if (ptrace_reparented(current->group_leader))
2389 do_notify_parent_cldstop(current->group_leader,
2390 true, why);
Tejun Heoedf2ed12011-03-23 10:37:00 +01002391 read_unlock(&tasklist_lock);
Tejun Heoceb6bd62011-03-23 10:37:01 +01002392
Oleg Nesterove4420552008-04-30 00:52:44 -07002393 goto relock;
2394 }
2395
Linus Torvalds1da177e2005-04-16 15:20:36 -07002396 for (;;) {
2397 struct k_sigaction *ka;
Tejun Heodd1d6772011-06-02 11:14:00 +02002398
2399 if (unlikely(current->jobctl & JOBCTL_STOP_PENDING) &&
2400 do_signal_stop(0))
Roland McGrath7bcf6a22008-07-25 19:45:53 -07002401 goto relock;
Oleg Nesterov1be53962009-12-15 16:47:26 -08002402
Tejun Heo73ddff22011-06-14 11:20:14 +02002403 if (unlikely(current->jobctl & JOBCTL_TRAP_MASK)) {
2404 do_jobctl_trap();
2405 spin_unlock_irq(&sighand->siglock);
2406 goto relock;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002407 }
2408
Richard Weinberger828b1f62013-10-07 15:26:57 +02002409 signr = dequeue_signal(current, &current->blocked, &ksig->info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002410
Tejun Heodd1d6772011-06-02 11:14:00 +02002411 if (!signr)
2412 break; /* will return 0 */
2413
Oleg Nesterov8a352412011-07-21 17:06:53 +02002414 if (unlikely(current->ptrace) && signr != SIGKILL) {
Richard Weinberger828b1f62013-10-07 15:26:57 +02002415 signr = ptrace_signal(signr, &ksig->info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002416 if (!signr)
Tejun Heodd1d6772011-06-02 11:14:00 +02002417 continue;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002418 }
2419
Tejun Heodd1d6772011-06-02 11:14:00 +02002420 ka = &sighand->action[signr-1];
2421
Masami Hiramatsuf9d42572009-11-24 16:56:51 -05002422 /* Trace actually delivered signals. */
Richard Weinberger828b1f62013-10-07 15:26:57 +02002423 trace_signal_deliver(signr, &ksig->info, ka);
Masami Hiramatsuf9d42572009-11-24 16:56:51 -05002424
Linus Torvalds1da177e2005-04-16 15:20:36 -07002425 if (ka->sa.sa_handler == SIG_IGN) /* Do nothing. */
2426 continue;
2427 if (ka->sa.sa_handler != SIG_DFL) {
2428 /* Run the handler. */
Richard Weinberger828b1f62013-10-07 15:26:57 +02002429 ksig->ka = *ka;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002430
2431 if (ka->sa.sa_flags & SA_ONESHOT)
2432 ka->sa.sa_handler = SIG_DFL;
2433
2434 break; /* will return non-zero "signr" value */
2435 }
2436
2437 /*
2438 * Now we are doing the default action for this signal.
2439 */
2440 if (sig_kernel_ignore(signr)) /* Default is nothing. */
2441 continue;
2442
Sukadev Bhattiprolu84d73782006-12-08 02:38:01 -08002443 /*
Sukadev Bhattiprolu0fbc26a2007-10-18 23:40:13 -07002444 * Global init gets no signals it doesn't want.
Sukadev Bhattiprolub3bfa0c2009-04-02 16:58:08 -07002445 * Container-init gets no signals it doesn't want from same
2446 * container.
2447 *
2448 * Note that if global/container-init sees a sig_kernel_only()
2449 * signal here, the signal must have been generated internally
2450 * or must have come from an ancestor namespace. In either
2451 * case, the signal cannot be dropped.
Sukadev Bhattiprolu84d73782006-12-08 02:38:01 -08002452 */
Oleg Nesterovfae5fa42008-04-30 00:53:03 -07002453 if (unlikely(signal->flags & SIGNAL_UNKILLABLE) &&
Sukadev Bhattiprolub3bfa0c2009-04-02 16:58:08 -07002454 !sig_kernel_only(signr))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002455 continue;
2456
2457 if (sig_kernel_stop(signr)) {
2458 /*
2459 * The default action is to stop all threads in
2460 * the thread group. The job control signals
2461 * do nothing in an orphaned pgrp, but SIGSTOP
2462 * always works. Note that siglock needs to be
2463 * dropped during the call to is_orphaned_pgrp()
2464 * because of lock ordering with tasklist_lock.
2465 * This allows an intervening SIGCONT to be posted.
2466 * We need to check for that and bail out if necessary.
2467 */
2468 if (signr != SIGSTOP) {
Oleg Nesterovf6b76d42008-04-30 00:52:47 -07002469 spin_unlock_irq(&sighand->siglock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002470
2471 /* signals can be posted during this window */
2472
Eric W. Biederman3e7cd6c2007-02-12 00:52:58 -08002473 if (is_current_pgrp_orphaned())
Linus Torvalds1da177e2005-04-16 15:20:36 -07002474 goto relock;
2475
Oleg Nesterovf6b76d42008-04-30 00:52:47 -07002476 spin_lock_irq(&sighand->siglock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002477 }
2478
Richard Weinberger828b1f62013-10-07 15:26:57 +02002479 if (likely(do_signal_stop(ksig->info.si_signo))) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002480 /* It released the siglock. */
2481 goto relock;
2482 }
2483
2484 /*
2485 * We didn't actually stop, due to a race
2486 * with SIGCONT or something like that.
2487 */
2488 continue;
2489 }
2490
Oleg Nesterovf6b76d42008-04-30 00:52:47 -07002491 spin_unlock_irq(&sighand->siglock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002492
2493 /*
2494 * Anything else is fatal, maybe with a core dump.
2495 */
2496 current->flags |= PF_SIGNALED;
Oleg Nesterov2dce81b2008-04-30 00:52:58 -07002497
Linus Torvalds1da177e2005-04-16 15:20:36 -07002498 if (sig_kernel_coredump(signr)) {
Oleg Nesterov2dce81b2008-04-30 00:52:58 -07002499 if (print_fatal_signals)
Richard Weinberger828b1f62013-10-07 15:26:57 +02002500 print_fatal_signal(ksig->info.si_signo);
Jesper Derehag2b5faa42013-03-19 20:50:05 +00002501 proc_coredump_connector(current);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002502 /*
2503 * If it was able to dump core, this kills all
2504 * other threads in the group and synchronizes with
2505 * their demise. If we lost the race with another
2506 * thread getting here, it set group_exit_code
2507 * first and our do_group_exit call below will use
2508 * that value and ignore the one we pass it.
2509 */
Richard Weinberger828b1f62013-10-07 15:26:57 +02002510 do_coredump(&ksig->info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002511 }
2512
2513 /*
2514 * Death signals, no core dump.
2515 */
Richard Weinberger828b1f62013-10-07 15:26:57 +02002516 do_group_exit(ksig->info.si_signo);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002517 /* NOTREACHED */
2518 }
Oleg Nesterovf6b76d42008-04-30 00:52:47 -07002519 spin_unlock_irq(&sighand->siglock);
Richard Weinberger828b1f62013-10-07 15:26:57 +02002520
2521 ksig->sig = signr;
2522 return ksig->sig > 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002523}
2524
Matt Fleming5e6292c2012-01-10 15:11:17 -08002525/**
Al Viroefee9842012-04-28 02:04:15 -04002526 * signal_delivered -
Richard Weinberger10b1c7a2014-07-13 13:36:04 +02002527 * @ksig: kernel signal struct
Al Viroefee9842012-04-28 02:04:15 -04002528 * @stepping: nonzero if debugger single-step or block-step in use
Matt Fleming5e6292c2012-01-10 15:11:17 -08002529 *
Masanari Iidae2278672014-02-18 22:54:36 +09002530 * This function should be called when a signal has successfully been
Richard Weinberger10b1c7a2014-07-13 13:36:04 +02002531 * delivered. It updates the blocked signals accordingly (@ksig->ka.sa.sa_mask
Al Viroefee9842012-04-28 02:04:15 -04002532 * is always blocked, and the signal itself is blocked unless %SA_NODEFER
Richard Weinberger10b1c7a2014-07-13 13:36:04 +02002533 * is set in @ksig->ka.sa.sa_flags. Tracing is notified.
Matt Fleming5e6292c2012-01-10 15:11:17 -08002534 */
Richard Weinberger10b1c7a2014-07-13 13:36:04 +02002535static void signal_delivered(struct ksignal *ksig, int stepping)
Matt Fleming5e6292c2012-01-10 15:11:17 -08002536{
2537 sigset_t blocked;
2538
Al Viroa610d6e2012-05-21 23:42:15 -04002539 /* A signal was successfully delivered, and the
2540 saved sigmask was stored on the signal frame,
2541 and will be restored by sigreturn. So we can
2542 simply clear the restore sigmask flag. */
2543 clear_restore_sigmask();
2544
Richard Weinberger10b1c7a2014-07-13 13:36:04 +02002545 sigorsets(&blocked, &current->blocked, &ksig->ka.sa.sa_mask);
2546 if (!(ksig->ka.sa.sa_flags & SA_NODEFER))
2547 sigaddset(&blocked, ksig->sig);
Matt Fleming5e6292c2012-01-10 15:11:17 -08002548 set_current_blocked(&blocked);
Richard Weinbergerdf5601f2013-10-07 15:37:19 +02002549 tracehook_signal_handler(stepping);
Matt Fleming5e6292c2012-01-10 15:11:17 -08002550}
2551
Al Viro2ce5da12012-11-07 15:11:25 -05002552void signal_setup_done(int failed, struct ksignal *ksig, int stepping)
2553{
2554 if (failed)
2555 force_sigsegv(ksig->sig, current);
2556 else
Richard Weinberger10b1c7a2014-07-13 13:36:04 +02002557 signal_delivered(ksig, stepping);
Al Viro2ce5da12012-11-07 15:11:25 -05002558}
2559
Oleg Nesterov0edceb7bc2011-04-27 19:17:37 +02002560/*
2561 * It could be that complete_signal() picked us to notify about the
Oleg Nesterovfec99932011-04-27 19:50:21 +02002562 * group-wide signal. Other threads should be notified now to take
2563 * the shared signals in @which since we will not.
Oleg Nesterov0edceb7bc2011-04-27 19:17:37 +02002564 */
Oleg Nesterovf646e222011-04-27 19:18:39 +02002565static void retarget_shared_pending(struct task_struct *tsk, sigset_t *which)
Oleg Nesterov0edceb7bc2011-04-27 19:17:37 +02002566{
Oleg Nesterovf646e222011-04-27 19:18:39 +02002567 sigset_t retarget;
Oleg Nesterov0edceb7bc2011-04-27 19:17:37 +02002568 struct task_struct *t;
2569
Oleg Nesterovf646e222011-04-27 19:18:39 +02002570 sigandsets(&retarget, &tsk->signal->shared_pending.signal, which);
2571 if (sigisemptyset(&retarget))
2572 return;
2573
Oleg Nesterov0edceb7bc2011-04-27 19:17:37 +02002574 t = tsk;
2575 while_each_thread(tsk, t) {
Oleg Nesterovfec99932011-04-27 19:50:21 +02002576 if (t->flags & PF_EXITING)
2577 continue;
2578
2579 if (!has_pending_signals(&retarget, &t->blocked))
2580 continue;
2581 /* Remove the signals this thread can handle. */
2582 sigandsets(&retarget, &retarget, &t->blocked);
2583
2584 if (!signal_pending(t))
2585 signal_wake_up(t, 0);
2586
2587 if (sigisemptyset(&retarget))
2588 break;
Oleg Nesterov0edceb7bc2011-04-27 19:17:37 +02002589 }
2590}
2591
Oleg Nesterovd12619b2008-02-08 04:19:12 -08002592void exit_signals(struct task_struct *tsk)
2593{
2594 int group_stop = 0;
Oleg Nesterovf646e222011-04-27 19:18:39 +02002595 sigset_t unblocked;
Oleg Nesterovd12619b2008-02-08 04:19:12 -08002596
Tejun Heo77e4ef92011-12-12 18:12:21 -08002597 /*
2598 * @tsk is about to have PF_EXITING set - lock out users which
2599 * expect stable threadgroup.
2600 */
Ingo Molnar780de9d2017-02-02 11:50:56 +01002601 cgroup_threadgroup_change_begin(tsk);
Tejun Heo77e4ef92011-12-12 18:12:21 -08002602
Oleg Nesterov5dee1702008-02-08 04:19:13 -08002603 if (thread_group_empty(tsk) || signal_group_exit(tsk->signal)) {
2604 tsk->flags |= PF_EXITING;
Ingo Molnar780de9d2017-02-02 11:50:56 +01002605 cgroup_threadgroup_change_end(tsk);
Oleg Nesterov5dee1702008-02-08 04:19:13 -08002606 return;
Oleg Nesterovd12619b2008-02-08 04:19:12 -08002607 }
2608
Oleg Nesterov5dee1702008-02-08 04:19:13 -08002609 spin_lock_irq(&tsk->sighand->siglock);
Oleg Nesterovd12619b2008-02-08 04:19:12 -08002610 /*
2611 * From now this task is not visible for group-wide signals,
2612 * see wants_signal(), do_signal_stop().
2613 */
2614 tsk->flags |= PF_EXITING;
Tejun Heo77e4ef92011-12-12 18:12:21 -08002615
Ingo Molnar780de9d2017-02-02 11:50:56 +01002616 cgroup_threadgroup_change_end(tsk);
Tejun Heo77e4ef92011-12-12 18:12:21 -08002617
Oleg Nesterov5dee1702008-02-08 04:19:13 -08002618 if (!signal_pending(tsk))
2619 goto out;
2620
Oleg Nesterovf646e222011-04-27 19:18:39 +02002621 unblocked = tsk->blocked;
2622 signotset(&unblocked);
2623 retarget_shared_pending(tsk, &unblocked);
Oleg Nesterov5dee1702008-02-08 04:19:13 -08002624
Tejun Heoa8f072c2011-06-02 11:13:59 +02002625 if (unlikely(tsk->jobctl & JOBCTL_STOP_PENDING) &&
Tejun Heoe5c1902e2011-03-23 10:37:00 +01002626 task_participate_group_stop(tsk))
Tejun Heoedf2ed12011-03-23 10:37:00 +01002627 group_stop = CLD_STOPPED;
Oleg Nesterov5dee1702008-02-08 04:19:13 -08002628out:
Oleg Nesterovd12619b2008-02-08 04:19:12 -08002629 spin_unlock_irq(&tsk->sighand->siglock);
2630
Tejun Heo62bcf9d2011-03-23 10:37:01 +01002631 /*
2632 * If group stop has completed, deliver the notification. This
2633 * should always go to the real parent of the group leader.
2634 */
Roland McGrathae6d2ed2009-09-23 15:56:53 -07002635 if (unlikely(group_stop)) {
Oleg Nesterovd12619b2008-02-08 04:19:12 -08002636 read_lock(&tasklist_lock);
Tejun Heo62bcf9d2011-03-23 10:37:01 +01002637 do_notify_parent_cldstop(tsk, false, group_stop);
Oleg Nesterovd12619b2008-02-08 04:19:12 -08002638 read_unlock(&tasklist_lock);
2639 }
2640}
2641
Linus Torvalds1da177e2005-04-16 15:20:36 -07002642/*
2643 * System call entry points.
2644 */
2645
Randy Dunlap41c57892011-04-04 15:00:26 -07002646/**
2647 * sys_restart_syscall - restart a system call
2648 */
Heiko Carstens754fe8d2009-01-14 14:14:09 +01002649SYSCALL_DEFINE0(restart_syscall)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002650{
Andy Lutomirskif56141e2015-02-12 15:01:14 -08002651 struct restart_block *restart = &current->restart_block;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002652 return restart->fn(restart);
2653}
2654
2655long do_no_restart_syscall(struct restart_block *param)
2656{
2657 return -EINTR;
2658}
2659
Oleg Nesterovb1828012011-04-27 21:56:14 +02002660static void __set_task_blocked(struct task_struct *tsk, const sigset_t *newset)
2661{
2662 if (signal_pending(tsk) && !thread_group_empty(tsk)) {
2663 sigset_t newblocked;
2664 /* A set of now blocked but previously unblocked signals. */
Oleg Nesterov702a5072011-04-27 22:01:27 +02002665 sigandnsets(&newblocked, newset, &current->blocked);
Oleg Nesterovb1828012011-04-27 21:56:14 +02002666 retarget_shared_pending(tsk, &newblocked);
2667 }
2668 tsk->blocked = *newset;
2669 recalc_sigpending();
2670}
2671
Oleg Nesterove6fa16a2011-04-27 20:59:41 +02002672/**
2673 * set_current_blocked - change current->blocked mask
2674 * @newset: new mask
2675 *
2676 * It is wrong to change ->blocked directly, this helper should be used
2677 * to ensure the process can't miss a shared signal we are going to block.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002678 */
Al Viro77097ae2012-04-27 13:58:59 -04002679void set_current_blocked(sigset_t *newset)
2680{
Al Viro77097ae2012-04-27 13:58:59 -04002681 sigdelsetmask(newset, sigmask(SIGKILL) | sigmask(SIGSTOP));
Oleg Nesterov0c4a8422013-01-05 19:13:29 +01002682 __set_current_blocked(newset);
Al Viro77097ae2012-04-27 13:58:59 -04002683}
2684
2685void __set_current_blocked(const sigset_t *newset)
Oleg Nesterove6fa16a2011-04-27 20:59:41 +02002686{
2687 struct task_struct *tsk = current;
2688
Waiman Longc7be96a2016-12-14 15:04:10 -08002689 /*
2690 * In case the signal mask hasn't changed, there is nothing we need
2691 * to do. The current->blocked shouldn't be modified by other task.
2692 */
2693 if (sigequalsets(&tsk->blocked, newset))
2694 return;
2695
Oleg Nesterove6fa16a2011-04-27 20:59:41 +02002696 spin_lock_irq(&tsk->sighand->siglock);
Oleg Nesterovb1828012011-04-27 21:56:14 +02002697 __set_task_blocked(tsk, newset);
Oleg Nesterove6fa16a2011-04-27 20:59:41 +02002698 spin_unlock_irq(&tsk->sighand->siglock);
2699}
Linus Torvalds1da177e2005-04-16 15:20:36 -07002700
2701/*
2702 * This is also useful for kernel threads that want to temporarily
2703 * (or permanently) block certain signals.
2704 *
2705 * NOTE! Unlike the user-mode sys_sigprocmask(), the kernel
2706 * interface happily blocks "unblockable" signals like SIGKILL
2707 * and friends.
2708 */
2709int sigprocmask(int how, sigset_t *set, sigset_t *oldset)
2710{
Oleg Nesterov73ef4ae2011-04-27 19:54:20 +02002711 struct task_struct *tsk = current;
2712 sigset_t newset;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002713
Oleg Nesterov73ef4ae2011-04-27 19:54:20 +02002714 /* Lockless, only current can change ->blocked, never from irq */
Oleg Nesterova26fd332006-03-23 03:00:49 -08002715 if (oldset)
Oleg Nesterov73ef4ae2011-04-27 19:54:20 +02002716 *oldset = tsk->blocked;
Oleg Nesterova26fd332006-03-23 03:00:49 -08002717
Linus Torvalds1da177e2005-04-16 15:20:36 -07002718 switch (how) {
2719 case SIG_BLOCK:
Oleg Nesterov73ef4ae2011-04-27 19:54:20 +02002720 sigorsets(&newset, &tsk->blocked, set);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002721 break;
2722 case SIG_UNBLOCK:
Oleg Nesterov702a5072011-04-27 22:01:27 +02002723 sigandnsets(&newset, &tsk->blocked, set);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002724 break;
2725 case SIG_SETMASK:
Oleg Nesterov73ef4ae2011-04-27 19:54:20 +02002726 newset = *set;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002727 break;
2728 default:
Oleg Nesterov73ef4ae2011-04-27 19:54:20 +02002729 return -EINVAL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002730 }
Oleg Nesterova26fd332006-03-23 03:00:49 -08002731
Al Viro77097ae2012-04-27 13:58:59 -04002732 __set_current_blocked(&newset);
Oleg Nesterov73ef4ae2011-04-27 19:54:20 +02002733 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002734}
Eric W. Biedermanfb50f5a2018-09-13 19:26:35 +02002735EXPORT_SYMBOL(sigprocmask);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002736
Deepa Dinamanided653c2018-09-19 21:41:04 -07002737/*
2738 * The api helps set app-provided sigmasks.
2739 *
2740 * This is useful for syscalls such as ppoll, pselect, io_pgetevents and
2741 * epoll_pwait where a new sigmask is passed from userland for the syscalls.
2742 */
2743int set_user_sigmask(const sigset_t __user *usigmask, sigset_t *set,
2744 sigset_t *oldset, size_t sigsetsize)
2745{
2746 if (!usigmask)
2747 return 0;
2748
2749 if (sigsetsize != sizeof(sigset_t))
2750 return -EINVAL;
2751 if (copy_from_user(set, usigmask, sizeof(sigset_t)))
2752 return -EFAULT;
2753
2754 *oldset = current->blocked;
2755 set_current_blocked(set);
2756
2757 return 0;
2758}
2759EXPORT_SYMBOL(set_user_sigmask);
2760
2761#ifdef CONFIG_COMPAT
2762int set_compat_user_sigmask(const compat_sigset_t __user *usigmask,
2763 sigset_t *set, sigset_t *oldset,
2764 size_t sigsetsize)
2765{
2766 if (!usigmask)
2767 return 0;
2768
2769 if (sigsetsize != sizeof(compat_sigset_t))
2770 return -EINVAL;
2771 if (get_compat_sigset(set, usigmask))
2772 return -EFAULT;
2773
2774 *oldset = current->blocked;
2775 set_current_blocked(set);
2776
2777 return 0;
2778}
2779EXPORT_SYMBOL(set_compat_user_sigmask);
2780#endif
2781
Deepa Dinamani854a6ed2018-09-19 21:41:05 -07002782/*
2783 * restore_user_sigmask:
2784 * usigmask: sigmask passed in from userland.
2785 * sigsaved: saved sigmask when the syscall started and changed the sigmask to
2786 * usigmask.
2787 *
2788 * This is useful for syscalls such as ppoll, pselect, io_pgetevents and
2789 * epoll_pwait where a new sigmask is passed in from userland for the syscalls.
2790 */
2791void restore_user_sigmask(const void __user *usigmask, sigset_t *sigsaved)
2792{
2793
2794 if (!usigmask)
2795 return;
2796 /*
2797 * When signals are pending, do not restore them here.
2798 * Restoring sigmask here can lead to delivering signals that the above
2799 * syscalls are intended to block because of the sigmask passed in.
2800 */
2801 if (signal_pending(current)) {
2802 current->saved_sigmask = *sigsaved;
2803 set_restore_sigmask();
2804 return;
2805 }
2806
2807 /*
2808 * This is needed because the fast syscall return path does not restore
2809 * saved_sigmask when signals are not pending.
2810 */
2811 set_current_blocked(sigsaved);
2812}
2813EXPORT_SYMBOL(restore_user_sigmask);
2814
Randy Dunlap41c57892011-04-04 15:00:26 -07002815/**
2816 * sys_rt_sigprocmask - change the list of currently blocked signals
2817 * @how: whether to add, remove, or set signals
Randy Dunlapada9c932011-06-14 15:50:11 -07002818 * @nset: stores pending signals
Randy Dunlap41c57892011-04-04 15:00:26 -07002819 * @oset: previous value of signal mask if non-null
2820 * @sigsetsize: size of sigset_t type
2821 */
Oleg Nesterovbb7efee2011-04-27 21:18:10 +02002822SYSCALL_DEFINE4(rt_sigprocmask, int, how, sigset_t __user *, nset,
Heiko Carstens17da2bd2009-01-14 14:14:10 +01002823 sigset_t __user *, oset, size_t, sigsetsize)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002824{
Linus Torvalds1da177e2005-04-16 15:20:36 -07002825 sigset_t old_set, new_set;
Oleg Nesterovbb7efee2011-04-27 21:18:10 +02002826 int error;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002827
2828 /* XXX: Don't preclude handling different sized sigset_t's. */
2829 if (sigsetsize != sizeof(sigset_t))
Oleg Nesterovbb7efee2011-04-27 21:18:10 +02002830 return -EINVAL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002831
Oleg Nesterovbb7efee2011-04-27 21:18:10 +02002832 old_set = current->blocked;
2833
2834 if (nset) {
2835 if (copy_from_user(&new_set, nset, sizeof(sigset_t)))
2836 return -EFAULT;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002837 sigdelsetmask(&new_set, sigmask(SIGKILL)|sigmask(SIGSTOP));
2838
Oleg Nesterovbb7efee2011-04-27 21:18:10 +02002839 error = sigprocmask(how, &new_set, NULL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002840 if (error)
Oleg Nesterovbb7efee2011-04-27 21:18:10 +02002841 return error;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002842 }
Oleg Nesterovbb7efee2011-04-27 21:18:10 +02002843
2844 if (oset) {
2845 if (copy_to_user(oset, &old_set, sizeof(sigset_t)))
2846 return -EFAULT;
2847 }
2848
2849 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002850}
2851
Al Viro322a56c2012-12-25 13:32:58 -05002852#ifdef CONFIG_COMPAT
Al Viro322a56c2012-12-25 13:32:58 -05002853COMPAT_SYSCALL_DEFINE4(rt_sigprocmask, int, how, compat_sigset_t __user *, nset,
2854 compat_sigset_t __user *, oset, compat_size_t, sigsetsize)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002855{
Al Viro322a56c2012-12-25 13:32:58 -05002856 sigset_t old_set = current->blocked;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002857
Al Viro322a56c2012-12-25 13:32:58 -05002858 /* XXX: Don't preclude handling different sized sigset_t's. */
2859 if (sigsetsize != sizeof(sigset_t))
2860 return -EINVAL;
2861
2862 if (nset) {
Al Viro322a56c2012-12-25 13:32:58 -05002863 sigset_t new_set;
2864 int error;
Al Viro3968cf62017-09-03 21:45:17 -04002865 if (get_compat_sigset(&new_set, nset))
Al Viro322a56c2012-12-25 13:32:58 -05002866 return -EFAULT;
Al Viro322a56c2012-12-25 13:32:58 -05002867 sigdelsetmask(&new_set, sigmask(SIGKILL)|sigmask(SIGSTOP));
2868
2869 error = sigprocmask(how, &new_set, NULL);
2870 if (error)
2871 return error;
2872 }
Dmitry V. Levinf4543222017-08-22 02:16:11 +03002873 return oset ? put_compat_sigset(oset, &old_set, sizeof(*oset)) : 0;
Al Viro322a56c2012-12-25 13:32:58 -05002874}
2875#endif
Al Viro322a56c2012-12-25 13:32:58 -05002876
Christian Braunerb1d294c2018-08-21 22:00:02 -07002877static void do_sigpending(sigset_t *set)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002878{
Linus Torvalds1da177e2005-04-16 15:20:36 -07002879 spin_lock_irq(&current->sighand->siglock);
Al Virofe9c1db2012-12-25 14:31:38 -05002880 sigorsets(set, &current->pending.signal,
Linus Torvalds1da177e2005-04-16 15:20:36 -07002881 &current->signal->shared_pending.signal);
2882 spin_unlock_irq(&current->sighand->siglock);
2883
2884 /* Outside the lock because only this thread touches it. */
Al Virofe9c1db2012-12-25 14:31:38 -05002885 sigandsets(set, &current->blocked, set);
Randy Dunlap5aba0852011-04-04 14:59:31 -07002886}
Linus Torvalds1da177e2005-04-16 15:20:36 -07002887
Randy Dunlap41c57892011-04-04 15:00:26 -07002888/**
2889 * sys_rt_sigpending - examine a pending signal that has been raised
2890 * while blocked
Randy Dunlap20f22ab2013-03-04 14:32:59 -08002891 * @uset: stores pending signals
Randy Dunlap41c57892011-04-04 15:00:26 -07002892 * @sigsetsize: size of sigset_t type or larger
2893 */
Al Virofe9c1db2012-12-25 14:31:38 -05002894SYSCALL_DEFINE2(rt_sigpending, sigset_t __user *, uset, size_t, sigsetsize)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002895{
Al Virofe9c1db2012-12-25 14:31:38 -05002896 sigset_t set;
Dmitry V. Levin176826a2017-08-22 02:16:43 +03002897
2898 if (sigsetsize > sizeof(*uset))
2899 return -EINVAL;
2900
Christian Braunerb1d294c2018-08-21 22:00:02 -07002901 do_sigpending(&set);
2902
2903 if (copy_to_user(uset, &set, sigsetsize))
2904 return -EFAULT;
2905
2906 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002907}
2908
Al Virofe9c1db2012-12-25 14:31:38 -05002909#ifdef CONFIG_COMPAT
Al Virofe9c1db2012-12-25 14:31:38 -05002910COMPAT_SYSCALL_DEFINE2(rt_sigpending, compat_sigset_t __user *, uset,
2911 compat_size_t, sigsetsize)
2912{
Al Virofe9c1db2012-12-25 14:31:38 -05002913 sigset_t set;
Dmitry V. Levin176826a2017-08-22 02:16:43 +03002914
2915 if (sigsetsize > sizeof(*uset))
2916 return -EINVAL;
2917
Christian Braunerb1d294c2018-08-21 22:00:02 -07002918 do_sigpending(&set);
2919
2920 return put_compat_sigset(uset, &set, sigsetsize);
Al Virofe9c1db2012-12-25 14:31:38 -05002921}
2922#endif
Al Virofe9c1db2012-12-25 14:31:38 -05002923
Eric W. Biederman4ce5f9c2018-09-25 12:59:31 +02002924static const struct {
2925 unsigned char limit, layout;
2926} sig_sicodes[] = {
2927 [SIGILL] = { NSIGILL, SIL_FAULT },
2928 [SIGFPE] = { NSIGFPE, SIL_FAULT },
2929 [SIGSEGV] = { NSIGSEGV, SIL_FAULT },
2930 [SIGBUS] = { NSIGBUS, SIL_FAULT },
2931 [SIGTRAP] = { NSIGTRAP, SIL_FAULT },
2932#if defined(SIGEMT)
2933 [SIGEMT] = { NSIGEMT, SIL_FAULT },
2934#endif
2935 [SIGCHLD] = { NSIGCHLD, SIL_CHLD },
2936 [SIGPOLL] = { NSIGPOLL, SIL_POLL },
2937 [SIGSYS] = { NSIGSYS, SIL_SYS },
2938};
2939
Eric W. Biedermanb2a2ab52018-10-10 20:11:25 -05002940static bool known_siginfo_layout(unsigned sig, int si_code)
Eric W. Biederman4ce5f9c2018-09-25 12:59:31 +02002941{
2942 if (si_code == SI_KERNEL)
2943 return true;
2944 else if ((si_code > SI_USER)) {
2945 if (sig_specific_sicodes(sig)) {
2946 if (si_code <= sig_sicodes[sig].limit)
2947 return true;
2948 }
2949 else if (si_code <= NSIGPOLL)
2950 return true;
2951 }
2952 else if (si_code >= SI_DETHREAD)
2953 return true;
2954 else if (si_code == SI_ASYNCNL)
2955 return true;
2956 return false;
2957}
2958
Eric W. Biedermana3670052018-10-10 20:29:44 -05002959enum siginfo_layout siginfo_layout(unsigned sig, int si_code)
Eric W. Biedermancc731522017-07-16 22:36:59 -05002960{
2961 enum siginfo_layout layout = SIL_KILL;
2962 if ((si_code > SI_USER) && (si_code < SI_KERNEL)) {
Eric W. Biederman4ce5f9c2018-09-25 12:59:31 +02002963 if ((sig < ARRAY_SIZE(sig_sicodes)) &&
2964 (si_code <= sig_sicodes[sig].limit)) {
2965 layout = sig_sicodes[sig].layout;
Eric W. Biederman31931c92018-04-24 20:59:47 -05002966 /* Handle the exceptions */
2967 if ((sig == SIGBUS) &&
2968 (si_code >= BUS_MCEERR_AR) && (si_code <= BUS_MCEERR_AO))
2969 layout = SIL_FAULT_MCEERR;
2970 else if ((sig == SIGSEGV) && (si_code == SEGV_BNDERR))
2971 layout = SIL_FAULT_BNDERR;
2972#ifdef SEGV_PKUERR
2973 else if ((sig == SIGSEGV) && (si_code == SEGV_PKUERR))
2974 layout = SIL_FAULT_PKUERR;
2975#endif
2976 }
Eric W. Biedermancc731522017-07-16 22:36:59 -05002977 else if (si_code <= NSIGPOLL)
2978 layout = SIL_POLL;
2979 } else {
2980 if (si_code == SI_TIMER)
2981 layout = SIL_TIMER;
2982 else if (si_code == SI_SIGIO)
2983 layout = SIL_POLL;
2984 else if (si_code < 0)
2985 layout = SIL_RT;
Eric W. Biedermancc731522017-07-16 22:36:59 -05002986 }
2987 return layout;
2988}
2989
Eric W. Biederman4ce5f9c2018-09-25 12:59:31 +02002990static inline char __user *si_expansion(const siginfo_t __user *info)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002991{
Eric W. Biederman4ce5f9c2018-09-25 12:59:31 +02002992 return ((char __user *)info) + sizeof(struct kernel_siginfo);
2993}
2994
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02002995int copy_siginfo_to_user(siginfo_t __user *to, const kernel_siginfo_t *from)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002996{
Eric W. Biederman4ce5f9c2018-09-25 12:59:31 +02002997 char __user *expansion = si_expansion(to);
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02002998 if (copy_to_user(to, from , sizeof(struct kernel_siginfo)))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002999 return -EFAULT;
Eric W. Biederman4ce5f9c2018-09-25 12:59:31 +02003000 if (clear_user(expansion, SI_EXPANSION_SIZE))
Linus Torvalds1da177e2005-04-16 15:20:36 -07003001 return -EFAULT;
Eric W. Biedermanc999b932018-04-14 13:03:25 -05003002 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003003}
3004
Eric W. Biederman601d5ab2018-10-05 09:02:48 +02003005static int post_copy_siginfo_from_user(kernel_siginfo_t *info,
3006 const siginfo_t __user *from)
Eric W. Biederman4cd2e0e2018-04-18 17:30:19 -05003007{
Eric W. Biederman601d5ab2018-10-05 09:02:48 +02003008 if (unlikely(!known_siginfo_layout(info->si_signo, info->si_code))) {
Eric W. Biederman4ce5f9c2018-09-25 12:59:31 +02003009 char __user *expansion = si_expansion(from);
3010 char buf[SI_EXPANSION_SIZE];
3011 int i;
3012 /*
3013 * An unknown si_code might need more than
3014 * sizeof(struct kernel_siginfo) bytes. Verify all of the
3015 * extra bytes are 0. This guarantees copy_siginfo_to_user
3016 * will return this data to userspace exactly.
3017 */
3018 if (copy_from_user(&buf, expansion, SI_EXPANSION_SIZE))
3019 return -EFAULT;
3020 for (i = 0; i < SI_EXPANSION_SIZE; i++) {
3021 if (buf[i] != 0)
3022 return -E2BIG;
3023 }
3024 }
Eric W. Biederman4cd2e0e2018-04-18 17:30:19 -05003025 return 0;
3026}
3027
Eric W. Biederman601d5ab2018-10-05 09:02:48 +02003028static int __copy_siginfo_from_user(int signo, kernel_siginfo_t *to,
3029 const siginfo_t __user *from)
3030{
3031 if (copy_from_user(to, from, sizeof(struct kernel_siginfo)))
3032 return -EFAULT;
3033 to->si_signo = signo;
3034 return post_copy_siginfo_from_user(to, from);
3035}
3036
3037int copy_siginfo_from_user(kernel_siginfo_t *to, const siginfo_t __user *from)
3038{
3039 if (copy_from_user(to, from, sizeof(struct kernel_siginfo)))
3040 return -EFAULT;
3041 return post_copy_siginfo_from_user(to, from);
3042}
3043
Eric W. Biederman212a36a2017-07-31 17:15:31 -05003044#ifdef CONFIG_COMPAT
Eric W. Biedermanea64d5a2018-01-15 18:03:33 -06003045int copy_siginfo_to_user32(struct compat_siginfo __user *to,
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003046 const struct kernel_siginfo *from)
Eric W. Biedermanea64d5a2018-01-15 18:03:33 -06003047#if defined(CONFIG_X86_X32_ABI) || defined(CONFIG_IA32_EMULATION)
3048{
3049 return __copy_siginfo_to_user32(to, from, in_x32_syscall());
3050}
3051int __copy_siginfo_to_user32(struct compat_siginfo __user *to,
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003052 const struct kernel_siginfo *from, bool x32_ABI)
Eric W. Biedermanea64d5a2018-01-15 18:03:33 -06003053#endif
3054{
3055 struct compat_siginfo new;
3056 memset(&new, 0, sizeof(new));
3057
3058 new.si_signo = from->si_signo;
3059 new.si_errno = from->si_errno;
3060 new.si_code = from->si_code;
3061 switch(siginfo_layout(from->si_signo, from->si_code)) {
3062 case SIL_KILL:
3063 new.si_pid = from->si_pid;
3064 new.si_uid = from->si_uid;
3065 break;
3066 case SIL_TIMER:
3067 new.si_tid = from->si_tid;
3068 new.si_overrun = from->si_overrun;
3069 new.si_int = from->si_int;
3070 break;
3071 case SIL_POLL:
3072 new.si_band = from->si_band;
3073 new.si_fd = from->si_fd;
3074 break;
3075 case SIL_FAULT:
3076 new.si_addr = ptr_to_compat(from->si_addr);
3077#ifdef __ARCH_SI_TRAPNO
3078 new.si_trapno = from->si_trapno;
3079#endif
Eric W. Biederman31931c92018-04-24 20:59:47 -05003080 break;
3081 case SIL_FAULT_MCEERR:
3082 new.si_addr = ptr_to_compat(from->si_addr);
3083#ifdef __ARCH_SI_TRAPNO
3084 new.si_trapno = from->si_trapno;
Eric W. Biedermanea64d5a2018-01-15 18:03:33 -06003085#endif
Eric W. Biederman31931c92018-04-24 20:59:47 -05003086 new.si_addr_lsb = from->si_addr_lsb;
3087 break;
3088 case SIL_FAULT_BNDERR:
3089 new.si_addr = ptr_to_compat(from->si_addr);
3090#ifdef __ARCH_SI_TRAPNO
3091 new.si_trapno = from->si_trapno;
Eric W. Biedermanea64d5a2018-01-15 18:03:33 -06003092#endif
Eric W. Biederman31931c92018-04-24 20:59:47 -05003093 new.si_lower = ptr_to_compat(from->si_lower);
3094 new.si_upper = ptr_to_compat(from->si_upper);
3095 break;
3096 case SIL_FAULT_PKUERR:
3097 new.si_addr = ptr_to_compat(from->si_addr);
3098#ifdef __ARCH_SI_TRAPNO
3099 new.si_trapno = from->si_trapno;
Eric W. Biedermanea64d5a2018-01-15 18:03:33 -06003100#endif
Eric W. Biederman31931c92018-04-24 20:59:47 -05003101 new.si_pkey = from->si_pkey;
Eric W. Biedermanea64d5a2018-01-15 18:03:33 -06003102 break;
3103 case SIL_CHLD:
3104 new.si_pid = from->si_pid;
3105 new.si_uid = from->si_uid;
3106 new.si_status = from->si_status;
3107#ifdef CONFIG_X86_X32_ABI
3108 if (x32_ABI) {
3109 new._sifields._sigchld_x32._utime = from->si_utime;
3110 new._sifields._sigchld_x32._stime = from->si_stime;
3111 } else
3112#endif
3113 {
3114 new.si_utime = from->si_utime;
3115 new.si_stime = from->si_stime;
3116 }
3117 break;
3118 case SIL_RT:
3119 new.si_pid = from->si_pid;
3120 new.si_uid = from->si_uid;
3121 new.si_int = from->si_int;
3122 break;
3123 case SIL_SYS:
3124 new.si_call_addr = ptr_to_compat(from->si_call_addr);
3125 new.si_syscall = from->si_syscall;
3126 new.si_arch = from->si_arch;
3127 break;
3128 }
3129
3130 if (copy_to_user(to, &new, sizeof(struct compat_siginfo)))
3131 return -EFAULT;
3132
3133 return 0;
3134}
3135
Eric W. Biederman601d5ab2018-10-05 09:02:48 +02003136static int post_copy_siginfo_from_user32(kernel_siginfo_t *to,
3137 const struct compat_siginfo *from)
3138{
3139 clear_siginfo(to);
3140 to->si_signo = from->si_signo;
3141 to->si_errno = from->si_errno;
3142 to->si_code = from->si_code;
3143 switch(siginfo_layout(from->si_signo, from->si_code)) {
3144 case SIL_KILL:
3145 to->si_pid = from->si_pid;
3146 to->si_uid = from->si_uid;
3147 break;
3148 case SIL_TIMER:
3149 to->si_tid = from->si_tid;
3150 to->si_overrun = from->si_overrun;
3151 to->si_int = from->si_int;
3152 break;
3153 case SIL_POLL:
3154 to->si_band = from->si_band;
3155 to->si_fd = from->si_fd;
3156 break;
3157 case SIL_FAULT:
3158 to->si_addr = compat_ptr(from->si_addr);
3159#ifdef __ARCH_SI_TRAPNO
3160 to->si_trapno = from->si_trapno;
3161#endif
3162 break;
3163 case SIL_FAULT_MCEERR:
3164 to->si_addr = compat_ptr(from->si_addr);
3165#ifdef __ARCH_SI_TRAPNO
3166 to->si_trapno = from->si_trapno;
3167#endif
3168 to->si_addr_lsb = from->si_addr_lsb;
3169 break;
3170 case SIL_FAULT_BNDERR:
3171 to->si_addr = compat_ptr(from->si_addr);
3172#ifdef __ARCH_SI_TRAPNO
3173 to->si_trapno = from->si_trapno;
3174#endif
3175 to->si_lower = compat_ptr(from->si_lower);
3176 to->si_upper = compat_ptr(from->si_upper);
3177 break;
3178 case SIL_FAULT_PKUERR:
3179 to->si_addr = compat_ptr(from->si_addr);
3180#ifdef __ARCH_SI_TRAPNO
3181 to->si_trapno = from->si_trapno;
3182#endif
3183 to->si_pkey = from->si_pkey;
3184 break;
3185 case SIL_CHLD:
3186 to->si_pid = from->si_pid;
3187 to->si_uid = from->si_uid;
3188 to->si_status = from->si_status;
3189#ifdef CONFIG_X86_X32_ABI
3190 if (in_x32_syscall()) {
3191 to->si_utime = from->_sifields._sigchld_x32._utime;
3192 to->si_stime = from->_sifields._sigchld_x32._stime;
3193 } else
3194#endif
3195 {
3196 to->si_utime = from->si_utime;
3197 to->si_stime = from->si_stime;
3198 }
3199 break;
3200 case SIL_RT:
3201 to->si_pid = from->si_pid;
3202 to->si_uid = from->si_uid;
3203 to->si_int = from->si_int;
3204 break;
3205 case SIL_SYS:
3206 to->si_call_addr = compat_ptr(from->si_call_addr);
3207 to->si_syscall = from->si_syscall;
3208 to->si_arch = from->si_arch;
3209 break;
3210 }
3211 return 0;
3212}
3213
3214static int __copy_siginfo_from_user32(int signo, struct kernel_siginfo *to,
3215 const struct compat_siginfo __user *ufrom)
3216{
3217 struct compat_siginfo from;
3218
3219 if (copy_from_user(&from, ufrom, sizeof(struct compat_siginfo)))
3220 return -EFAULT;
3221
3222 from.si_signo = signo;
3223 return post_copy_siginfo_from_user32(to, &from);
3224}
3225
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003226int copy_siginfo_from_user32(struct kernel_siginfo *to,
Eric W. Biederman212a36a2017-07-31 17:15:31 -05003227 const struct compat_siginfo __user *ufrom)
3228{
3229 struct compat_siginfo from;
3230
3231 if (copy_from_user(&from, ufrom, sizeof(struct compat_siginfo)))
3232 return -EFAULT;
3233
Eric W. Biederman601d5ab2018-10-05 09:02:48 +02003234 return post_copy_siginfo_from_user32(to, &from);
Eric W. Biederman212a36a2017-07-31 17:15:31 -05003235}
3236#endif /* CONFIG_COMPAT */
3237
Randy Dunlap41c57892011-04-04 15:00:26 -07003238/**
Oleg Nesterov943df142011-04-27 21:44:14 +02003239 * do_sigtimedwait - wait for queued signals specified in @which
3240 * @which: queued signals to wait for
3241 * @info: if non-null, the signal's siginfo is returned here
3242 * @ts: upper bound on process time suspension
3243 */
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003244static int do_sigtimedwait(const sigset_t *which, kernel_siginfo_t *info,
Arnd Bergmann49c39f82018-04-18 15:56:13 +02003245 const struct timespec64 *ts)
Oleg Nesterov943df142011-04-27 21:44:14 +02003246{
Thomas Gleixner2456e852016-12-25 11:38:40 +01003247 ktime_t *to = NULL, timeout = KTIME_MAX;
Oleg Nesterov943df142011-04-27 21:44:14 +02003248 struct task_struct *tsk = current;
Oleg Nesterov943df142011-04-27 21:44:14 +02003249 sigset_t mask = *which;
Thomas Gleixner2b1ecc32016-07-04 09:50:25 +00003250 int sig, ret = 0;
Oleg Nesterov943df142011-04-27 21:44:14 +02003251
3252 if (ts) {
Arnd Bergmann49c39f82018-04-18 15:56:13 +02003253 if (!timespec64_valid(ts))
Oleg Nesterov943df142011-04-27 21:44:14 +02003254 return -EINVAL;
Arnd Bergmann49c39f82018-04-18 15:56:13 +02003255 timeout = timespec64_to_ktime(*ts);
Thomas Gleixner2b1ecc32016-07-04 09:50:25 +00003256 to = &timeout;
Oleg Nesterov943df142011-04-27 21:44:14 +02003257 }
3258
3259 /*
3260 * Invert the set of allowed signals to get those we want to block.
3261 */
3262 sigdelsetmask(&mask, sigmask(SIGKILL) | sigmask(SIGSTOP));
3263 signotset(&mask);
3264
3265 spin_lock_irq(&tsk->sighand->siglock);
3266 sig = dequeue_signal(tsk, &mask, info);
Thomas Gleixner2456e852016-12-25 11:38:40 +01003267 if (!sig && timeout) {
Oleg Nesterov943df142011-04-27 21:44:14 +02003268 /*
3269 * None ready, temporarily unblock those we're interested
3270 * while we are sleeping in so that we'll be awakened when
Oleg Nesterovb1828012011-04-27 21:56:14 +02003271 * they arrive. Unblocking is always fine, we can avoid
3272 * set_current_blocked().
Oleg Nesterov943df142011-04-27 21:44:14 +02003273 */
3274 tsk->real_blocked = tsk->blocked;
3275 sigandsets(&tsk->blocked, &tsk->blocked, &mask);
3276 recalc_sigpending();
3277 spin_unlock_irq(&tsk->sighand->siglock);
3278
Thomas Gleixner2b1ecc32016-07-04 09:50:25 +00003279 __set_current_state(TASK_INTERRUPTIBLE);
3280 ret = freezable_schedule_hrtimeout_range(to, tsk->timer_slack_ns,
3281 HRTIMER_MODE_REL);
Oleg Nesterov943df142011-04-27 21:44:14 +02003282 spin_lock_irq(&tsk->sighand->siglock);
Oleg Nesterovb1828012011-04-27 21:56:14 +02003283 __set_task_blocked(tsk, &tsk->real_blocked);
Oleg Nesterov61140412014-06-06 14:36:46 -07003284 sigemptyset(&tsk->real_blocked);
Oleg Nesterovb1828012011-04-27 21:56:14 +02003285 sig = dequeue_signal(tsk, &mask, info);
Oleg Nesterov943df142011-04-27 21:44:14 +02003286 }
3287 spin_unlock_irq(&tsk->sighand->siglock);
3288
3289 if (sig)
3290 return sig;
Thomas Gleixner2b1ecc32016-07-04 09:50:25 +00003291 return ret ? -EINTR : -EAGAIN;
Oleg Nesterov943df142011-04-27 21:44:14 +02003292}
3293
3294/**
Randy Dunlap41c57892011-04-04 15:00:26 -07003295 * sys_rt_sigtimedwait - synchronously wait for queued signals specified
3296 * in @uthese
3297 * @uthese: queued signals to wait for
3298 * @uinfo: if non-null, the signal's siginfo is returned here
3299 * @uts: upper bound on process time suspension
3300 * @sigsetsize: size of sigset_t type
3301 */
Heiko Carstens17da2bd2009-01-14 14:14:10 +01003302SYSCALL_DEFINE4(rt_sigtimedwait, const sigset_t __user *, uthese,
Arnd Bergmann49c39f82018-04-18 15:56:13 +02003303 siginfo_t __user *, uinfo,
3304 const struct __kernel_timespec __user *, uts,
Heiko Carstens17da2bd2009-01-14 14:14:10 +01003305 size_t, sigsetsize)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003306{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003307 sigset_t these;
Arnd Bergmann49c39f82018-04-18 15:56:13 +02003308 struct timespec64 ts;
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003309 kernel_siginfo_t info;
Oleg Nesterov943df142011-04-27 21:44:14 +02003310 int ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003311
3312 /* XXX: Don't preclude handling different sized sigset_t's. */
3313 if (sigsetsize != sizeof(sigset_t))
3314 return -EINVAL;
3315
3316 if (copy_from_user(&these, uthese, sizeof(these)))
3317 return -EFAULT;
Randy Dunlap5aba0852011-04-04 14:59:31 -07003318
Linus Torvalds1da177e2005-04-16 15:20:36 -07003319 if (uts) {
Arnd Bergmann49c39f82018-04-18 15:56:13 +02003320 if (get_timespec64(&ts, uts))
Linus Torvalds1da177e2005-04-16 15:20:36 -07003321 return -EFAULT;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003322 }
3323
Oleg Nesterov943df142011-04-27 21:44:14 +02003324 ret = do_sigtimedwait(&these, &info, uts ? &ts : NULL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003325
Oleg Nesterov943df142011-04-27 21:44:14 +02003326 if (ret > 0 && uinfo) {
3327 if (copy_siginfo_to_user(uinfo, &info))
3328 ret = -EFAULT;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003329 }
3330
3331 return ret;
3332}
3333
Arnd Bergmanndf8522a2018-04-18 16:15:37 +02003334#ifdef CONFIG_COMPAT_32BIT_TIME
3335SYSCALL_DEFINE4(rt_sigtimedwait_time32, const sigset_t __user *, uthese,
3336 siginfo_t __user *, uinfo,
3337 const struct old_timespec32 __user *, uts,
3338 size_t, sigsetsize)
3339{
3340 sigset_t these;
3341 struct timespec64 ts;
3342 kernel_siginfo_t info;
3343 int ret;
3344
3345 if (sigsetsize != sizeof(sigset_t))
3346 return -EINVAL;
3347
3348 if (copy_from_user(&these, uthese, sizeof(these)))
3349 return -EFAULT;
3350
3351 if (uts) {
3352 if (get_old_timespec32(&ts, uts))
3353 return -EFAULT;
3354 }
3355
3356 ret = do_sigtimedwait(&these, &info, uts ? &ts : NULL);
3357
3358 if (ret > 0 && uinfo) {
3359 if (copy_siginfo_to_user(uinfo, &info))
3360 ret = -EFAULT;
3361 }
3362
3363 return ret;
3364}
3365#endif
3366
Al Viro1b3c8722017-05-31 04:46:17 -04003367#ifdef CONFIG_COMPAT
Arnd Bergmann2367c4b2018-04-18 16:18:35 +02003368COMPAT_SYSCALL_DEFINE4(rt_sigtimedwait_time64, compat_sigset_t __user *, uthese,
3369 struct compat_siginfo __user *, uinfo,
3370 struct __kernel_timespec __user *, uts, compat_size_t, sigsetsize)
3371{
3372 sigset_t s;
3373 struct timespec64 t;
3374 kernel_siginfo_t info;
3375 long ret;
3376
3377 if (sigsetsize != sizeof(sigset_t))
3378 return -EINVAL;
3379
3380 if (get_compat_sigset(&s, uthese))
3381 return -EFAULT;
3382
3383 if (uts) {
3384 if (get_timespec64(&t, uts))
3385 return -EFAULT;
3386 }
3387
3388 ret = do_sigtimedwait(&s, &info, uts ? &t : NULL);
3389
3390 if (ret > 0 && uinfo) {
3391 if (copy_siginfo_to_user32(uinfo, &info))
3392 ret = -EFAULT;
3393 }
3394
3395 return ret;
3396}
3397
3398#ifdef CONFIG_COMPAT_32BIT_TIME
Al Viro1b3c8722017-05-31 04:46:17 -04003399COMPAT_SYSCALL_DEFINE4(rt_sigtimedwait, compat_sigset_t __user *, uthese,
3400 struct compat_siginfo __user *, uinfo,
Arnd Bergmann9afc5ee2018-07-13 12:52:28 +02003401 struct old_timespec32 __user *, uts, compat_size_t, sigsetsize)
Al Viro1b3c8722017-05-31 04:46:17 -04003402{
Al Viro1b3c8722017-05-31 04:46:17 -04003403 sigset_t s;
Arnd Bergmann49c39f82018-04-18 15:56:13 +02003404 struct timespec64 t;
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003405 kernel_siginfo_t info;
Al Viro1b3c8722017-05-31 04:46:17 -04003406 long ret;
3407
3408 if (sigsetsize != sizeof(sigset_t))
3409 return -EINVAL;
3410
Al Viro3968cf62017-09-03 21:45:17 -04003411 if (get_compat_sigset(&s, uthese))
Al Viro1b3c8722017-05-31 04:46:17 -04003412 return -EFAULT;
Al Viro1b3c8722017-05-31 04:46:17 -04003413
3414 if (uts) {
Arnd Bergmann49c39f82018-04-18 15:56:13 +02003415 if (get_old_timespec32(&t, uts))
Al Viro1b3c8722017-05-31 04:46:17 -04003416 return -EFAULT;
3417 }
3418
3419 ret = do_sigtimedwait(&s, &info, uts ? &t : NULL);
3420
3421 if (ret > 0 && uinfo) {
3422 if (copy_siginfo_to_user32(uinfo, &info))
3423 ret = -EFAULT;
3424 }
3425
3426 return ret;
3427}
3428#endif
Arnd Bergmann2367c4b2018-04-18 16:18:35 +02003429#endif
Al Viro1b3c8722017-05-31 04:46:17 -04003430
Randy Dunlap41c57892011-04-04 15:00:26 -07003431/**
3432 * sys_kill - send a signal to a process
3433 * @pid: the PID of the process
3434 * @sig: signal to be sent
3435 */
Heiko Carstens17da2bd2009-01-14 14:14:10 +01003436SYSCALL_DEFINE2(kill, pid_t, pid, int, sig)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003437{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003438 struct kernel_siginfo info;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003439
Eric W. Biedermanfaf1f222018-01-05 17:27:42 -06003440 clear_siginfo(&info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003441 info.si_signo = sig;
3442 info.si_errno = 0;
3443 info.si_code = SI_USER;
Pavel Emelyanovb4888932007-10-18 23:40:14 -07003444 info.si_pid = task_tgid_vnr(current);
Eric W. Biederman078de5f2012-02-08 07:00:08 -08003445 info.si_uid = from_kuid_munged(current_user_ns(), current_uid());
Linus Torvalds1da177e2005-04-16 15:20:36 -07003446
3447 return kill_something_info(sig, &info, pid);
3448}
3449
Thomas Gleixner30b4ae82009-04-04 21:01:01 +00003450static int
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003451do_send_specific(pid_t tgid, pid_t pid, int sig, struct kernel_siginfo *info)
Vadim Lobanov6dd69f12005-10-30 15:02:18 -08003452{
Vadim Lobanov6dd69f12005-10-30 15:02:18 -08003453 struct task_struct *p;
Thomas Gleixner30b4ae82009-04-04 21:01:01 +00003454 int error = -ESRCH;
Vadim Lobanov6dd69f12005-10-30 15:02:18 -08003455
Oleg Nesterov3547ff32008-04-30 00:52:51 -07003456 rcu_read_lock();
Pavel Emelyanov228ebcb2007-10-18 23:40:16 -07003457 p = find_task_by_vpid(pid);
Pavel Emelyanovb4888932007-10-18 23:40:14 -07003458 if (p && (tgid <= 0 || task_tgid_vnr(p) == tgid)) {
Thomas Gleixner30b4ae82009-04-04 21:01:01 +00003459 error = check_kill_permission(sig, info, p);
Vadim Lobanov6dd69f12005-10-30 15:02:18 -08003460 /*
3461 * The null signal is a permissions and process existence
3462 * probe. No signal is actually delivered.
3463 */
Oleg Nesterov4a30deb2009-09-23 15:57:00 -07003464 if (!error && sig) {
Eric W. Biederman40b3b022018-07-21 10:45:15 -05003465 error = do_send_sig_info(sig, info, p, PIDTYPE_PID);
Oleg Nesterov4a30deb2009-09-23 15:57:00 -07003466 /*
3467 * If lock_task_sighand() failed we pretend the task
3468 * dies after receiving the signal. The window is tiny,
3469 * and the signal is private anyway.
3470 */
3471 if (unlikely(error == -ESRCH))
3472 error = 0;
Vadim Lobanov6dd69f12005-10-30 15:02:18 -08003473 }
3474 }
Oleg Nesterov3547ff32008-04-30 00:52:51 -07003475 rcu_read_unlock();
Vadim Lobanov6dd69f12005-10-30 15:02:18 -08003476
3477 return error;
3478}
3479
Thomas Gleixner30b4ae82009-04-04 21:01:01 +00003480static int do_tkill(pid_t tgid, pid_t pid, int sig)
3481{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003482 struct kernel_siginfo info;
Thomas Gleixner30b4ae82009-04-04 21:01:01 +00003483
Eric W. Biederman5f749722018-01-22 14:58:57 -06003484 clear_siginfo(&info);
Thomas Gleixner30b4ae82009-04-04 21:01:01 +00003485 info.si_signo = sig;
3486 info.si_errno = 0;
3487 info.si_code = SI_TKILL;
3488 info.si_pid = task_tgid_vnr(current);
Eric W. Biederman078de5f2012-02-08 07:00:08 -08003489 info.si_uid = from_kuid_munged(current_user_ns(), current_uid());
Thomas Gleixner30b4ae82009-04-04 21:01:01 +00003490
3491 return do_send_specific(tgid, pid, sig, &info);
3492}
3493
Linus Torvalds1da177e2005-04-16 15:20:36 -07003494/**
3495 * sys_tgkill - send signal to one specific thread
3496 * @tgid: the thread group ID of the thread
3497 * @pid: the PID of the thread
3498 * @sig: signal to be sent
3499 *
Robert P. J. Day72fd4a32007-02-10 01:45:59 -08003500 * This syscall also checks the @tgid and returns -ESRCH even if the PID
Linus Torvalds1da177e2005-04-16 15:20:36 -07003501 * exists but it's not belonging to the target process anymore. This
3502 * method solves the problem of threads exiting and PIDs getting reused.
3503 */
Heiko Carstensa5f8fa92009-01-14 14:14:11 +01003504SYSCALL_DEFINE3(tgkill, pid_t, tgid, pid_t, pid, int, sig)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003505{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003506 /* This is only valid for single tasks */
3507 if (pid <= 0 || tgid <= 0)
3508 return -EINVAL;
3509
Vadim Lobanov6dd69f12005-10-30 15:02:18 -08003510 return do_tkill(tgid, pid, sig);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003511}
3512
Randy Dunlap41c57892011-04-04 15:00:26 -07003513/**
3514 * sys_tkill - send signal to one specific task
3515 * @pid: the PID of the task
3516 * @sig: signal to be sent
3517 *
Linus Torvalds1da177e2005-04-16 15:20:36 -07003518 * Send a signal to only one task, even if it's a CLONE_THREAD task.
3519 */
Heiko Carstensa5f8fa92009-01-14 14:14:11 +01003520SYSCALL_DEFINE2(tkill, pid_t, pid, int, sig)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003521{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003522 /* This is only valid for single tasks */
3523 if (pid <= 0)
3524 return -EINVAL;
3525
Vadim Lobanov6dd69f12005-10-30 15:02:18 -08003526 return do_tkill(0, pid, sig);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003527}
3528
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003529static int do_rt_sigqueueinfo(pid_t pid, int sig, kernel_siginfo_t *info)
Al Viro75907d42012-12-25 15:19:12 -05003530{
3531 /* Not even root can pretend to send signals from the kernel.
3532 * Nor can they impersonate a kill()/tgkill(), which adds source info.
3533 */
Andrey Vagin66dd34a2013-02-27 17:03:12 -08003534 if ((info->si_code >= 0 || info->si_code == SI_TKILL) &&
Vladimir Davydov69828dc2015-04-16 12:47:35 -07003535 (task_pid_vnr(current) != pid))
Al Viro75907d42012-12-25 15:19:12 -05003536 return -EPERM;
Vladimir Davydov69828dc2015-04-16 12:47:35 -07003537
Al Viro75907d42012-12-25 15:19:12 -05003538 /* POSIX.1b doesn't mention process groups. */
3539 return kill_proc_info(sig, info, pid);
3540}
3541
Randy Dunlap41c57892011-04-04 15:00:26 -07003542/**
3543 * sys_rt_sigqueueinfo - send signal information to a signal
3544 * @pid: the PID of the thread
3545 * @sig: signal to be sent
3546 * @uinfo: signal info to be sent
3547 */
Heiko Carstensa5f8fa92009-01-14 14:14:11 +01003548SYSCALL_DEFINE3(rt_sigqueueinfo, pid_t, pid, int, sig,
3549 siginfo_t __user *, uinfo)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003550{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003551 kernel_siginfo_t info;
Eric W. Biederman601d5ab2018-10-05 09:02:48 +02003552 int ret = __copy_siginfo_from_user(sig, &info, uinfo);
Eric W. Biederman4cd2e0e2018-04-18 17:30:19 -05003553 if (unlikely(ret))
3554 return ret;
Al Viro75907d42012-12-25 15:19:12 -05003555 return do_rt_sigqueueinfo(pid, sig, &info);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003556}
3557
Al Viro75907d42012-12-25 15:19:12 -05003558#ifdef CONFIG_COMPAT
Al Viro75907d42012-12-25 15:19:12 -05003559COMPAT_SYSCALL_DEFINE3(rt_sigqueueinfo,
3560 compat_pid_t, pid,
3561 int, sig,
3562 struct compat_siginfo __user *, uinfo)
3563{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003564 kernel_siginfo_t info;
Eric W. Biederman601d5ab2018-10-05 09:02:48 +02003565 int ret = __copy_siginfo_from_user32(sig, &info, uinfo);
Al Viro75907d42012-12-25 15:19:12 -05003566 if (unlikely(ret))
3567 return ret;
3568 return do_rt_sigqueueinfo(pid, sig, &info);
3569}
3570#endif
Al Viro75907d42012-12-25 15:19:12 -05003571
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003572static int do_rt_tgsigqueueinfo(pid_t tgid, pid_t pid, int sig, kernel_siginfo_t *info)
Thomas Gleixner62ab4502009-04-04 21:01:06 +00003573{
3574 /* This is only valid for single tasks */
3575 if (pid <= 0 || tgid <= 0)
3576 return -EINVAL;
3577
3578 /* Not even root can pretend to send signals from the kernel.
Julien Tinnesda485242011-03-18 15:05:21 -07003579 * Nor can they impersonate a kill()/tgkill(), which adds source info.
3580 */
Vladimir Davydov69828dc2015-04-16 12:47:35 -07003581 if ((info->si_code >= 0 || info->si_code == SI_TKILL) &&
3582 (task_pid_vnr(current) != pid))
Thomas Gleixner62ab4502009-04-04 21:01:06 +00003583 return -EPERM;
Vladimir Davydov69828dc2015-04-16 12:47:35 -07003584
Thomas Gleixner62ab4502009-04-04 21:01:06 +00003585 return do_send_specific(tgid, pid, sig, info);
3586}
3587
3588SYSCALL_DEFINE4(rt_tgsigqueueinfo, pid_t, tgid, pid_t, pid, int, sig,
3589 siginfo_t __user *, uinfo)
3590{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003591 kernel_siginfo_t info;
Eric W. Biederman601d5ab2018-10-05 09:02:48 +02003592 int ret = __copy_siginfo_from_user(sig, &info, uinfo);
Eric W. Biederman4cd2e0e2018-04-18 17:30:19 -05003593 if (unlikely(ret))
3594 return ret;
Thomas Gleixner62ab4502009-04-04 21:01:06 +00003595 return do_rt_tgsigqueueinfo(tgid, pid, sig, &info);
3596}
3597
Al Viro9aae8fc2012-12-24 23:12:04 -05003598#ifdef CONFIG_COMPAT
3599COMPAT_SYSCALL_DEFINE4(rt_tgsigqueueinfo,
3600 compat_pid_t, tgid,
3601 compat_pid_t, pid,
3602 int, sig,
3603 struct compat_siginfo __user *, uinfo)
3604{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02003605 kernel_siginfo_t info;
Eric W. Biederman601d5ab2018-10-05 09:02:48 +02003606 int ret = __copy_siginfo_from_user32(sig, &info, uinfo);
Eric W. Biederman4cd2e0e2018-04-18 17:30:19 -05003607 if (unlikely(ret))
3608 return ret;
Al Viro9aae8fc2012-12-24 23:12:04 -05003609 return do_rt_tgsigqueueinfo(tgid, pid, sig, &info);
3610}
3611#endif
3612
Oleg Nesterov03417292014-06-06 14:36:53 -07003613/*
Oleg Nesterovb4e74262014-06-06 14:37:00 -07003614 * For kthreads only, must not be used if cloned with CLONE_SIGHAND
Oleg Nesterov03417292014-06-06 14:36:53 -07003615 */
Oleg Nesterovb4e74262014-06-06 14:37:00 -07003616void kernel_sigaction(int sig, __sighandler_t action)
Oleg Nesterov03417292014-06-06 14:36:53 -07003617{
Oleg Nesterovec5955b2014-06-06 14:36:57 -07003618 spin_lock_irq(&current->sighand->siglock);
Oleg Nesterovb4e74262014-06-06 14:37:00 -07003619 current->sighand->action[sig - 1].sa.sa_handler = action;
3620 if (action == SIG_IGN) {
3621 sigset_t mask;
3622
3623 sigemptyset(&mask);
3624 sigaddset(&mask, sig);
3625
3626 flush_sigqueue_mask(&mask, &current->signal->shared_pending);
3627 flush_sigqueue_mask(&mask, &current->pending);
3628 recalc_sigpending();
3629 }
Oleg Nesterov03417292014-06-06 14:36:53 -07003630 spin_unlock_irq(&current->sighand->siglock);
3631}
Oleg Nesterovb4e74262014-06-06 14:37:00 -07003632EXPORT_SYMBOL(kernel_sigaction);
Oleg Nesterov03417292014-06-06 14:36:53 -07003633
Dmitry Safonov68463512016-09-05 16:33:08 +03003634void __weak sigaction_compat_abi(struct k_sigaction *act,
3635 struct k_sigaction *oact)
3636{
3637}
3638
Oleg Nesterov88531f72006-03-28 16:11:24 -08003639int do_sigaction(int sig, struct k_sigaction *act, struct k_sigaction *oact)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003640{
Oleg Nesterovafe2b032014-06-06 14:36:51 -07003641 struct task_struct *p = current, *t;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003642 struct k_sigaction *k;
George Anzinger71fabd52006-01-08 01:02:48 -08003643 sigset_t mask;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003644
Jesper Juhl7ed20e12005-05-01 08:59:14 -07003645 if (!valid_signal(sig) || sig < 1 || (act && sig_kernel_only(sig)))
Linus Torvalds1da177e2005-04-16 15:20:36 -07003646 return -EINVAL;
3647
Oleg Nesterovafe2b032014-06-06 14:36:51 -07003648 k = &p->sighand->action[sig-1];
Linus Torvalds1da177e2005-04-16 15:20:36 -07003649
Oleg Nesterovafe2b032014-06-06 14:36:51 -07003650 spin_lock_irq(&p->sighand->siglock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003651 if (oact)
3652 *oact = *k;
3653
Dmitry Safonov68463512016-09-05 16:33:08 +03003654 sigaction_compat_abi(act, oact);
3655
Linus Torvalds1da177e2005-04-16 15:20:36 -07003656 if (act) {
Oleg Nesterov9ac95f22006-02-09 22:41:50 +03003657 sigdelsetmask(&act->sa.sa_mask,
3658 sigmask(SIGKILL) | sigmask(SIGSTOP));
Oleg Nesterov88531f72006-03-28 16:11:24 -08003659 *k = *act;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003660 /*
3661 * POSIX 3.3.1.3:
3662 * "Setting a signal action to SIG_IGN for a signal that is
3663 * pending shall cause the pending signal to be discarded,
3664 * whether or not it is blocked."
3665 *
3666 * "Setting a signal action to SIG_DFL for a signal that is
3667 * pending and whose default action is to ignore the signal
3668 * (for example, SIGCHLD), shall cause the pending signal to
3669 * be discarded, whether or not it is blocked"
3670 */
Oleg Nesterovafe2b032014-06-06 14:36:51 -07003671 if (sig_handler_ignored(sig_handler(p, sig), sig)) {
George Anzinger71fabd52006-01-08 01:02:48 -08003672 sigemptyset(&mask);
3673 sigaddset(&mask, sig);
Oleg Nesterovafe2b032014-06-06 14:36:51 -07003674 flush_sigqueue_mask(&mask, &p->signal->shared_pending);
3675 for_each_thread(p, t)
Oleg Nesterovc09c1442014-06-06 14:36:50 -07003676 flush_sigqueue_mask(&mask, &t->pending);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003677 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07003678 }
3679
Oleg Nesterovafe2b032014-06-06 14:36:51 -07003680 spin_unlock_irq(&p->sighand->siglock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003681 return 0;
3682}
3683
Oleg Nesterovc09c1442014-06-06 14:36:50 -07003684static int
Will Deacon22839862018-09-05 15:34:42 +01003685do_sigaltstack (const stack_t *ss, stack_t *oss, unsigned long sp,
3686 size_t min_ss_size)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003687{
Al Virobcfe8ad2017-05-27 00:29:34 -04003688 struct task_struct *t = current;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003689
Al Virobcfe8ad2017-05-27 00:29:34 -04003690 if (oss) {
3691 memset(oss, 0, sizeof(stack_t));
3692 oss->ss_sp = (void __user *) t->sas_ss_sp;
3693 oss->ss_size = t->sas_ss_size;
3694 oss->ss_flags = sas_ss_flags(sp) |
3695 (current->sas_ss_flags & SS_FLAG_BITS);
3696 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07003697
Al Virobcfe8ad2017-05-27 00:29:34 -04003698 if (ss) {
3699 void __user *ss_sp = ss->ss_sp;
3700 size_t ss_size = ss->ss_size;
3701 unsigned ss_flags = ss->ss_flags;
Stas Sergeev407bc162016-04-14 23:20:03 +03003702 int ss_mode;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003703
Al Virobcfe8ad2017-05-27 00:29:34 -04003704 if (unlikely(on_sig_stack(sp)))
3705 return -EPERM;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003706
Stas Sergeev407bc162016-04-14 23:20:03 +03003707 ss_mode = ss_flags & ~SS_FLAG_BITS;
Al Virobcfe8ad2017-05-27 00:29:34 -04003708 if (unlikely(ss_mode != SS_DISABLE && ss_mode != SS_ONSTACK &&
3709 ss_mode != 0))
3710 return -EINVAL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003711
Stas Sergeev407bc162016-04-14 23:20:03 +03003712 if (ss_mode == SS_DISABLE) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07003713 ss_size = 0;
3714 ss_sp = NULL;
3715 } else {
Will Deacon22839862018-09-05 15:34:42 +01003716 if (unlikely(ss_size < min_ss_size))
Al Virobcfe8ad2017-05-27 00:29:34 -04003717 return -ENOMEM;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003718 }
3719
Al Virobcfe8ad2017-05-27 00:29:34 -04003720 t->sas_ss_sp = (unsigned long) ss_sp;
3721 t->sas_ss_size = ss_size;
3722 t->sas_ss_flags = ss_flags;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003723 }
Al Virobcfe8ad2017-05-27 00:29:34 -04003724 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003725}
Al Virobcfe8ad2017-05-27 00:29:34 -04003726
Al Viro6bf9adf2012-12-14 14:09:47 -05003727SYSCALL_DEFINE2(sigaltstack,const stack_t __user *,uss, stack_t __user *,uoss)
3728{
Al Virobcfe8ad2017-05-27 00:29:34 -04003729 stack_t new, old;
3730 int err;
3731 if (uss && copy_from_user(&new, uss, sizeof(stack_t)))
3732 return -EFAULT;
3733 err = do_sigaltstack(uss ? &new : NULL, uoss ? &old : NULL,
Will Deacon22839862018-09-05 15:34:42 +01003734 current_user_stack_pointer(),
3735 MINSIGSTKSZ);
Al Virobcfe8ad2017-05-27 00:29:34 -04003736 if (!err && uoss && copy_to_user(uoss, &old, sizeof(stack_t)))
3737 err = -EFAULT;
3738 return err;
Al Viro6bf9adf2012-12-14 14:09:47 -05003739}
Linus Torvalds1da177e2005-04-16 15:20:36 -07003740
Al Viro5c495742012-11-18 15:29:16 -05003741int restore_altstack(const stack_t __user *uss)
3742{
Al Virobcfe8ad2017-05-27 00:29:34 -04003743 stack_t new;
3744 if (copy_from_user(&new, uss, sizeof(stack_t)))
3745 return -EFAULT;
Will Deacon22839862018-09-05 15:34:42 +01003746 (void)do_sigaltstack(&new, NULL, current_user_stack_pointer(),
3747 MINSIGSTKSZ);
Al Viro5c495742012-11-18 15:29:16 -05003748 /* squash all but EFAULT for now */
Al Virobcfe8ad2017-05-27 00:29:34 -04003749 return 0;
Al Viro5c495742012-11-18 15:29:16 -05003750}
3751
Al Viroc40702c2012-11-20 14:24:26 -05003752int __save_altstack(stack_t __user *uss, unsigned long sp)
3753{
3754 struct task_struct *t = current;
Stas Sergeev2a742132016-04-14 23:20:04 +03003755 int err = __put_user((void __user *)t->sas_ss_sp, &uss->ss_sp) |
3756 __put_user(t->sas_ss_flags, &uss->ss_flags) |
Al Viroc40702c2012-11-20 14:24:26 -05003757 __put_user(t->sas_ss_size, &uss->ss_size);
Stas Sergeev2a742132016-04-14 23:20:04 +03003758 if (err)
3759 return err;
3760 if (t->sas_ss_flags & SS_AUTODISARM)
3761 sas_ss_reset(t);
3762 return 0;
Al Viroc40702c2012-11-20 14:24:26 -05003763}
3764
Al Viro90268432012-12-14 14:47:53 -05003765#ifdef CONFIG_COMPAT
Dominik Brodowski6203deb2018-03-17 17:11:51 +01003766static int do_compat_sigaltstack(const compat_stack_t __user *uss_ptr,
3767 compat_stack_t __user *uoss_ptr)
Al Viro90268432012-12-14 14:47:53 -05003768{
3769 stack_t uss, uoss;
3770 int ret;
Al Viro90268432012-12-14 14:47:53 -05003771
3772 if (uss_ptr) {
3773 compat_stack_t uss32;
Al Viro90268432012-12-14 14:47:53 -05003774 if (copy_from_user(&uss32, uss_ptr, sizeof(compat_stack_t)))
3775 return -EFAULT;
3776 uss.ss_sp = compat_ptr(uss32.ss_sp);
3777 uss.ss_flags = uss32.ss_flags;
3778 uss.ss_size = uss32.ss_size;
3779 }
Al Virobcfe8ad2017-05-27 00:29:34 -04003780 ret = do_sigaltstack(uss_ptr ? &uss : NULL, &uoss,
Will Deacon22839862018-09-05 15:34:42 +01003781 compat_user_stack_pointer(),
3782 COMPAT_MINSIGSTKSZ);
Al Viro90268432012-12-14 14:47:53 -05003783 if (ret >= 0 && uoss_ptr) {
Al Virobcfe8ad2017-05-27 00:29:34 -04003784 compat_stack_t old;
3785 memset(&old, 0, sizeof(old));
3786 old.ss_sp = ptr_to_compat(uoss.ss_sp);
3787 old.ss_flags = uoss.ss_flags;
3788 old.ss_size = uoss.ss_size;
3789 if (copy_to_user(uoss_ptr, &old, sizeof(compat_stack_t)))
Al Viro90268432012-12-14 14:47:53 -05003790 ret = -EFAULT;
3791 }
3792 return ret;
3793}
3794
Dominik Brodowski6203deb2018-03-17 17:11:51 +01003795COMPAT_SYSCALL_DEFINE2(sigaltstack,
3796 const compat_stack_t __user *, uss_ptr,
3797 compat_stack_t __user *, uoss_ptr)
3798{
3799 return do_compat_sigaltstack(uss_ptr, uoss_ptr);
3800}
3801
Al Viro90268432012-12-14 14:47:53 -05003802int compat_restore_altstack(const compat_stack_t __user *uss)
3803{
Dominik Brodowski6203deb2018-03-17 17:11:51 +01003804 int err = do_compat_sigaltstack(uss, NULL);
Al Viro90268432012-12-14 14:47:53 -05003805 /* squash all but -EFAULT for now */
3806 return err == -EFAULT ? err : 0;
3807}
Al Viroc40702c2012-11-20 14:24:26 -05003808
3809int __compat_save_altstack(compat_stack_t __user *uss, unsigned long sp)
3810{
Stas Sergeev441398d2017-02-27 14:27:25 -08003811 int err;
Al Viroc40702c2012-11-20 14:24:26 -05003812 struct task_struct *t = current;
Stas Sergeev441398d2017-02-27 14:27:25 -08003813 err = __put_user(ptr_to_compat((void __user *)t->sas_ss_sp),
3814 &uss->ss_sp) |
3815 __put_user(t->sas_ss_flags, &uss->ss_flags) |
Al Viroc40702c2012-11-20 14:24:26 -05003816 __put_user(t->sas_ss_size, &uss->ss_size);
Stas Sergeev441398d2017-02-27 14:27:25 -08003817 if (err)
3818 return err;
3819 if (t->sas_ss_flags & SS_AUTODISARM)
3820 sas_ss_reset(t);
3821 return 0;
Al Viroc40702c2012-11-20 14:24:26 -05003822}
Al Viro90268432012-12-14 14:47:53 -05003823#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -07003824
3825#ifdef __ARCH_WANT_SYS_SIGPENDING
3826
Randy Dunlap41c57892011-04-04 15:00:26 -07003827/**
3828 * sys_sigpending - examine pending signals
Dominik Brodowskid53238c2018-03-11 11:34:37 +01003829 * @uset: where mask of pending signal is returned
Randy Dunlap41c57892011-04-04 15:00:26 -07003830 */
Dominik Brodowskid53238c2018-03-11 11:34:37 +01003831SYSCALL_DEFINE1(sigpending, old_sigset_t __user *, uset)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003832{
Dominik Brodowskid53238c2018-03-11 11:34:37 +01003833 sigset_t set;
Dominik Brodowskid53238c2018-03-11 11:34:37 +01003834
3835 if (sizeof(old_sigset_t) > sizeof(*uset))
3836 return -EINVAL;
3837
Christian Braunerb1d294c2018-08-21 22:00:02 -07003838 do_sigpending(&set);
3839
3840 if (copy_to_user(uset, &set, sizeof(old_sigset_t)))
3841 return -EFAULT;
3842
3843 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003844}
3845
Al Viro8f136212017-05-31 04:42:07 -04003846#ifdef CONFIG_COMPAT
3847COMPAT_SYSCALL_DEFINE1(sigpending, compat_old_sigset_t __user *, set32)
3848{
3849 sigset_t set;
Christian Braunerb1d294c2018-08-21 22:00:02 -07003850
3851 do_sigpending(&set);
3852
3853 return put_user(set.sig[0], set32);
Al Viro8f136212017-05-31 04:42:07 -04003854}
3855#endif
3856
Linus Torvalds1da177e2005-04-16 15:20:36 -07003857#endif
3858
3859#ifdef __ARCH_WANT_SYS_SIGPROCMASK
Randy Dunlap41c57892011-04-04 15:00:26 -07003860/**
3861 * sys_sigprocmask - examine and change blocked signals
3862 * @how: whether to add, remove, or set signals
Oleg Nesterovb013c392011-04-28 11:36:20 +02003863 * @nset: signals to add or remove (if non-null)
Randy Dunlap41c57892011-04-04 15:00:26 -07003864 * @oset: previous value of signal mask if non-null
3865 *
Randy Dunlap5aba0852011-04-04 14:59:31 -07003866 * Some platforms have their own version with special arguments;
3867 * others support only sys_rt_sigprocmask.
3868 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07003869
Oleg Nesterovb013c392011-04-28 11:36:20 +02003870SYSCALL_DEFINE3(sigprocmask, int, how, old_sigset_t __user *, nset,
Heiko Carstensb290ebe2009-01-14 14:14:06 +01003871 old_sigset_t __user *, oset)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003872{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003873 old_sigset_t old_set, new_set;
Oleg Nesterov2e4f7c72011-05-09 13:48:56 +02003874 sigset_t new_blocked;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003875
Oleg Nesterovb013c392011-04-28 11:36:20 +02003876 old_set = current->blocked.sig[0];
3877
3878 if (nset) {
3879 if (copy_from_user(&new_set, nset, sizeof(*nset)))
3880 return -EFAULT;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003881
Oleg Nesterov2e4f7c72011-05-09 13:48:56 +02003882 new_blocked = current->blocked;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003883
Linus Torvalds1da177e2005-04-16 15:20:36 -07003884 switch (how) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07003885 case SIG_BLOCK:
Oleg Nesterov2e4f7c72011-05-09 13:48:56 +02003886 sigaddsetmask(&new_blocked, new_set);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003887 break;
3888 case SIG_UNBLOCK:
Oleg Nesterov2e4f7c72011-05-09 13:48:56 +02003889 sigdelsetmask(&new_blocked, new_set);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003890 break;
3891 case SIG_SETMASK:
Oleg Nesterov2e4f7c72011-05-09 13:48:56 +02003892 new_blocked.sig[0] = new_set;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003893 break;
Oleg Nesterov2e4f7c72011-05-09 13:48:56 +02003894 default:
3895 return -EINVAL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003896 }
3897
Oleg Nesterov0c4a8422013-01-05 19:13:29 +01003898 set_current_blocked(&new_blocked);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003899 }
Oleg Nesterovb013c392011-04-28 11:36:20 +02003900
3901 if (oset) {
3902 if (copy_to_user(oset, &old_set, sizeof(*oset)))
3903 return -EFAULT;
3904 }
3905
3906 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003907}
3908#endif /* __ARCH_WANT_SYS_SIGPROCMASK */
3909
Al Viroeaca6ea2012-11-25 23:12:10 -05003910#ifndef CONFIG_ODD_RT_SIGACTION
Randy Dunlap41c57892011-04-04 15:00:26 -07003911/**
3912 * sys_rt_sigaction - alter an action taken by a process
3913 * @sig: signal to be sent
Randy Dunlapf9fa0bc2011-04-08 10:53:46 -07003914 * @act: new sigaction
3915 * @oact: used to save the previous sigaction
Randy Dunlap41c57892011-04-04 15:00:26 -07003916 * @sigsetsize: size of sigset_t type
3917 */
Heiko Carstensd4e82042009-01-14 14:14:34 +01003918SYSCALL_DEFINE4(rt_sigaction, int, sig,
3919 const struct sigaction __user *, act,
3920 struct sigaction __user *, oact,
3921 size_t, sigsetsize)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003922{
3923 struct k_sigaction new_sa, old_sa;
Christian Braunerd8f993b2018-08-21 22:00:07 -07003924 int ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003925
3926 /* XXX: Don't preclude handling different sized sigset_t's. */
3927 if (sigsetsize != sizeof(sigset_t))
Christian Braunerd8f993b2018-08-21 22:00:07 -07003928 return -EINVAL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003929
Christian Braunerd8f993b2018-08-21 22:00:07 -07003930 if (act && copy_from_user(&new_sa.sa, act, sizeof(new_sa.sa)))
3931 return -EFAULT;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003932
3933 ret = do_sigaction(sig, act ? &new_sa : NULL, oact ? &old_sa : NULL);
Christian Braunerd8f993b2018-08-21 22:00:07 -07003934 if (ret)
3935 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003936
Christian Braunerd8f993b2018-08-21 22:00:07 -07003937 if (oact && copy_to_user(oact, &old_sa.sa, sizeof(old_sa.sa)))
3938 return -EFAULT;
3939
3940 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003941}
Al Viro08d32fe2012-12-25 18:38:15 -05003942#ifdef CONFIG_COMPAT
Al Viro08d32fe2012-12-25 18:38:15 -05003943COMPAT_SYSCALL_DEFINE4(rt_sigaction, int, sig,
3944 const struct compat_sigaction __user *, act,
3945 struct compat_sigaction __user *, oact,
3946 compat_size_t, sigsetsize)
3947{
3948 struct k_sigaction new_ka, old_ka;
Al Viro08d32fe2012-12-25 18:38:15 -05003949#ifdef __ARCH_HAS_SA_RESTORER
3950 compat_uptr_t restorer;
3951#endif
3952 int ret;
3953
3954 /* XXX: Don't preclude handling different sized sigset_t's. */
3955 if (sigsetsize != sizeof(compat_sigset_t))
3956 return -EINVAL;
3957
3958 if (act) {
3959 compat_uptr_t handler;
3960 ret = get_user(handler, &act->sa_handler);
3961 new_ka.sa.sa_handler = compat_ptr(handler);
3962#ifdef __ARCH_HAS_SA_RESTORER
3963 ret |= get_user(restorer, &act->sa_restorer);
3964 new_ka.sa.sa_restorer = compat_ptr(restorer);
3965#endif
Al Viro3968cf62017-09-03 21:45:17 -04003966 ret |= get_compat_sigset(&new_ka.sa.sa_mask, &act->sa_mask);
Mathieu Desnoyers3ddc5b42013-09-11 14:23:18 -07003967 ret |= get_user(new_ka.sa.sa_flags, &act->sa_flags);
Al Viro08d32fe2012-12-25 18:38:15 -05003968 if (ret)
3969 return -EFAULT;
Al Viro08d32fe2012-12-25 18:38:15 -05003970 }
3971
3972 ret = do_sigaction(sig, act ? &new_ka : NULL, oact ? &old_ka : NULL);
3973 if (!ret && oact) {
Al Viro08d32fe2012-12-25 18:38:15 -05003974 ret = put_user(ptr_to_compat(old_ka.sa.sa_handler),
3975 &oact->sa_handler);
Dmitry V. Levinf4543222017-08-22 02:16:11 +03003976 ret |= put_compat_sigset(&oact->sa_mask, &old_ka.sa.sa_mask,
3977 sizeof(oact->sa_mask));
Mathieu Desnoyers3ddc5b42013-09-11 14:23:18 -07003978 ret |= put_user(old_ka.sa.sa_flags, &oact->sa_flags);
Al Viro08d32fe2012-12-25 18:38:15 -05003979#ifdef __ARCH_HAS_SA_RESTORER
3980 ret |= put_user(ptr_to_compat(old_ka.sa.sa_restorer),
3981 &oact->sa_restorer);
3982#endif
3983 }
3984 return ret;
3985}
3986#endif
Al Viroeaca6ea2012-11-25 23:12:10 -05003987#endif /* !CONFIG_ODD_RT_SIGACTION */
Linus Torvalds1da177e2005-04-16 15:20:36 -07003988
Al Viro495dfbf2012-12-25 19:09:45 -05003989#ifdef CONFIG_OLD_SIGACTION
3990SYSCALL_DEFINE3(sigaction, int, sig,
3991 const struct old_sigaction __user *, act,
3992 struct old_sigaction __user *, oact)
3993{
3994 struct k_sigaction new_ka, old_ka;
3995 int ret;
3996
3997 if (act) {
3998 old_sigset_t mask;
Linus Torvalds96d4f262019-01-03 18:57:57 -08003999 if (!access_ok(act, sizeof(*act)) ||
Al Viro495dfbf2012-12-25 19:09:45 -05004000 __get_user(new_ka.sa.sa_handler, &act->sa_handler) ||
4001 __get_user(new_ka.sa.sa_restorer, &act->sa_restorer) ||
4002 __get_user(new_ka.sa.sa_flags, &act->sa_flags) ||
4003 __get_user(mask, &act->sa_mask))
4004 return -EFAULT;
4005#ifdef __ARCH_HAS_KA_RESTORER
4006 new_ka.ka_restorer = NULL;
4007#endif
4008 siginitset(&new_ka.sa.sa_mask, mask);
4009 }
4010
4011 ret = do_sigaction(sig, act ? &new_ka : NULL, oact ? &old_ka : NULL);
4012
4013 if (!ret && oact) {
Linus Torvalds96d4f262019-01-03 18:57:57 -08004014 if (!access_ok(oact, sizeof(*oact)) ||
Al Viro495dfbf2012-12-25 19:09:45 -05004015 __put_user(old_ka.sa.sa_handler, &oact->sa_handler) ||
4016 __put_user(old_ka.sa.sa_restorer, &oact->sa_restorer) ||
4017 __put_user(old_ka.sa.sa_flags, &oact->sa_flags) ||
4018 __put_user(old_ka.sa.sa_mask.sig[0], &oact->sa_mask))
4019 return -EFAULT;
4020 }
4021
4022 return ret;
4023}
4024#endif
4025#ifdef CONFIG_COMPAT_OLD_SIGACTION
4026COMPAT_SYSCALL_DEFINE3(sigaction, int, sig,
4027 const struct compat_old_sigaction __user *, act,
4028 struct compat_old_sigaction __user *, oact)
4029{
4030 struct k_sigaction new_ka, old_ka;
4031 int ret;
4032 compat_old_sigset_t mask;
4033 compat_uptr_t handler, restorer;
4034
4035 if (act) {
Linus Torvalds96d4f262019-01-03 18:57:57 -08004036 if (!access_ok(act, sizeof(*act)) ||
Al Viro495dfbf2012-12-25 19:09:45 -05004037 __get_user(handler, &act->sa_handler) ||
4038 __get_user(restorer, &act->sa_restorer) ||
4039 __get_user(new_ka.sa.sa_flags, &act->sa_flags) ||
4040 __get_user(mask, &act->sa_mask))
4041 return -EFAULT;
4042
4043#ifdef __ARCH_HAS_KA_RESTORER
4044 new_ka.ka_restorer = NULL;
4045#endif
4046 new_ka.sa.sa_handler = compat_ptr(handler);
4047 new_ka.sa.sa_restorer = compat_ptr(restorer);
4048 siginitset(&new_ka.sa.sa_mask, mask);
4049 }
4050
4051 ret = do_sigaction(sig, act ? &new_ka : NULL, oact ? &old_ka : NULL);
4052
4053 if (!ret && oact) {
Linus Torvalds96d4f262019-01-03 18:57:57 -08004054 if (!access_ok(oact, sizeof(*oact)) ||
Al Viro495dfbf2012-12-25 19:09:45 -05004055 __put_user(ptr_to_compat(old_ka.sa.sa_handler),
4056 &oact->sa_handler) ||
4057 __put_user(ptr_to_compat(old_ka.sa.sa_restorer),
4058 &oact->sa_restorer) ||
4059 __put_user(old_ka.sa.sa_flags, &oact->sa_flags) ||
4060 __put_user(old_ka.sa.sa_mask.sig[0], &oact->sa_mask))
4061 return -EFAULT;
4062 }
4063 return ret;
4064}
4065#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -07004066
Fabian Frederickf6187762014-06-04 16:11:12 -07004067#ifdef CONFIG_SGETMASK_SYSCALL
Linus Torvalds1da177e2005-04-16 15:20:36 -07004068
4069/*
4070 * For backwards compatibility. Functionality superseded by sigprocmask.
4071 */
Heiko Carstensa5f8fa92009-01-14 14:14:11 +01004072SYSCALL_DEFINE0(sgetmask)
Linus Torvalds1da177e2005-04-16 15:20:36 -07004073{
4074 /* SMP safe */
4075 return current->blocked.sig[0];
4076}
4077
Heiko Carstensa5f8fa92009-01-14 14:14:11 +01004078SYSCALL_DEFINE1(ssetmask, int, newmask)
Linus Torvalds1da177e2005-04-16 15:20:36 -07004079{
Oleg Nesterovc1095c62011-07-27 12:49:44 -07004080 int old = current->blocked.sig[0];
4081 sigset_t newset;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004082
Oleg Nesterov5ba53ff2013-01-05 19:13:13 +01004083 siginitset(&newset, newmask);
Oleg Nesterovc1095c62011-07-27 12:49:44 -07004084 set_current_blocked(&newset);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004085
4086 return old;
4087}
Fabian Frederickf6187762014-06-04 16:11:12 -07004088#endif /* CONFIG_SGETMASK_SYSCALL */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004089
4090#ifdef __ARCH_WANT_SYS_SIGNAL
4091/*
4092 * For backwards compatibility. Functionality superseded by sigaction.
4093 */
Heiko Carstensa5f8fa92009-01-14 14:14:11 +01004094SYSCALL_DEFINE2(signal, int, sig, __sighandler_t, handler)
Linus Torvalds1da177e2005-04-16 15:20:36 -07004095{
4096 struct k_sigaction new_sa, old_sa;
4097 int ret;
4098
4099 new_sa.sa.sa_handler = handler;
4100 new_sa.sa.sa_flags = SA_ONESHOT | SA_NOMASK;
Oleg Nesterovc70d3d702006-02-09 22:41:41 +03004101 sigemptyset(&new_sa.sa.sa_mask);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004102
4103 ret = do_sigaction(sig, &new_sa, &old_sa);
4104
4105 return ret ? ret : (unsigned long)old_sa.sa.sa_handler;
4106}
4107#endif /* __ARCH_WANT_SYS_SIGNAL */
4108
4109#ifdef __ARCH_WANT_SYS_PAUSE
4110
Heiko Carstensa5f8fa92009-01-14 14:14:11 +01004111SYSCALL_DEFINE0(pause)
Linus Torvalds1da177e2005-04-16 15:20:36 -07004112{
Oleg Nesterovd92fcf02011-05-25 19:22:27 +02004113 while (!signal_pending(current)) {
Davidlohr Bueso1df01352015-02-17 13:45:41 -08004114 __set_current_state(TASK_INTERRUPTIBLE);
Oleg Nesterovd92fcf02011-05-25 19:22:27 +02004115 schedule();
4116 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07004117 return -ERESTARTNOHAND;
4118}
4119
4120#endif
4121
Richard Weinberger9d8a7652015-11-20 15:57:21 -08004122static int sigsuspend(sigset_t *set)
Al Viro68f3f162012-05-21 21:42:32 -04004123{
Al Viro68f3f162012-05-21 21:42:32 -04004124 current->saved_sigmask = current->blocked;
4125 set_current_blocked(set);
4126
Sasha Levin823dd322016-02-05 15:36:05 -08004127 while (!signal_pending(current)) {
4128 __set_current_state(TASK_INTERRUPTIBLE);
4129 schedule();
4130 }
Al Viro68f3f162012-05-21 21:42:32 -04004131 set_restore_sigmask();
4132 return -ERESTARTNOHAND;
4133}
Al Viro68f3f162012-05-21 21:42:32 -04004134
Randy Dunlap41c57892011-04-04 15:00:26 -07004135/**
4136 * sys_rt_sigsuspend - replace the signal mask for a value with the
4137 * @unewset value until a signal is received
4138 * @unewset: new signal mask value
4139 * @sigsetsize: size of sigset_t type
4140 */
Heiko Carstensd4e82042009-01-14 14:14:34 +01004141SYSCALL_DEFINE2(rt_sigsuspend, sigset_t __user *, unewset, size_t, sigsetsize)
David Woodhouse150256d2006-01-18 17:43:57 -08004142{
4143 sigset_t newset;
4144
4145 /* XXX: Don't preclude handling different sized sigset_t's. */
4146 if (sigsetsize != sizeof(sigset_t))
4147 return -EINVAL;
4148
4149 if (copy_from_user(&newset, unewset, sizeof(newset)))
4150 return -EFAULT;
Al Viro68f3f162012-05-21 21:42:32 -04004151 return sigsuspend(&newset);
David Woodhouse150256d2006-01-18 17:43:57 -08004152}
Al Viroad4b65a2012-12-24 21:43:56 -05004153
4154#ifdef CONFIG_COMPAT
4155COMPAT_SYSCALL_DEFINE2(rt_sigsuspend, compat_sigset_t __user *, unewset, compat_size_t, sigsetsize)
4156{
Al Viroad4b65a2012-12-24 21:43:56 -05004157 sigset_t newset;
Al Viroad4b65a2012-12-24 21:43:56 -05004158
4159 /* XXX: Don't preclude handling different sized sigset_t's. */
4160 if (sigsetsize != sizeof(sigset_t))
4161 return -EINVAL;
4162
Al Viro3968cf62017-09-03 21:45:17 -04004163 if (get_compat_sigset(&newset, unewset))
Al Viroad4b65a2012-12-24 21:43:56 -05004164 return -EFAULT;
Al Viroad4b65a2012-12-24 21:43:56 -05004165 return sigsuspend(&newset);
Al Viroad4b65a2012-12-24 21:43:56 -05004166}
4167#endif
David Woodhouse150256d2006-01-18 17:43:57 -08004168
Al Viro0a0e8cd2012-12-25 16:04:12 -05004169#ifdef CONFIG_OLD_SIGSUSPEND
4170SYSCALL_DEFINE1(sigsuspend, old_sigset_t, mask)
4171{
4172 sigset_t blocked;
4173 siginitset(&blocked, mask);
4174 return sigsuspend(&blocked);
4175}
4176#endif
4177#ifdef CONFIG_OLD_SIGSUSPEND3
4178SYSCALL_DEFINE3(sigsuspend, int, unused1, int, unused2, old_sigset_t, mask)
4179{
4180 sigset_t blocked;
4181 siginitset(&blocked, mask);
4182 return sigsuspend(&blocked);
4183}
4184#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -07004185
Gideon Israel Dsouza52f5684c2014-04-07 15:39:20 -07004186__weak const char *arch_vma_name(struct vm_area_struct *vma)
David Howellsf269fdd2006-09-27 01:50:23 -07004187{
4188 return NULL;
4189}
4190
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02004191static inline void siginfo_buildtime_checks(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -07004192{
Eric W. Biedermanaba1be22017-07-19 21:23:15 -05004193 BUILD_BUG_ON(sizeof(struct siginfo) != SI_MAX_SIZE);
Helge Deller41b27152016-03-22 14:27:54 -07004194
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02004195 /* Verify the offsets in the two siginfos match */
4196#define CHECK_OFFSET(field) \
4197 BUILD_BUG_ON(offsetof(siginfo_t, field) != offsetof(kernel_siginfo_t, field))
4198
4199 /* kill */
4200 CHECK_OFFSET(si_pid);
4201 CHECK_OFFSET(si_uid);
4202
4203 /* timer */
4204 CHECK_OFFSET(si_tid);
4205 CHECK_OFFSET(si_overrun);
4206 CHECK_OFFSET(si_value);
4207
4208 /* rt */
4209 CHECK_OFFSET(si_pid);
4210 CHECK_OFFSET(si_uid);
4211 CHECK_OFFSET(si_value);
4212
4213 /* sigchld */
4214 CHECK_OFFSET(si_pid);
4215 CHECK_OFFSET(si_uid);
4216 CHECK_OFFSET(si_status);
4217 CHECK_OFFSET(si_utime);
4218 CHECK_OFFSET(si_stime);
4219
4220 /* sigfault */
4221 CHECK_OFFSET(si_addr);
4222 CHECK_OFFSET(si_addr_lsb);
4223 CHECK_OFFSET(si_lower);
4224 CHECK_OFFSET(si_upper);
4225 CHECK_OFFSET(si_pkey);
4226
4227 /* sigpoll */
4228 CHECK_OFFSET(si_band);
4229 CHECK_OFFSET(si_fd);
4230
4231 /* sigsys */
4232 CHECK_OFFSET(si_call_addr);
4233 CHECK_OFFSET(si_syscall);
4234 CHECK_OFFSET(si_arch);
4235#undef CHECK_OFFSET
4236}
4237
Linus Torvalds1da177e2005-04-16 15:20:36 -07004238void __init signals_init(void)
4239{
Eric W. Biedermanae7795b2018-09-25 11:27:20 +02004240 siginfo_buildtime_checks();
Jason Wessel67fc4e02010-05-20 21:04:21 -05004241
4242 sigqueue_cachep = KMEM_CACHE(sigqueue, SLAB_PANIC);
4243}
4244
4245#ifdef CONFIG_KGDB_KDB
4246#include <linux/kdb.h>
4247/*
Eric W. Biederman0b44bf92017-08-17 15:45:38 -05004248 * kdb_send_sig - Allows kdb to send signals without exposing
Jason Wessel67fc4e02010-05-20 21:04:21 -05004249 * signal internals. This function checks if the required locks are
4250 * available before calling the main signal code, to avoid kdb
4251 * deadlocks.
4252 */
Eric W. Biederman0b44bf92017-08-17 15:45:38 -05004253void kdb_send_sig(struct task_struct *t, int sig)
Jason Wessel67fc4e02010-05-20 21:04:21 -05004254{
4255 static struct task_struct *kdb_prev_t;
Eric W. Biederman0b44bf92017-08-17 15:45:38 -05004256 int new_t, ret;
Jason Wessel67fc4e02010-05-20 21:04:21 -05004257 if (!spin_trylock(&t->sighand->siglock)) {
4258 kdb_printf("Can't do kill command now.\n"
4259 "The sigmask lock is held somewhere else in "
4260 "kernel, try again later\n");
4261 return;
4262 }
Jason Wessel67fc4e02010-05-20 21:04:21 -05004263 new_t = kdb_prev_t != t;
4264 kdb_prev_t = t;
4265 if (t->state != TASK_RUNNING && new_t) {
Eric W. Biederman0b44bf92017-08-17 15:45:38 -05004266 spin_unlock(&t->sighand->siglock);
Jason Wessel67fc4e02010-05-20 21:04:21 -05004267 kdb_printf("Process is not RUNNING, sending a signal from "
4268 "kdb risks deadlock\n"
4269 "on the run queue locks. "
4270 "The signal has _not_ been sent.\n"
4271 "Reissue the kill command if you want to risk "
4272 "the deadlock.\n");
4273 return;
4274 }
Eric W. Biedermanb2139842018-07-20 15:49:17 -05004275 ret = send_signal(sig, SEND_SIG_PRIV, t, PIDTYPE_PID);
Eric W. Biederman0b44bf92017-08-17 15:45:38 -05004276 spin_unlock(&t->sighand->siglock);
4277 if (ret)
Jason Wessel67fc4e02010-05-20 21:04:21 -05004278 kdb_printf("Fail to deliver Signal %d to process %d.\n",
4279 sig, t->pid);
4280 else
4281 kdb_printf("Signal %d is sent to process %d.\n", sig, t->pid);
4282}
4283#endif /* CONFIG_KGDB_KDB */