[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1313656467.2905.14.camel@epip-laptop>
Date: Thu, 18 Aug 2011 16:34:27 +0800
From: Guan Xuetao <gxt@...c.pku.edu.cn>
To: Matt Fleming <matt@...sole-pimps.org>
Cc: Oleg Nesterov <oleg@...hat.com>, linux-kernel@...r.kernel.org,
arnd@...db.de
Subject: Re: [PATCH 32/41] unicore32: Use set_current_blocked()
It looks good to me.
And already tested by compilation.
Cc: Arnd Bergmann <arnd@...db.de>
Acked-by: Guan Xuetao <gxt@...c.pku.edu.cn>
Thanks & Regards.
Guan Xuetao
On Thu, 2011-08-11 at 14:57 +0100, Matt Fleming wrote:
> From: Matt Fleming <matt.fleming@...el.com>
>
> As described in e6fa16ab ("signal: sigprocmask() should do
> retarget_shared_pending()") the modification of current->blocked is
> incorrect as we need to check whether the signal we're about to block
> is pending in the shared queue.
>
> Cc: Oleg Nesterov <oleg@...hat.com>
> Cc: Guan Xuetao <gxt@...c.pku.edu.cn>
> Signed-off-by: Matt Fleming <matt.fleming@...el.com>
> ---
> arch/unicore32/kernel/signal.c | 15 +++++----------
> 1 files changed, 5 insertions(+), 10 deletions(-)
>
> diff --git a/arch/unicore32/kernel/signal.c b/arch/unicore32/kernel/signal.c
> index b163fca..911b549 100644
> --- a/arch/unicore32/kernel/signal.c
> +++ b/arch/unicore32/kernel/signal.c
> @@ -63,10 +63,7 @@ static int restore_sigframe(struct pt_regs *regs, struct sigframe __user *sf)
> err = __copy_from_user(&set, &sf->uc.uc_sigmask, sizeof(set));
> if (err == 0) {
> sigdelsetmask(&set, ~_BLOCKABLE);
> - spin_lock_irq(¤t->sighand->siglock);
> - current->blocked = set;
> - recalc_sigpending();
> - spin_unlock_irq(¤t->sighand->siglock);
> + set_current_blocked(&set);
> }
>
> err |= __get_user(regs->UCreg_00, &sf->uc.uc_mcontext.regs.UCreg_00);
> @@ -321,6 +318,7 @@ static int handle_signal(unsigned long sig, struct k_sigaction *ka,
> {
> struct thread_info *thread = current_thread_info();
> struct task_struct *tsk = current;
> + sigset_t blocked;
> int usig = sig;
> int ret;
>
> @@ -372,13 +370,10 @@ static int handle_signal(unsigned long sig, struct k_sigaction *ka,
> /*
> * Block the signal if we were successful.
> */
> - spin_lock_irq(&tsk->sighand->siglock);
> - sigorsets(&tsk->blocked, &tsk->blocked,
> - &ka->sa.sa_mask);
> + sigorsets(&blocked, &tsk->blocked, &ka->sa.sa_mask);
> if (!(ka->sa.sa_flags & SA_NODEFER))
> - sigaddset(&tsk->blocked, sig);
> - recalc_sigpending();
> - spin_unlock_irq(&tsk->sighand->siglock);
> + sigaddset(&blocked, sig);
> + set_current_blocked(&blocked);
>
> return 0;
> }
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists