Received: by 10.223.164.202 with SMTP id h10csp2258895wrb; Mon, 27 Nov 2017 14:23:42 -0800 (PST) X-Google-Smtp-Source: AGs4zMZRDnp/A4EkZY/4ewG5n6z+99JM5RLF2xPfqQrpTIckgksuqrJ+55V6jKX6ulIUvYVc1XZL X-Received: by 10.98.31.142 with SMTP id l14mr38583579pfj.62.1511821422044; Mon, 27 Nov 2017 14:23:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511821422; cv=none; d=google.com; s=arc-20160816; b=W9SmNoUuoYmBchuS+cPUGN8q5rOLDX6fIsOuK+2MzLfKIuBJ4vO/WZwPs+OO+Tc1WN cRvhpJiviaWrNUtKizUzJm1Jc5TQVjS077kC8AXvebIfVxz7zMzw9qrfoEEYQebCXt3H 6UAe6xULx8BClt6m6jTueCZnPdKt/DxFW+76VPDTr9lYYyH6WjI1fAjq/fkOGDdlKAwh B8NWCo+CPt5LwoptPfwhDG7+b76RDYsQSgzjl9TqEJ4uWQ4rqLvKX9dRV5yCXeeQkQTq hnrjguRMBVQwzA+kTTPxpVTe2vGeoratHPPQO6WRu80GsZX7VjLf34Xm8sCOmwDfR7Of AGug== 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:dmarc-filter:dkim-signature:dkim-signature :arc-authentication-results; bh=IqRSFofgAu+7kDbVbhFNCW/wSZ9nl2q88A7yfhVVuO0=; b=bFvVeEWFzKIwu6F/KHpmq57U9Dmo3Mo91GORGwV0mjRxS6RXMoVhLfB8h+VeNyaIyY BS011Ao59BE7jSiYq7GGS6EbvdGXu73DbPxRElcglA0udStbywUqplp1P1sw0CozQQ6I bJJh6q0dpOEvVGRyQESk6gpHEFqTtgbI0xvdgL1I5RwGRs9x0bCD4kpRoqvYLV3qmxAe 3ntpPK6z6vQMDzL/kEuemcdfBB160Bns9xi0TZ+au94y+3p84wm7RxvF8lXt0Hv2b+eI EFeD5dj4FpElwsB7hdtfhK30fgS/7kUpJX0ra9gIMvf+xAX3myjZh9CaFnqT3YfB3mzC 8/XA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=dFXfdNMr; dkim=pass header.i=@codeaurora.org header.s=default header.b=CgMSkCmb; 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 h185si23555991pgc.164.2017.11.27.14.23.29; Mon, 27 Nov 2017 14:23:41 -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; dkim=pass header.i=@codeaurora.org header.s=default header.b=dFXfdNMr; dkim=pass header.i=@codeaurora.org header.s=default header.b=CgMSkCmb; 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 S1752572AbdK0WWp (ORCPT + 78 others); Mon, 27 Nov 2017 17:22:45 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:32894 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752399AbdK0WWl (ORCPT ); Mon, 27 Nov 2017 17:22:41 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id D574F6A42A; Mon, 27 Nov 2017 22:22:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1511821360; bh=/1VyHIq7suicmXkJbqhrnI3tOaN/KbnzIV05nQlVriM=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=dFXfdNMrH/dCmjpqxrHnd9WNuYdz3wqITMxFGfpSDjpjWkJ/yKU7gsjwfAoyre9nx tyv+GZaUDs/3ZORhrc911HJA5sbwpDrli2S25fmGFt4C2yUAcu16BZ9cc2A1G3EHDy CfM/aR8VjunHxvO3hALXg+/iD5eaiKMZo4sEaOlI= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from localhost (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher DHE-RSA-AES128-SHA (128/128 bits)) (No client certificate requested) (Authenticated sender: sboyd@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 513B86A410; Mon, 27 Nov 2017 22:22:39 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1511821359; bh=/1VyHIq7suicmXkJbqhrnI3tOaN/KbnzIV05nQlVriM=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=CgMSkCmbN23oWis7tjtx/WBiAsMloPZM5PB8/WiakMwJFd2faRb1S0BKLZuuUJazL uAMUnF0YofMY8pvaLqKH+D9SSpwK2MffYhgEqlKwbGuOcHLU45aIMlBImDSGuDbnJI svMOqtyyvowJwlwTtgLgr+Igl8j6j0JS+2BRGjak= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 513B86A410 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=sboyd@codeaurora.org Date: Mon, 27 Nov 2017 14:22:38 -0800 From: Stephen Boyd To: Vivek Gautam Cc: Rob Clark , Robin Murphy , Will Deacon , "Rafael J. Wysocki" , Sricharan R , Joerg Roedel , Rob Herring , Mark Rutland , Marek Szyprowski , "iommu@lists.linux-foundation.org" , "devicetree@vger.kernel.org" , Linux Kernel Mailing List , linux-clk , linux-arm-msm , Stanimir Varbanov , Archit Taneja , "linux-arm-kernel@lists.infradead.org" Subject: Re: [PATCH V4 3/6] iommu/arm-smmu: Invoke pm_runtime during probe, add/remove device Message-ID: <20171127222238.GF18379@codeaurora.org> References: <1499333825-7658-1-git-send-email-vivek.gautam@codeaurora.org> <1499333825-7658-4-git-send-email-vivek.gautam@codeaurora.org> <20170712225459.GZ22780@codeaurora.org> <5ee0bacd-e557-a6c4-a897-844fb12ea6ae@codeaurora.org> <4dbc938c-ac88-9bd4-cf00-458008ae24c1@codeaurora.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/15, Vivek Gautam wrote: > Hi, > > > On Mon, Aug 7, 2017 at 5:59 PM, Rob Clark wrote: > > On Mon, Aug 7, 2017 at 4:27 AM, Vivek Gautam > > wrote: > >> On Thu, Jul 13, 2017 at 5:20 PM, Rob Clark wrote: > >>> On Thu, Jul 13, 2017 at 1:35 AM, Sricharan R wrote: > >>>> Hi Vivek, > >>>> > >>>> On 7/13/2017 10:43 AM, Vivek Gautam wrote: > >>>>> Hi Stephen, > >>>>> > >>>>> > >>>>> On 07/13/2017 04:24 AM, Stephen Boyd wrote: > >>>>>> On 07/06, Vivek Gautam wrote: > >>>>>>> @@ -1231,12 +1237,18 @@ static int arm_smmu_map(struct iommu_domain *domain, unsigned long iova, > >>>>>>> static size_t arm_smmu_unmap(struct iommu_domain *domain, unsigned long iova, > >>>>>>> size_t size) > >>>>>>> { > >>>>>>> - struct io_pgtable_ops *ops = to_smmu_domain(domain)->pgtbl_ops; > >>>>>>> + struct arm_smmu_domain *smmu_domain = to_smmu_domain(domain); > >>>>>>> + struct io_pgtable_ops *ops = smmu_domain->pgtbl_ops; > >>>>>>> + size_t ret; > >>>>>>> if (!ops) > >>>>>>> return 0; > >>>>>>> - return ops->unmap(ops, iova, size); > >>>>>>> + pm_runtime_get_sync(smmu_domain->smmu->dev); > >>>>>> Can these map/unmap ops be called from an atomic context? I seem > >>>>>> to recall that being a problem before. > >>>>> > >>>>> That's something which was dropped in the following patch merged in master: > >>>>> 523d7423e21b iommu/arm-smmu: Remove io-pgtable spinlock > >>>>> > >>>>> Looks like we don't need locks here anymore? > >>>> > >>>> Apart from the locking, wonder why a explicit pm_runtime is needed > >>>> from unmap. Somehow looks like some path in the master using that > >>>> should have enabled the pm ? > >>>> > >>> > >>> Yes, there are a bunch of scenarios where unmap can happen with > >>> disabled master (but not in atomic context). > >> > >> I would like to understand whether there is a situation where an unmap is > >> called in atomic context without an enabled master? > >> > >> Let's say we have the case where all the unmap calls in atomic context happen > >> only from the master's context (in which case the device link should > >> take care of > >> the pm state of smmu), and the only unmap that happen in non-atomic context > >> is the one with master disabled. In such a case doesn it make sense to > >> distinguish > >> the atomic/non-atomic context and add pm_runtime_get_sync()/put_sync() only > >> for the non-atomic context since that would be the one with master disabled. > >> > > > > At least drm/msm needs to hold obj->lock (a mutex) in unmap, so it > > won't unmap anything in atomic ctx (but it can unmap w/ master > > disabled). I can't really comment about other non-gpu drivers. It > > seems like a reasonable constraint that either master is enabled or > > not in atomic ctx. > > > > Currently we actually wrap unmap w/ pm_runtime_get/put_sync(), but I'd > > like to drop that to avoid powering up the gpu. > > Since the deferring the TLB maintenance doesn't look like the best approach [1], > how about if we try to power-up only the smmu from different client > devices such as, > GPU in the unmap path. Then we won't need to add pm_runtime_get/put() calls in > arm_smmu_unmap(). > > The client device can use something like - pm_runtime_get_supplier() since > we already have the device link in place with this patch series. This should > power-on the supplier (which is smmu) without turning on the consumer > (such as GPU). > > pm_runtime_get_supplier() however is not exported at this moment. > Will it be useful to export this API and use it in the drivers. > I'm not sure pm_runtime_get_supplier() is correct either. That feels like we're relying on the GPU driver knowing the internal details of how the device links are configured. Is there some way to have the GPU driver know in its runtime PM resume hook that it doesn't need to be powered on because it isn't actively drawing anything or processing commands? I'm thinking of the code calling pm_runtime_get() as proposed around the IOMMU unmap path in the GPU driver and then having the runtime PM resume hook in the GPU driver return some special value to indicate that it didn't really resume because it didn't need to and to treat the device as runtime suspended but not return an error. Then the runtime PM core can keep track of that and try to power the GPU on again when another pm_runtime_get() is called on the GPU device. This keeps the consumer API the same, always pm_runtime_get(), but leaves the device driver logic of what to do when the GPU doesn't need to power on to the runtime PM hook where the driver has all the information. -- Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project From 1584069944930597147@xxx Tue Nov 14 19:13:41 +0000 2017 X-GM-THRID: 1572165554236663762 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread