Received: by 10.223.185.116 with SMTP id b49csp447274wrg; Wed, 14 Feb 2018 01:23:19 -0800 (PST) X-Google-Smtp-Source: AH8x225zFEC3OZpLe9T5VB5SfnvXJID0Xof9N6ZeOgNna+gR40UsYyoWCkoOkyRtoQaCo9ZaVdfp X-Received: by 2002:a17:902:2823:: with SMTP id e32-v6mr3909054plb.44.1518600198960; Wed, 14 Feb 2018 01:23:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518600198; cv=none; d=google.com; s=arc-20160816; b=TUCSLIl8+NtxMjGQkIyoScD83fa67Qz74tM/6cSCiRXiqzUqEWBCrZyai6hhDZReZm LiX1WuU2PCDdP7Dz0nsOJOxyw+AB5P6J7lUDwK5ZoAbG0xntO9mtJN2ahWr9V/20HrPd t4bikVmN1QaHRNG+VhQO8fiheLn7a8/nmREcNMOBhCx4vi2Vuj6tpR4munml6P5itSXI MWsfWwE7zjSb/AZ5s7qiyD1YahlTfZksI+INEI6iEIFNvVB252XrCbhcQRPusvyBMFvJ nyNvW0OsGSLdU3HLdGrviHYZa7HXvj+JIg4XFyNU++1Tf+t5iPlkjH5Wtd1y5tL69DXO 5qqA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=c0lCUrxmS9rzhhpC+KlwcwqGtn5GZN3bOyYyrbGznBE=; b=VCg0VSBVSyrKHfbNYZMfZeU4hlgxOuCnTCONViqF89uw3cNCtQcEdYc4U9v0wLG9lP AVBekvk2swqyXksHtMxb+zkv8TlcQ7YyMzybO74rhrqaDeTyaNUvNYnbdpNP37UxEwiX Quz9BUNYf68PxptuT/YYz9oismdTVw0u+o5MOkoTI3Lliz8VOGnT4WbiG9X0+Z5xl92/ mTBNXy8o55dw1koV/qxdisG1lJ8H9RR2TthA8NQtOTv5oqKPZx/KjWnsbKFQ9OKc6oPv og9vz1IUZaRIq1zdALDzDNwyb1pzSqgSH9s1OG0F8QgCqwIJ+ICzi76uTcSqbVBZJV8s FEeQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=f8FqdbUm; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j11si1932010pgp.468.2018.02.14.01.23.04; Wed, 14 Feb 2018 01:23:18 -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=@chromium.org header.s=google header.b=f8FqdbUm; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S966840AbeBNJW1 (ORCPT + 99 others); Wed, 14 Feb 2018 04:22:27 -0500 Received: from mail-ua0-f193.google.com ([209.85.217.193]:41659 "EHLO mail-ua0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S966405AbeBNJWZ (ORCPT ); Wed, 14 Feb 2018 04:22:25 -0500 Received: by mail-ua0-f193.google.com with SMTP id d4so8723021uak.8 for ; Wed, 14 Feb 2018 01:22:25 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=c0lCUrxmS9rzhhpC+KlwcwqGtn5GZN3bOyYyrbGznBE=; b=f8FqdbUmJwfJMc5iVvWax2LLlkgfAHmeyRYlHLR6TBXPgAdbx9pPiqyAMVA38/FeLj uF6iDr/j1lNrjPghgQeZCOlk2+n9jqHQwg/m54skV++s/Jrcg5ZPxCJTyoxONRg+c5FL cBaJ37Q4L2MYpdv3hMuvc9HPBTFhzCWj38LFc= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=c0lCUrxmS9rzhhpC+KlwcwqGtn5GZN3bOyYyrbGznBE=; b=DQgr5+N+BhRyDQRPkrbjuhXH4kGj1DT15wnAy//Y51ZXdUKxPovW9A5KVXlNU8sSUT RTg/1FMT10WkkpYOcC+EF5gd+i1prcAg85J0QvOf2oY5gQ9ua1bDoYlqyegCxdTwN4kf +59T6IKAZeqMwySUrdaRptUCpBBiWHnEz5Q6ljhC1Qkb7Xw0/i1CcijhQByE0k3QJC3D 3L2Sk/9R5gt4XICKEbiXg85gZ6vyETCBmqAUg3kLUpfH7xulDUWQHRn2PCz3jR5VXlW7 YziXTs2YDv9eW+v1iItlWNco41gQYwWQeAlL6+L6dbRHqLDXbQnOblSHmXGtzOFM4J2/ STiQ== X-Gm-Message-State: APf1xPBbAa7zCF50fQc13KD+/ZDw7vgrY9i+papCjT1le88U2MJlPvE/ Jq2mica6O88PpWJiBHq8MA3Z/nLKgio= X-Received: by 10.176.23.93 with SMTP id k29mr3843570uaf.56.1518600143250; Wed, 14 Feb 2018 01:22:23 -0800 (PST) Received: from mail-vk0-f43.google.com (mail-vk0-f43.google.com. [209.85.213.43]) by smtp.gmail.com with ESMTPSA id o21sm204723vkb.15.2018.02.14.01.22.22 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 14 Feb 2018 01:22:23 -0800 (PST) Received: by mail-vk0-f43.google.com with SMTP id b132so5538392vke.9 for ; Wed, 14 Feb 2018 01:22:22 -0800 (PST) X-Received: by 10.31.172.22 with SMTP id v22mr4030415vke.54.1518599780883; Wed, 14 Feb 2018 01:16:20 -0800 (PST) MIME-Version: 1.0 Received: by 10.176.0.68 with HTTP; Wed, 14 Feb 2018 01:16:00 -0800 (PST) In-Reply-To: References: <1517999482-17317-1-git-send-email-vivek.gautam@codeaurora.org> <1517999482-17317-7-git-send-email-vivek.gautam@codeaurora.org> From: Tomasz Figa Date: Wed, 14 Feb 2018 18:16:00 +0900 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH v7 6/6] drm/msm: iommu: Replace runtime calls with runtime suppliers To: Vivek Gautam Cc: Rob Clark , "list@263.net:IOMMU DRIVERS , Joerg Roedel ," , Rob Herring , Mark Rutland , "Rafael J. Wysocki" , Robin Murphy , Will Deacon , "list@263.net:IOMMU DRIVERS , Joerg Roedel ," , devicetree@vger.kernel.org, Linux Kernel Mailing List , Linux PM , dri-devel , freedreno , David Airlie , Greg KH , Stephen Boyd , linux-arm-msm Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 14, 2018 at 6:13 PM, Vivek Gautam wrote: > Hi Tomasz, > > On Wed, Feb 14, 2018 at 11:08 AM, Tomasz Figa wrote: >> On Wed, Feb 14, 2018 at 1:17 PM, Vivek Gautam >> wrote: >>> Hi Tomasz, >>> >>> On Wed, Feb 14, 2018 at 8:31 AM, Tomasz Figa wrote: >>>> On Wed, Feb 14, 2018 at 11:13 AM, Rob Clark wrote: >>>>> On Tue, Feb 13, 2018 at 8:59 PM, Tomasz Figa wrote: >>>>>> On Wed, Feb 14, 2018 at 3:03 AM, Rob Clark wrote: >>>>>>> On Tue, Feb 13, 2018 at 4:10 AM, Tomasz Figa wrote: >>>>>>>> Hi Vivek, >>>>>>>> >>>>>>>> Thanks for the patch. Please see my comments inline. >>>>>>>> >>>>>>>> On Wed, Feb 7, 2018 at 7:31 PM, Vivek Gautam >>>>>>>> wrote: >>>>>>>>> While handling the concerned iommu, there should not be a >>>>>>>>> need to power control the drm devices from iommu interface. >>>>>>>>> If these drm devices need to be powered around this time, >>>>>>>>> the respective drivers should take care of this. >>>>>>>>> >>>>>>>>> Replace the pm_runtime_get/put_sync() with >>>>>>>>> pm_runtime_get/put_suppliers() calls, to power-up >>>>>>>>> the connected iommu through the device link interface. >>>>>>>>> In case the device link is not setup these get/put_suppliers() >>>>>>>>> calls will be a no-op, and the iommu driver should take care of >>>>>>>>> powering on its devices accordingly. >>>>>>>>> >>>>>>>>> Signed-off-by: Vivek Gautam >>>>>>>>> --- >>>>>>>>> drivers/gpu/drm/msm/msm_iommu.c | 16 ++++++++-------- >>>>>>>>> 1 file changed, 8 insertions(+), 8 deletions(-) >>>>>>>>> >>>>>>>>> diff --git a/drivers/gpu/drm/msm/msm_iommu.c b/drivers/gpu/drm/msm/msm_iommu.c >>>>>>>>> index b23d33622f37..1ab629bbee69 100644 >>>>>>>>> --- a/drivers/gpu/drm/msm/msm_iommu.c >>>>>>>>> +++ b/drivers/gpu/drm/msm/msm_iommu.c >>>>>>>>> @@ -40,9 +40,9 @@ static int msm_iommu_attach(struct msm_mmu *mmu, const char * const *names, >>>>>>>>> struct msm_iommu *iommu = to_msm_iommu(mmu); >>>>>>>>> int ret; >>>>>>>>> >>>>>>>>> - pm_runtime_get_sync(mmu->dev); >>>>>>>>> + pm_runtime_get_suppliers(mmu->dev); >>>>>>>>> ret = iommu_attach_device(iommu->domain, mmu->dev); >>>>>>>>> - pm_runtime_put_sync(mmu->dev); >>>>>>>>> + pm_runtime_put_suppliers(mmu->dev); >>>>>>>> >>>>>>>> For me, it looks like a wrong place to handle runtime PM of IOMMU >>>>>>>> here. iommu_attach_device() calls into IOMMU driver's attach_device() >>>>>>>> callback and that's where necessary runtime PM gets should happen, if >>>>>>>> any. In other words, driver A (MSM DRM driver) shouldn't be dealing >>>>>>>> with power state of device controlled by driver B (ARM SMMU). >>>>>>> >>>>>>> Note that we end up having to do the same, because of iommu_unmap() >>>>>>> while DRM driver is powered off.. it might be cleaner if it was all >>>>>>> self contained in the iommu driver, but that would make it so other >>>>>>> drivers couldn't call iommu_unmap() from an irq handler, which is >>>>>>> apparently something that some of them want to do.. >>>>>> >>>>>> I'd assume that runtime PM status is already guaranteed to be active >>>>>> when the IRQ handler is running, by some other means (e.g. >>>>>> pm_runtime_get_sync() called earlier, when queuing some work to the >>>>>> hardware). Otherwise, I'm not sure how a powered down device could >>>>>> trigger an IRQ. >>>>>> >>>>>> So, if the master device power is already on, suppliers should be >>>>>> powered on as well, thanks to device links. >>>>>> >>>>> >>>>> umm, that is kindof the inverse of the problem.. the problem is >>>>> things like gpu driver (and v4l2 drivers that import dma-buf's, >>>>> afaict).. they will potentially call iommu->unmap() when device is not >>>>> active (due to userspace or things beyond the control of the driver).. >>>>> so *they* would want iommu to do pm get/put calls. >>>> >>>> Which is fine and which is actually already done by one of the patches >>>> in this series, not for map/unmap, but probe, add_device, >>>> remove_device. Having parts of the API doing it inside the callback >>>> and other parts outside sounds at least inconsistent. >>>> >>>>> But other drivers >>>>> trying to unmap from irq ctx would not. Which is the contradictory >>>>> requirement that lead to the idea of iommu user powering up iommu for >>>>> unmap. >>>> >>>> Sorry, maybe I wasn't clear. My last message was supposed to show that >>>> it's not contradictory at all, because "other drivers trying to unmap >>>> from irq ctx" would already have called pm_runtime_get_*() earlier >>>> from a non-irq ctx, which would have also done the same on all the >>>> linked suppliers, including the IOMMU. The ultimate result would be >>>> that the map/unmap() of the IOMMU driver calling pm_runtime_get_sync() >>>> would do nothing besides incrementing the reference count. >>> >>> The entire point was to avoid the slowpath that pm_runtime_get/put_sync() >>> would add in map/unmap. It would not be correct to add a slowpath in irq_ctx >>> for taking care of non-irq_ctx and for the situations where master is already >>> powered-off. >> >> Correct me if I'm wrong, but I believe that with what I'm proposing >> there wouldn't be any slow path. > > Yea, but only when the power domain is irq-safe? And not all platforms > enable irq-safe power domains. For instance, msm doesn't enable its > gdsc power domains as irq-safe. > Is it something i am missing? irq-safe would matter if there would exist a case when the call is done from IRQ context and the power is off. As I explained in a), it shouldn't happen. Best regards, Tomasz > >> >> a) For IRQ context, the master is already powered on and so the SMMU >> is also powered on, through respective device link. >> pm_runtime_get_sync() would ultimately just increment the runtime PM >> usage count. >> >> b) For a case when the master is already powered off (which wouldn't >> be IRQ context, for the reason stated in a)), powering on the SMMU is >> unavoidable, if the SMMU hardware really needs to be accessed (i.e. >> some TLBs need to be invalidated, if their state is preserved despite >> master being powered down). >> >>> >>>> >>>>> >>>>> There has already been some discussion about this on various earlier >>>>> permutations of this patchset. I think we have exhausted all other >>>>> options. >>>> >>>> I guess I should have read those. Let me do that now. >>> Yea, i point to the thread in cover letter and [PATCH 1/6]. >>> Thanks. >> >> I read through all the links in the cover letter and I could see other >> attempts not working out indeed, but they were different from what I'm >> proposing. >> >> There was also a point raised that __pm_runtime_resume() called from >> pm_runtime_get_sync() would grab dev->power_lock spinlock, which is >> true, except that if the device is already active, it would do it only >> for the time of checking device state, so I doubt it would really be a >> significant point of contention. >> >> Best regards, >> Tomasz >> -- >> To unsubscribe from this list: send the line "unsubscribe linux-arm-msm" in >> the body of a message to majordomo@vger.kernel.org >> More majordomo info at http://vger.kernel.org/majordomo-info.html > > > > -- > QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member > of Code Aurora Forum, hosted by The Linux Foundation