Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755129AbaBULK2 (ORCPT ); Fri, 21 Feb 2014 06:10:28 -0500 Received: from www.linutronix.de ([62.245.132.108]:37813 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755016AbaBULK1 (ORCPT ); Fri, 21 Feb 2014 06:10:27 -0500 Date: Fri, 21 Feb 2014 12:10:35 +0100 (CET) From: Thomas Gleixner To: "Liu, Chuansheng" cc: "linux-kernel@vger.kernel.org" , "Wang, Xiaoming" Subject: RE: [PATCH 1/2] genirq: Fix the possible synchronize_irq() wait-forever In-Reply-To: <27240C0AC20F114CBF8149A2696CBE4A01C287C7@SHSMSX101.ccr.corp.intel.com> Message-ID: References: <1392020037-5484-1-git-send-email-chuansheng.liu@intel.com> <27240C0AC20F114CBF8149A2696CBE4A01C269E8@SHSMSX101.ccr.corp.intel.com> <27240C0AC20F114CBF8149A2696CBE4A01C27CF7@SHSMSX101.ccr.corp.intel.com> <27240C0AC20F114CBF8149A2696CBE4A01C287C7@SHSMSX101.ccr.corp.intel.com> User-Agent: Alpine 2.02 (DEB 1266 2009-07-14) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII X-Linutronix-Spam-Score: -1.0 X-Linutronix-Spam-Level: - X-Linutronix-Spam-Status: No , -1.0 points, 5.0 required, ALL_TRUSTED=-1,SHORTCIRCUIT=-0.0001 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 21 Feb 2014, Liu, Chuansheng wrote: > Hello Thomas, > > > -----Original Message----- > > From: Thomas Gleixner [mailto:tglx@linutronix.de] > > Sent: Friday, February 21, 2014 6:34 PM > > To: Liu, Chuansheng > > Cc: linux-kernel@vger.kernel.org; Wang, Xiaoming > > Subject: RE: [PATCH 1/2] genirq: Fix the possible synchronize_irq() wait-forever > > > > On Fri, 21 Feb 2014, Liu, Chuansheng wrote: > > > But feels there is another case which the synchronize_irq waited there > > forever, > > > it is no waking up action from irq_thread(). > > > > > > CPU0 CPU1 > > > disable_irq() irq_thread() > > > synchronize_irq() > > > wait_event() > > > adding the __wait into the queue wake_threads_waitq > > > test threads_active==0 > > > atomic_dec_and_test(threads_active) 1 -- > 0 > > > > > waitqueue_active(&desc->wait_for_threads) > > > <== Here without smp_mb(), CPU1 > > maybe detect > > > the queue is still empty?? > > > schedule() > > > > > > It will cause although the threads_active is 0, but irq_thread() didn't do the > > waking up action. > > > Is it reasonable? Then maybe we can add one smp_mb() before > > waitqueue_active. > > > > I think you have a point there, but not on x86 wherre the atomic_dec > > and the spinlock on the queueing side are full barriers. For non-x86 > > there is definitely a potential issue. > > > But even on X86, spin_unlock has no full barrier, the following scenario: > CPU0 CPU1 > spin_lock > atomic_dec_and_test > insert into queue > spin_unlock > checking waitqueue_active But CPU0 sees the 0, right? Thanks, tglx -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/