From: Greg Ungerer <gerg@snapgear.com>
To: Matt Fleming <matt@console-pimps.org>
Cc: Oleg Nesterov <oleg@redhat.com>, <linux-kernel@vger.kernel.org>,
Geert Uytterhoeven <geert@linux-m68k.org>,
Greg Ungerer <gerg@uclinux.org>
Subject: Re: [PATCH v2 13/43] m68k: Use set_current_blocked() and block_sigmask()
Date: Wed, 24 Aug 2011 14:38:37 +1000 [thread overview]
Message-ID: <4E54804D.80005@snapgear.com> (raw)
In-Reply-To: <1313772419-21951-14-git-send-email-matt@console-pimps.org>
Hi Matt,
On 20/08/11 02:46, Matt Fleming wrote:
> From: Matt Fleming<matt.fleming@intel.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.
>
> Also, use the new helper function block_sigmask() which centralises
> the code for updating current->blocked after successfully delivering a
> signal and reduces the amount of duplicate code across
> architectures. In the past some architectures got this code wrong, so
> using this helper function should stop that from happening again.
>
> Cc: Oleg Nesterov<oleg@redhat.com>
> Cc: Geert Uytterhoeven<geert@linux-m68k.org>
> Cc: Greg Ungerer<gerg@uclinux.org>
> Signed-off-by: Matt Fleming<matt.fleming@intel.com>
I don't see any problems. Fine by me.
Acked-by: Greg Ungerer <gerg@uclinux.org>
Regards
Greg
> ---
>
> v2 of this patch depends on "[PATCH 01/43] signal: Add block_sigmask()
> for adding sigmask to current->blocked" so they need to go through the
> same tree but this patch would benefit from some maintainer ACK's.
>
> arch/m68k/kernel/signal_mm.c | 22 +++++++++-------------
> arch/m68k/kernel/signal_no.c | 28 +++++++++-------------------
> 2 files changed, 18 insertions(+), 32 deletions(-)
>
> diff --git a/arch/m68k/kernel/signal_mm.c b/arch/m68k/kernel/signal_mm.c
> index a0afc23..74ba0cf 100644
> --- a/arch/m68k/kernel/signal_mm.c
> +++ b/arch/m68k/kernel/signal_mm.c
> @@ -97,12 +97,13 @@ int handle_kernel_fault(struct pt_regs *regs)
> asmlinkage int
> sys_sigsuspend(int unused0, int unused1, old_sigset_t mask)
> {
> - mask&= _BLOCKABLE;
> - spin_lock_irq(¤t->sighand->siglock);
> + sigset_t blocked;
> +
> current->saved_sigmask = current->blocked;
> - siginitset(¤t->blocked, mask);
> - recalc_sigpending();
> - spin_unlock_irq(¤t->sighand->siglock);
> +
> + mask&= _BLOCKABLE;
> + siginitset(&blocked, mask);
> + set_current_blocked(&blocked);
>
> current->state = TASK_INTERRUPTIBLE;
> schedule();
> @@ -465,8 +466,7 @@ asmlinkage int do_sigreturn(unsigned long __unused)
> goto badframe;
>
> sigdelsetmask(&set, ~_BLOCKABLE);
> - current->blocked = set;
> - recalc_sigpending();
> + set_current_blocked(&set);
>
> if (restore_sigcontext(regs,&frame->sc, frame + 1))
> goto badframe;
> @@ -491,8 +491,7 @@ asmlinkage int do_rt_sigreturn(unsigned long __unused)
> goto badframe;
>
> sigdelsetmask(&set, ~_BLOCKABLE);
> - current->blocked = set;
> - recalc_sigpending();
> + set_current_blocked(&set);
>
> if (rt_restore_ucontext(regs, sw,&frame->uc))
> goto badframe;
> @@ -965,10 +964,7 @@ handle_signal(int sig, struct k_sigaction *ka, siginfo_t *info,
> if (err)
> return;
>
> - sigorsets(¤t->blocked,¤t->blocked,&ka->sa.sa_mask);
> - if (!(ka->sa.sa_flags& SA_NODEFER))
> - sigaddset(¤t->blocked,sig);
> - recalc_sigpending();
> + block_sigmask(ka, sig);
>
> if (test_thread_flag(TIF_DELAYED_TRACE)) {
> regs->sr&= ~0x8000;
> diff --git a/arch/m68k/kernel/signal_no.c b/arch/m68k/kernel/signal_no.c
> index 36a81bb..33e8bf5 100644
> --- a/arch/m68k/kernel/signal_no.c
> +++ b/arch/m68k/kernel/signal_no.c
> @@ -60,12 +60,13 @@ void ret_from_user_rt_signal(void);
> asmlinkage int
> sys_sigsuspend(int unused0, int unused1, old_sigset_t mask)
> {
> - mask&= _BLOCKABLE;
> - spin_lock_irq(¤t->sighand->siglock);
> + sigset_t blocked;
> +
> current->saved_sigmask = current->blocked;
> - siginitset(¤t->blocked, mask);
> - recalc_sigpending();
> - spin_unlock_irq(¤t->sighand->siglock);
> +
> + mask&= _BLOCKABLE;
> + siginitset(&blocked, mask);
> + set_current_blocked(&blocked);
>
> current->state = TASK_INTERRUPTIBLE;
> schedule();
> @@ -343,10 +344,7 @@ asmlinkage int do_sigreturn(unsigned long __unused)
> goto badframe;
>
> sigdelsetmask(&set, ~_BLOCKABLE);
> - spin_lock_irq(¤t->sighand->siglock);
> - current->blocked = set;
> - recalc_sigpending();
> - spin_unlock_irq(¤t->sighand->siglock);
> + set_current_blocked(&set);
>
> if (restore_sigcontext(regs,&frame->sc, frame + 1,&d0))
> goto badframe;
> @@ -372,10 +370,7 @@ asmlinkage int do_rt_sigreturn(unsigned long __unused)
> goto badframe;
>
> sigdelsetmask(&set, ~_BLOCKABLE);
> - spin_lock_irq(¤t->sighand->siglock);
> - current->blocked = set;
> - recalc_sigpending();
> - spin_unlock_irq(¤t->sighand->siglock);
> + set_current_blocked(&set);
>
> if (rt_restore_ucontext(regs, sw,&frame->uc,&d0))
> goto badframe;
> @@ -708,12 +703,7 @@ handle_signal(int sig, struct k_sigaction *ka, siginfo_t *info,
> if (err)
> return;
>
> - spin_lock_irq(¤t->sighand->siglock);
> - sigorsets(¤t->blocked,¤t->blocked,&ka->sa.sa_mask);
> - if (!(ka->sa.sa_flags& SA_NODEFER))
> - sigaddset(¤t->blocked,sig);
> - recalc_sigpending();
> - spin_unlock_irq(¤t->sighand->siglock);
> + block_sigmask(ka, sig);
>
> clear_thread_flag(TIF_RESTORE_SIGMASK);
> }
--
------------------------------------------------------------------------
Greg Ungerer -- Principal Engineer EMAIL: gerg@snapgear.com
SnapGear Group, McAfee PHONE: +61 7 3435 2888
8 Gardner Close FAX: +61 7 3217 5323
Milton, QLD, 4064, Australia WEB: http://www.SnapGear.com
next prev parent reply other threads:[~2011-08-24 4:38 UTC|newest]
Thread overview: 71+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-08-19 16:46 [PATCH v2 00/43] signal: set_current_blocked() and block_sigmask() Matt Fleming
2011-08-19 16:46 ` [PATCH 01/43] signal: Add block_sigmask() for adding sigmask to current->blocked Matt Fleming
2011-08-22 10:19 ` Matt Fleming
2011-08-22 14:01 ` Oleg Nesterov
2011-08-22 14:04 ` Oleg Nesterov
2011-08-22 15:56 ` Matt Fleming
2011-08-19 16:46 ` [PATCH v2 02/43] alpha: Use set_current_blocked() and block_sigmask() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 03/43] arm: " Matt Fleming
2011-08-25 17:15 ` Will Deacon
2011-08-26 10:06 ` Matt Fleming
2011-08-26 14:18 ` Oleg Nesterov
2011-08-19 16:46 ` [PATCH v2 04/43] avr32: Don't mask signals in the error path Matt Fleming
2011-08-19 16:46 ` [PATCH v2 05/43] avr32: use set_current_blocked() in handle_signal/sys_rt_sigreturn Matt Fleming
2011-08-19 16:46 ` [PATCH v2 06/43] avr32: Use block_sigmask() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 07/43] blackfin: Use set_current_blocked() and block_sigmask() Matt Fleming
2011-08-20 4:00 ` Mike Frysinger
2011-08-20 8:36 ` Matt Fleming
2011-08-20 17:31 ` Mike Frysinger
2011-08-19 16:46 ` [PATCH v2 08/43] cris: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 09/43] frv: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 10/43] h8300: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 11/43] ia64: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 12/43] m32r: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 13/43] m68k: " Matt Fleming
2011-08-24 4:38 ` Greg Ungerer [this message]
2011-08-19 16:46 ` [PATCH v2 14/43] microblaze: Don't reimplement force_sigsegv() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 15/43] microblaze: No need to reset handler if SA_ONESHOT Matt Fleming
2011-08-19 16:46 ` [PATCH v2 16/43] microblaze: Fix signal masking Matt Fleming
2011-08-19 16:46 ` [PATCH v2 17/43] microblaze: Use set_current_blocked() and block_sigmask() Matt Fleming
2011-08-24 8:49 ` Michal Simek
2011-08-24 10:21 ` Matt Fleming
2011-08-24 13:53 ` Oleg Nesterov
2011-08-24 14:02 ` Michal Simek
2011-08-19 16:46 ` [PATCH v2 18/43] MIPS: " Matt Fleming
2011-08-19 17:27 ` Ralf Baechle
2011-08-19 16:46 ` [PATCH v2 19/43] mn10300: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 20/43] OpenRISC: Don't reimplement force_sigsegv() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 21/43] OpenRISC: No need to reset handler if SA_ONESHOT Matt Fleming
2011-08-19 16:46 ` [PATCH v2 22/43] OpenRISC: Don't mask signals if we fail to setup signal stack Matt Fleming
2011-08-19 16:46 ` [PATCH v2 23/43] OpenRISC: Use set_current_blocked() and block_sigmask() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 24/43] parisc: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 25/43] powerpc: " Matt Fleming
2011-08-19 16:46 ` [PATCH 26/43] [S390]: Use block_sigmask() Matt Fleming
2011-08-23 6:04 ` Martin Schwidefsky
2011-08-19 16:46 ` [PATCH v2 27/43] score: Don't mask signals if we fail to setup signal stack Matt Fleming
2011-08-19 16:46 ` [PATCH v2 28/43] score: Use set_current_blocked() and block_sigmask() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 29/43] sh: No need to reset handler if SA_ONESHOT Matt Fleming
2011-08-19 16:46 ` [PATCH v2 30/43] sh: Use set_current_blocked() and block_sigmask() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 31/43] sparc: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 32/43] tile: " Matt Fleming
2011-08-29 20:44 ` Chris Metcalf
2011-08-19 16:46 ` [PATCH v2 33/43] um: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 34/43] um: Don't restore current->blocked on error Matt Fleming
2011-08-19 16:46 ` [PATCH v2 35/43] unicore32: Use set_current_blocked() and block_sigmask() Matt Fleming
2011-08-22 2:15 ` Guan Xuetao
2011-08-22 10:26 ` Matt Fleming
2011-08-24 2:03 ` Guan Xuetao
2011-08-19 16:46 ` [PATCH v2 36/43] xtensa: Don't reimplement force_sigsegv() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 37/43] xtensa: No need to reset handler if SA_ONESHOT Matt Fleming
2011-08-19 16:46 ` [PATCH v2 38/43] xtensa: Don't mask signals if we fail to setup signal stack Matt Fleming
2011-08-19 16:46 ` [PATCH v2 39/43] xtensa: Use set_current_blocked() and block_sigmask() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 40/43] autofs4: Use set_current_blocked() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 41/43] coda: " Matt Fleming
2011-08-19 16:46 ` [PATCH v2 42/43] dlm: Remove another superfluous call to recalc_sigpending() Matt Fleming
2011-08-19 16:46 ` [PATCH v2 43/43] ncpfs: Use set_current_blocked() Matt Fleming
2011-08-24 17:36 ` Oleg Nesterov
2011-08-24 17:52 ` Oleg Nesterov
2011-08-24 19:08 ` Matt Fleming
2011-08-24 18:24 ` [PATCH v2 00/43] signal: set_current_blocked() and block_sigmask() Oleg Nesterov
2011-08-25 4:30 ` Ian Kent
2011-08-25 15:31 ` Oleg Nesterov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4E54804D.80005@snapgear.com \
--to=gerg@snapgear.com \
--cc=geert@linux-m68k.org \
--cc=gerg@uclinux.org \
--cc=linux-kernel@vger.kernel.org \
--cc=matt@console-pimps.org \
--cc=oleg@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox