From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.7 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, SIGNED_OFF_BY,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id D6EF1C04EB8 for ; Tue, 4 Dec 2018 21:42:51 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id A0E6120672 for ; Tue, 4 Dec 2018 21:42:51 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="NNa/kRrp" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org A0E6120672 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=rjwysocki.net Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:Cc:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Message-ID:Date:Subject:To:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=ti990uHpFbnJgkIWGvdOOLimWQBrpxLOu2RW0S7qIWg=; b=NNa/kRrpI4oECr bUUlO06xzwp34PwKBxK7zvAD6kUta03pCVs6mFgqC4M11FojrZIsm8FcZx9tB5/NQ5gKGEOu2yWp6 rS53nNgrdauXIoPb9JY5VsMiOVH2E59tzCki77sSuPLq10Ud6cfeybDN4SEZ7OCahwVAjIMlPT3Dw EMCFm6d/jxzCr3NO+mX9+zu0s22B+GvsKfePKpzQ/bwA1s3kDxNaH4or3T9r1M8N7tQBiDVC5mWJa hUwzrQirMp0Ezip0aYItmcFobmYFvYK/BFwyS0J34H8gY2hCfBqGu+8byFhx0iy9seGOpA2qYn6DS Cb7pBHncW/DWQehJNzuw==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.90_1 #2 (Red Hat Linux)) id 1gUISv-0006SY-Sd; Tue, 04 Dec 2018 21:42:49 +0000 Received: from cloudserver094114.home.pl ([79.96.170.134]) by bombadil.infradead.org with esmtps (Exim 4.90_1 #2 (Red Hat Linux)) id 1gUISr-0006RW-GF for linux-arm-kernel@lists.infradead.org; Tue, 04 Dec 2018 21:42:47 +0000 Received: from 79.184.252.87.ipv4.supernova.orange.pl (79.184.252.87) (HELO aspire.rjw.lan) by serwer1319399.home.pl (79.96.170.134) with SMTP (IdeaSmtpServer 0.83.157) id 7428ed0fb50c2c93; Tue, 4 Dec 2018 22:42:30 +0100 From: "Rafael J. Wysocki" To: Lorenzo Pieralisi Subject: Re: [PATCH 05/12] PCI: aardvark: add suspend to RAM support Date: Tue, 04 Dec 2018 22:42:19 +0100 Message-ID: <1966692.fVZYlVgWHv@aspire.rjw.lan> In-Reply-To: <20181204094558.GA24588@e107981-ln.cambridge.arm.com> References: <20181123141831.8214-1-miquel.raynal@bootlin.com> <1999610.6DN9RK2Tt3@aspire.rjw.lan> <20181204094558.GA24588@e107981-ln.cambridge.arm.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20181204_134245_701219_47AB5D54 X-CRM114-Status: GOOD ( 26.87 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Mark Rutland , Andrew Lunn , Jason Cooper , devicetree@vger.kernel.org, Antoine Tenart , linux-pci@vger.kernel.org, Gregory Clement , Miquel Raynal , linux-kernel@vger.kernel.org, Maxime Chevallier , Nadav Haklai , Rob Herring , Thomas Petazzoni , sudeep.holla@arm.com, Bjorn Helgaas , linux-arm-kernel@lists.infradead.org, Sebastian Hesselbarth Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org On Tuesday, December 4, 2018 10:45:58 AM CET Lorenzo Pieralisi wrote: > On Mon, Dec 03, 2018 at 11:00:20PM +0100, Rafael J. Wysocki wrote: > > On Monday, December 3, 2018 4:38:46 PM CET Miquel Raynal wrote: > > > Hi Lorenzo, > > > > > > Lorenzo Pieralisi wrote on Mon, 3 Dec 2018 > > > 10:27:08 +0000: > > > > > > > [+Rafael, Sudeep] > > > > > > > > On Fri, Nov 23, 2018 at 03:18:24PM +0100, Miquel Raynal wrote: > > > > > Add suspend and resume callbacks. The priority of these are > > > > > "_noirq()", to workaround early access to the registers done by the > > > > > PCI core through the ->read()/->write() callbacks at resume time. > > > > > > > > > > Signed-off-by: Miquel Raynal > > > > > --- > > > > > drivers/pci/controller/pci-aardvark.c | 52 +++++++++++++++++++++++++++ > > > > > 1 file changed, 52 insertions(+) > > > > > > > > > > diff --git a/drivers/pci/controller/pci-aardvark.c b/drivers/pci/controller/pci-aardvark.c > > > > > index 108b3f15c410..7ecf1ac4036b 100644 > > > > > --- a/drivers/pci/controller/pci-aardvark.c > > > > > +++ b/drivers/pci/controller/pci-aardvark.c > > > > > @@ -1108,6 +1108,55 @@ static int advk_pcie_setup_clk(struct advk_pcie *pci > > > > > return ret; > > > > > } > > > > > > > > > > +static int __maybe_unused advk_pcie_suspend(struct device *dev) > > > > > +{ > > > > > + struct advk_pcie *pcie = dev_get_drvdata(dev); > > > > > + > > > > > + advk_pcie_disable_phy(pcie); > > > > > + > > > > > + clk_disable_unprepare(pcie->clk); > > > > > > > > I have noticed it is common practice, still, I would like to check whether > > > > it is allowed to call functions that may sleep in a NOIRQ suspend/resume > > > > callback ? > > > > > > You are right this is weird. I double checked and for instance, > > > pcie-mediatek.c, pci-tegra.c and pci-imx6.c do the exact same thing. There are > > > probably other cases where drivers call functions that may sleep from a NOIRQ > > > context. I am interested to know if this is valid and if not, what is the > > > alternative? > > > > > > > Yes, it is valid. _noirq means that the high-level action handlers > > will not be invoked for interrupts occurring during that period, but > > that doesn't apply to timer interrupts. > > > > IOW, don't expect *your* IRQ handler to be invoked then (if this is > > not a timer IRQ), but you can sleep. > > Hi Rafael, all, > > I did not ask my question (that may be silly) properly apologies. I know > that the S2R context allows sleeping the question is, in case > clk_disable_unprepare() (and resume counterparts) sleeps, If it just sleeps, then this is not a problem, but if it actually *waits* for something meaningful to happen (which I guess is what you really mean), then things may go awry. > what is going to wake it up, given that we are in the S2R NOIRQ phase and as > you said the action handlers (that are possibly required to wake up the eg > clk_disable_unprepare() caller) are disabled (unless, AFAIK, > IRQF_NO_SUSPEND is passed at IRQ request time in the respective driver). So if it waits for an action handler to do something and wake it up, it may very well deadlock. I have no idea if that really happens, though. > The clk API implementations back-ends are beyond my depth, I just wanted > to make sure I understand how the S2R flow is expected to work in this > specific case. Action handlers won't run unless the IRQs are marked as IRQF_NO_SUSPEND (well, there are a few more complications I don't recall exactly, but that's the basic rule). If anything depends on them to run, it will block. Thanks, Rafael _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel