Re: [PATCH 32/41] unicore32: Use set_current_blocked()

From: Guan Xuetao
Date: Thu Aug 18 2011 - 04:33:52 EST


It looks good to me.

And already tested by compilation.

Cc: Arnd Bergmann <arnd@xxxxxxxx>

Acked-by: Guan Xuetao <gxt@xxxxxxxxxxxxxxx>

Thanks & Regards.

Guan Xuetao


On Thu, 2011-08-11 at 14:57 +0100, Matt Fleming wrote:
> From: Matt Fleming <matt.fleming@xxxxxxxxx>
>
> 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@xxxxxxxxxx>
> Cc: Guan Xuetao <gxt@xxxxxxxxxxxxxxx>
> Signed-off-by: Matt Fleming <matt.fleming@xxxxxxxxx>
> ---
> 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(&current->sighand->siglock);
> - current->blocked = set;
> - recalc_sigpending();
> - spin_unlock_irq(&current->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@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/