From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751573Ab1JYQUd (ORCPT ); Tue, 25 Oct 2011 12:20:33 -0400 Received: from mx1.redhat.com ([209.132.183.28]:13785 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751103Ab1JYQUb (ORCPT ); Tue, 25 Oct 2011 12:20:31 -0400 Date: Tue, 25 Oct 2011 18:14:26 +0200 From: Oleg Nesterov To: Srikar Dronamraju Cc: Peter Zijlstra , "H. Peter Anvin" , Steven Rostedt , Linus Torvalds , Christoph Hellwig , Ananth N Mavinakayanahalli , Thomas Gleixner , Andi Kleen , Andrew Morton , Jim Keniston , Roland McGrath , Shuah Khan , Ingo Molnar , Alexander van Heukelum , Russell King , LKML Subject: Re: [RESEND] [RFC][PATCH X86_32 1/2]: Call do_notify_resume() with interrupts enabled Message-ID: <20111025161426.GC17067@redhat.com> References: <20111025141812.GA21225@linux.vnet.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20111025141812.GA21225@linux.vnet.ibm.com> User-Agent: Mutt/1.5.18 (2008-05-17) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/25, Srikar Dronamraju wrote: > > do_notify_resume() gets called with interrupts disabled on x86_32. This > is different from the x86_64 behavior, where interrupts are enabled at > the time. And note that do_notify_resume() paths assume that irqs are enabled. key_replace_session_keyring/get_signal_to_deliver start with _lock_irq. IOW, I vote for this change even if I can't ack it (although it looks "obviously correct" to me). In fact refrigerator() looks buggy without this change. Yes, it enables irqs but only "by accident", via unlock_irq(). And we are going to remove this recalc_sigpending() from freezer. > Queries on lkml on this issue hasn't yielded any clear answer. Lets make > x86_32 behave the same as x86_64, unless there is a real reason to > maintain status quo. > > Please refer https://lkml.org/lkml/2011/9/27/130 for more details > > A similar change was suggested in arm > https://lkml.org/lkml/2011/8/25/231 > > My 32-bit machine works fine (tm) with the patch below > > Signed-off-by: Srikar Dronamraju > --- > arch/x86/kernel/entry_32.S | 4 ++++ > 1 files changed, 4 insertions(+) > > diff --git a/arch/x86/kernel/entry_32.S b/arch/x86/kernel/entry_32.S > index f3f6f53..22d0e21 100644 > --- a/arch/x86/kernel/entry_32.S > +++ b/arch/x86/kernel/entry_32.S > @@ -625,6 +625,8 @@ work_notifysig: # deal with pending signals and > movl %esp, %eax > jne work_notifysig_v86 # returning to kernel-space or > # vm86-space > + TRACE_IRQS_ON > + ENABLE_INTERRUPTS(CLBR_NONE) > xorl %edx, %edx > call do_notify_resume > jmp resume_userspace_sig > @@ -638,6 +640,8 @@ work_notifysig: # deal with pending signals and > #else > movl %esp, %eax > #endif > + TRACE_IRQS_ON > + ENABLE_INTERRUPTS(CLBR_NONE) > xorl %edx, %edx > call do_notify_resume > jmp resume_userspace_sig >