Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp474047imm; Fri, 13 Jul 2018 00:22:49 -0700 (PDT) X-Google-Smtp-Source: AAOMgpda0Lhrzd/OCixNOvzEaJF9Hs5bKaoB8pjSxwkLOQ51cOZmM+FDDz28YnM9/TDCJnnh/1+L X-Received: by 2002:a17:902:b58f:: with SMTP id a15-v6mr5287269pls.76.1531466569043; Fri, 13 Jul 2018 00:22:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531466569; cv=none; d=google.com; s=arc-20160816; b=Vx6IpHGRSVP6Cfrw7FqShm/qwGVsBgcctpSXSVjdk91zAqdOllhkIfTbj32WnhLM5S QOF3+rrbP1d/5tWsB39ACx0mlkFjwErKJOJf8THErsLYdS+Apx/fs56Q+k7K/5INZhJT t8wVG8HW75b3vkbcyElCrdNiW1mgWJsLHnbuIxaya7yIc9mw2PnikTL0inQC88QwiydK W1oBPd4WycfOwIDa8pKRbWG82SatbNqxTENhaM1sr1gVLFWLVfvS/qRZPXCrh1iNiz07 YcesVy4Ae++b58OMETb8tOxY/+ryzfaOPrXqyZu1DT8L4WsRxyKfm+J/uK+rV59ccDZL c2YQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=KgThf9C7TEzhQBKRD91Y8+wHbYd08vd2Ri4jzM+w1as=; b=BMY4lBpX/Lk4FXOY6EpbnwU9yu3nRMsdpE3Ha7efW2cOkFFCIPS4a67xGdGHmpHyk/ 2MLcfcRIsGtDrY2MuzeiZZifJ8FCLxlz7+DcL9ezLE6xd1x76lt54PL6sOCQLTYj+HTU 9YzzaXCHC7uo6Gsm8T51dicFkaPgGlVVK05nX0YFp3xff0NuuvnCWuu+b40tPM0ncftH DwHhOU4Tna5bZNVdZR1Usa7XEPoJOCCEVv3qcjHCmpGOVk9mP+noSteQr3whA826pyxp O0oIOWIHs87P3FOXQAzdnCqxsRmXtczCrL9DpisX9ChNSrkQEZ3Ir2dwWW5+2Rh5GzJz Ss2A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j8-v6si19916444pgi.575.2018.07.13.00.22.33; Fri, 13 Jul 2018 00:22:49 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729768AbeGMHec (ORCPT + 99 others); Fri, 13 Jul 2018 03:34:32 -0400 Received: from bmailout2.hostsharing.net ([83.223.90.240]:48713 "EHLO bmailout2.hostsharing.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728289AbeGMHeb (ORCPT ); Fri, 13 Jul 2018 03:34:31 -0400 Received: from h08.hostsharing.net (h08.hostsharing.net [83.223.95.28]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client CN "*.hostsharing.net", Issuer "COMODO RSA Domain Validation Secure Server CA" (not verified)) by bmailout2.hostsharing.net (Postfix) with ESMTPS id E66F128004EB5; Fri, 13 Jul 2018 09:21:09 +0200 (CEST) Received: by h08.hostsharing.net (Postfix, from userid 100393) id 9951A4A26; Fri, 13 Jul 2018 09:21:09 +0200 (CEST) Date: Fri, 13 Jul 2018 09:21:09 +0200 From: Lukas Wunner To: Bjorn Helgaas Cc: Thomas Gleixner , Mika Westerberg , "Rafael J. Wysocki" , Ashok Raj , Keith Busch , Yinghai Lu , Sinan Kaya , linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 08/32] genirq: Synchronize only with single thread on free_irq() Message-ID: <20180713072109.GA23955@wunner.de> References: <83cfe0c826f1d793e2ead9032ef2109b5efa403a.1529173804.git.lukas@wunner.de> <20180712222109.GE28466@bhelgaas-glaptop.roam.corp.google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180712222109.GE28466@bhelgaas-glaptop.roam.corp.google.com> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jul 12, 2018 at 05:21:09PM -0500, Bjorn Helgaas wrote: > On Sat, Jun 16, 2018 at 09:25:00PM +0200, Lukas Wunner wrote: > > When pciehp is converted to threaded IRQ handling, removal of unplugged > > devices below a PCIe hotplug port happens synchronously in the IRQ > > thread. Removal of devices typically entails a call to free_irq() by > > their drivers. > > > > If those devices share their IRQ with the hotplug port, free_irq() > > deadlocks because it calls synchronize_irq() to wait for all hard IRQ > > handlers as well as all threads sharing the IRQ to finish. > > > > Actually it's sufficient to wait only for the IRQ thread of the removed > > device, so call synchronize_hardirq() to wait for all hard IRQ handlers > > to finish, but no longer for any threads. Compensate by rearranging the > > control flow in irq_wait_for_interrupt() such that the device's thread > > is allowed to run one last time after kthread_stop() has been called. > > I assume this would need to be merged along with the rest of the > series, which should probably go through the PCI tree, but I'm > definitely not qualified to review this IRQ patch. And it would need > an ack from Thomas in any case. A v2 of this patch has already been merged through the tip tree on June 24, it's in linux-next as commit 519cc8652b3a, and ISTR that I marked this patch either as "Obsoleted" or "Not Applicable" in pci-patchwork. There was no build-dependency of the succeeding patches in the series on this patch, hence merging through a different tree was possible. Thanks! Lukas