Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp8041460imu; Tue, 4 Dec 2018 01:47:06 -0800 (PST) X-Google-Smtp-Source: AFSGD/Vy9QOzy4C3QUfiO2ofaILr2Vi0F0riUljcd/btcMMPzQDeT+8hrN/qt2RcCSs5nNJbMWXO X-Received: by 2002:a63:a35c:: with SMTP id v28mr16142478pgn.205.1543916826568; Tue, 04 Dec 2018 01:47:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543916826; cv=none; d=google.com; s=arc-20160816; b=lZg9ggNGcKU2GO8dJyHOy8ufWrRtDHHS0UbC+7qkEk/wo34+I6wOppVspItKm8eIqX V0gk5g1RTr2fH9C1IYYeJ5DoI7/C5/pqtkmJfG3RcREaHA73S9UCQEADiMMl+yZ8dZIO u9QNkwwKQljDo5EN8+ivJNlej/LuobAEd/Vo0+p3FCRKeX+XeSJIQCxfYyG8HrFGFqPd bAvppaRb9nVxgOAl16pypCLQajTgJM7oFrGJG+04blFXhtWxCb3LJovr7x1c5FvrWfnC /mKj5KELOVRs/CqsjgnfB8UCr0CWjOZBU2jPbUnabc728TmOvzzidcJzuexZ/txh1Cj9 UksQ== 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; bh=REgMUqatYAsi6wnWKZoLvv71BmUtd9t5tbl7mPoEJUg=; b=jKshgPbmSQG74UQQJI1C/206WmCeNA9oxmYvMR+lUhFmFqmG/0hh2w3ESTL2TEenU/ WDuOY8ZhDUwGvVrQrUDcWyYYKhX3cPxwkU5DwAtr8PmnEx7uKQ5Q4IYQngxaki6fYQEe SC4OFtvFwLpES3u6toN2ton7jmA3M/jzY6nF59OjxdFqyX410wBIFJyNMqE+5ohMcLMV iB5jTNs1/3Ln2wVdW7UE4Ig5SP3QNs4Hl4fX1tx7i4GUeB7Eh4UCASEuQ+GbdaGj3DKw DBqY7ZEXluS71DFYAhUY7i50i/R50SIQa+u3Y8oXVVStGWrwJejjrsLprrYnTfPPDC7G PL7Q== 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 m23si14240280pgb.479.2018.12.04.01.46.52; Tue, 04 Dec 2018 01:47:06 -0800 (PST) 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 S1725984AbeLDJqI (ORCPT + 99 others); Tue, 4 Dec 2018 04:46:08 -0500 Received: from foss.arm.com ([217.140.101.70]:56084 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725613AbeLDJqH (ORCPT ); Tue, 4 Dec 2018 04:46:07 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id C5D81A78; Tue, 4 Dec 2018 01:46:06 -0800 (PST) Received: from e107981-ln.cambridge.arm.com (e107981-ln.cambridge.arm.com [10.1.197.40]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id D152B3F5AF; Tue, 4 Dec 2018 01:46:03 -0800 (PST) Date: Tue, 4 Dec 2018 09:45:58 +0000 From: Lorenzo Pieralisi To: "Rafael J. Wysocki" Cc: Miquel Raynal , sudeep.holla@arm.com, Gregory Clement , Jason Cooper , Andrew Lunn , Sebastian Hesselbarth , Thomas Petazzoni , Bjorn Helgaas , devicetree@vger.kernel.org, Rob Herring , Mark Rutland , linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Antoine Tenart , Maxime Chevallier , Nadav Haklai Subject: Re: [PATCH 05/12] PCI: aardvark: add suspend to RAM support Message-ID: <20181204094558.GA24588@e107981-ln.cambridge.arm.com> References: <20181123141831.8214-1-miquel.raynal@bootlin.com> <20181203102708.GA6090@e107981-ln.cambridge.arm.com> <20181203163846.494904f9@xps13> <1999610.6DN9RK2Tt3@aspire.rjw.lan> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1999610.6DN9RK2Tt3@aspire.rjw.lan> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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, 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). 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. Thanks, Lorenzo