Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754462AbaBUKdq (ORCPT ); Fri, 21 Feb 2014 05:33:46 -0500 Received: from www.linutronix.de ([62.245.132.108]:37575 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754382AbaBUKdo (ORCPT ); Fri, 21 Feb 2014 05:33:44 -0500 Date: Fri, 21 Feb 2014 11:33:52 +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: <27240C0AC20F114CBF8149A2696CBE4A01C27CF7@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> 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: > 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. 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/