Commit 40b3b025 authored by Eric W. Biederman's avatar Eric W. Biederman

signal: Pass pid type into do_send_sig_info

This passes the information we already have at the call sight into
do_send_sig_info.  Ultimately allowing for better handling of signals
sent to a group of processes during fork.
Signed-off-by: default avatar"Eric W. Biederman" <ebiederm@xmission.com>
parent 9c2db007
...@@ -348,7 +348,7 @@ static void send_sig_all(int sig) ...@@ -348,7 +348,7 @@ static void send_sig_all(int sig)
if (is_global_init(p)) if (is_global_init(p))
continue; continue;
do_send_sig_info(sig, SEND_SIG_FORCED, p, true); do_send_sig_info(sig, SEND_SIG_FORCED, p, PIDTYPE_MAX);
} }
read_unlock(&tasklist_lock); read_unlock(&tasklist_lock);
} }
......
...@@ -767,11 +767,11 @@ static void send_sigio_to_task(struct task_struct *p, ...@@ -767,11 +767,11 @@ static void send_sigio_to_task(struct task_struct *p,
else else
si.si_band = mangle_poll(band_table[reason - POLL_IN]); si.si_band = mangle_poll(band_table[reason - POLL_IN]);
si.si_fd = fd; si.si_fd = fd;
if (!do_send_sig_info(signum, &si, p, type != PIDTYPE_PID)) if (!do_send_sig_info(signum, &si, p, type))
break; break;
/* fall-through: fall back on the old plain SIGIO signal */ /* fall-through: fall back on the old plain SIGIO signal */
case 0: case 0:
do_send_sig_info(SIGIO, SEND_SIG_PRIV, p, type != PIDTYPE_PID); do_send_sig_info(SIGIO, SEND_SIG_PRIV, p, type);
} }
} }
...@@ -808,7 +808,7 @@ static void send_sigurg_to_task(struct task_struct *p, ...@@ -808,7 +808,7 @@ static void send_sigurg_to_task(struct task_struct *p,
struct fown_struct *fown, enum pid_type type) struct fown_struct *fown, enum pid_type type)
{ {
if (sigio_perm(p, fown, SIGURG)) if (sigio_perm(p, fown, SIGURG))
do_send_sig_info(SIGURG, SEND_SIG_PRIV, p, type != PIDTYPE_PID); do_send_sig_info(SIGURG, SEND_SIG_PRIV, p, type);
} }
int send_sigurg(struct fown_struct *fown) int send_sigurg(struct fown_struct *fown)
......
...@@ -258,7 +258,7 @@ enum pid_type; ...@@ -258,7 +258,7 @@ enum pid_type;
extern int next_signal(struct sigpending *pending, sigset_t *mask); extern int next_signal(struct sigpending *pending, sigset_t *mask);
extern int do_send_sig_info(int sig, struct siginfo *info, extern int do_send_sig_info(int sig, struct siginfo *info,
struct task_struct *p, bool group); struct task_struct *p, enum pid_type type);
extern int group_send_sig_info(int sig, struct siginfo *info, extern int group_send_sig_info(int sig, struct siginfo *info,
struct task_struct *p, enum pid_type type); struct task_struct *p, enum pid_type type);
extern int __group_send_sig_info(int, struct siginfo *, struct task_struct *); extern int __group_send_sig_info(int, struct siginfo *, struct task_struct *);
......
...@@ -1161,13 +1161,13 @@ specific_send_sig_info(int sig, struct siginfo *info, struct task_struct *t) ...@@ -1161,13 +1161,13 @@ specific_send_sig_info(int sig, struct siginfo *info, struct task_struct *t)
} }
int do_send_sig_info(int sig, struct siginfo *info, struct task_struct *p, int do_send_sig_info(int sig, struct siginfo *info, struct task_struct *p,
bool group) enum pid_type type)
{ {
unsigned long flags; unsigned long flags;
int ret = -ESRCH; int ret = -ESRCH;
if (lock_task_sighand(p, &flags)) { if (lock_task_sighand(p, &flags)) {
ret = send_signal(sig, info, p, group); ret = send_signal(sig, info, p, type != PIDTYPE_PID);
unlock_task_sighand(p, &flags); unlock_task_sighand(p, &flags);
} }
...@@ -1284,7 +1284,7 @@ int group_send_sig_info(int sig, struct siginfo *info, struct task_struct *p, ...@@ -1284,7 +1284,7 @@ int group_send_sig_info(int sig, struct siginfo *info, struct task_struct *p,
rcu_read_unlock(); rcu_read_unlock();
if (!ret && sig) if (!ret && sig)
ret = do_send_sig_info(sig, info, p, true); ret = do_send_sig_info(sig, info, p, type);
return ret; return ret;
} }
...@@ -1448,7 +1448,7 @@ int send_sig_info(int sig, struct siginfo *info, struct task_struct *p) ...@@ -1448,7 +1448,7 @@ int send_sig_info(int sig, struct siginfo *info, struct task_struct *p)
if (!valid_signal(sig)) if (!valid_signal(sig))
return -EINVAL; return -EINVAL;
return do_send_sig_info(sig, info, p, false); return do_send_sig_info(sig, info, p, PIDTYPE_PID);
} }
#define __si_special(priv) \ #define __si_special(priv) \
...@@ -3199,7 +3199,7 @@ do_send_specific(pid_t tgid, pid_t pid, int sig, struct siginfo *info) ...@@ -3199,7 +3199,7 @@ do_send_specific(pid_t tgid, pid_t pid, int sig, struct siginfo *info)
* probe. No signal is actually delivered. * probe. No signal is actually delivered.
*/ */
if (!error && sig) { if (!error && sig) {
error = do_send_sig_info(sig, info, p, false); error = do_send_sig_info(sig, info, p, PIDTYPE_PID);
/* /*
* If lock_task_sighand() failed we pretend the task * If lock_task_sighand() failed we pretend the task
* dies after receiving the signal. The window is tiny, * dies after receiving the signal. The window is tiny,
......
...@@ -920,7 +920,7 @@ static void oom_kill_process(struct oom_control *oc, const char *message) ...@@ -920,7 +920,7 @@ static void oom_kill_process(struct oom_control *oc, const char *message)
* in order to prevent the OOM victim from depleting the memory * in order to prevent the OOM victim from depleting the memory
* reserves from the user space under its control. * reserves from the user space under its control.
*/ */
do_send_sig_info(SIGKILL, SEND_SIG_FORCED, victim, true); do_send_sig_info(SIGKILL, SEND_SIG_FORCED, victim, PIDTYPE_TGID);
mark_oom_victim(victim); mark_oom_victim(victim);
pr_err("Killed process %d (%s) total-vm:%lukB, anon-rss:%lukB, file-rss:%lukB, shmem-rss:%lukB\n", pr_err("Killed process %d (%s) total-vm:%lukB, anon-rss:%lukB, file-rss:%lukB, shmem-rss:%lukB\n",
task_pid_nr(victim), victim->comm, K(victim->mm->total_vm), task_pid_nr(victim), victim->comm, K(victim->mm->total_vm),
...@@ -958,7 +958,7 @@ static void oom_kill_process(struct oom_control *oc, const char *message) ...@@ -958,7 +958,7 @@ static void oom_kill_process(struct oom_control *oc, const char *message)
*/ */
if (unlikely(p->flags & PF_KTHREAD)) if (unlikely(p->flags & PF_KTHREAD))
continue; continue;
do_send_sig_info(SIGKILL, SEND_SIG_FORCED, p, true); do_send_sig_info(SIGKILL, SEND_SIG_FORCED, p, PIDTYPE_TGID);
} }
rcu_read_unlock(); rcu_read_unlock();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment