Received: by 10.223.185.116 with SMTP id b49csp439919wrg; Wed, 14 Feb 2018 01:15:05 -0800 (PST) X-Google-Smtp-Source: AH8x2248Rn+GUwg/yNgoGDZojVowG0B45AurIWpgGzqC2f2GD2zxKoq2MQwcGpMf+A3NJ6XZ/am/ X-Received: by 10.99.178.2 with SMTP id x2mr3406119pge.98.1518599705487; Wed, 14 Feb 2018 01:15:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518599705; cv=none; d=google.com; s=arc-20160816; b=PmNuxnlsQCjBnHYegSSWX90Iv2cwR4vgL+yxh1wLfTHNT8YjuAK3CkQf5nRWx4B0i6 G+QBWCi3QPhz38hCkF0W+ZjXV6zNL/kIZF/3WnUm05Za26IzyzA657zBsn3ZMuIChUhA b8ZSgEJOgxhGZGt4EQpkHUSimAr6gDZtMcYv3SYceDF4A66O2QC1Ln/57K3Y8C1aUifu zBHrop0WfzvovUJ62ui/PVbLRI2J6ZJElh5jhA8KAnVo03Q2kVfFr6okXpAlQaN5LTLR OYxpUxCk/wkQqgs0wSm2dshPeemvpm8QplS+2cHp9UNrHlIJnM1SvBzN0AxmO9AFZzST Yhzg== 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:dmarc-filter:dkim-signature :dkim-signature:arc-authentication-results; bh=R+fdno4oc/MDgbo52lUIMUMwGBXJ7rGcXoYqhb7glZM=; b=v5Ojf6+1GXH/jvtaznA7Z9APK0eVLHc3iTlUkHTgHKMKjMXm7oj34lrpO1Tu/Na1NI g0+E+O8QPi6o2ipdAZs235kwkdQIqpdjTpeszzT3hru0KzeZzWpuZoa3vK+OPRiI6Oae YK1OHL5hO8XaPzQfW47PUkwUrLogaMkNr5yyoX+2umimp/F5PNj6A/XWkXQ2RHEV2YO+ uICdQOk78rHWcctOEmouaiTSzHMWSBVuTYhhbI55QBj+Lqkc+eBR4i3nUHeX6fNHJ1v+ oQZm9N9IEOraBqseXds36YKVdHUzJYG9sgjpYnaphU/7A0gLfmX50Pd4tS3jFBQnc6wM cXZA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=RQqRWVCa; dkim=pass header.i=@codeaurora.org header.s=default header.b=jtPQtrah; 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 b81si1132461pfj.331.2018.02.14.01.14.51; Wed, 14 Feb 2018 01:15:05 -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=RQqRWVCa; dkim=pass header.i=@codeaurora.org header.s=default header.b=jtPQtrah; 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 S966655AbeBNJOC (ORCPT + 99 others); Wed, 14 Feb 2018 04:14:02 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:52328 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S934847AbeBNJN5 (ORCPT ); Wed, 14 Feb 2018 04:13:57 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id D742C60FEA; Wed, 14 Feb 2018 09:13:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1518599637; bh=wqZ6S0CpF2DqLv/qf90LU33J0nTbdszETqYStZAAj/U=; h=In-Reply-To:References:From:Date:Subject:To:Cc:From; b=RQqRWVCa9zQhiPoA1khF4lnndJDJpBm925R0lDb9GjigU1GtkUbhZeZ8PwMOLIEIY ezJ6Gby4s0Cg6YZR/3phk43/tTXwcukffMGm7suK2hxGnxy1DSM71YBRetzoRdjl2l 2lBolYE6ZdZFzOm3Qgpm6DbtUzXcOquoHh5r9pKE= 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 mail-qt0-f179.google.com (mail-qt0-f179.google.com [209.85.216.179]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: vivek.gautam@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 50F1C60FEE; Wed, 14 Feb 2018 09:13:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1518599632; bh=wqZ6S0CpF2DqLv/qf90LU33J0nTbdszETqYStZAAj/U=; h=In-Reply-To:References:From:Date:Subject:To:Cc:From; b=jtPQtrahpNQYP2NpfsjrI5bAyn4feJvxbUKhKsdNR2S/B+90cdkOLoZJLaWCQRGvz LkTfZYalzMmryGQa0f24+686nD9dxy7IapaHq1WwYEEM06bAAg03JP6qszS52rcqWV EOEDymqf33bZl5ipwGUy19B48wsIzBsxN6KtkPN0= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 50F1C60FEE 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=vivek.gautam@codeaurora.org Received: by mail-qt0-f179.google.com with SMTP id g14so6919167qti.2; Wed, 14 Feb 2018 01:13:52 -0800 (PST) X-Gm-Message-State: APf1xPB2c5K89KXgEB0Sxl7m8g4IJS9dMIqtpdXbExuQEGOKDSJko65g k9yzCvL7w9CD73gIKNFGJQKfT9ASsTbOKY9wROo= X-Received: by 10.200.11.132 with SMTP id h4mr1913486qti.82.1518599631284; Wed, 14 Feb 2018 01:13:51 -0800 (PST) MIME-Version: 1.0 Received: by 10.200.8.227 with HTTP; Wed, 14 Feb 2018 01:13:50 -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: Vivek Gautam Date: Wed, 14 Feb 2018 14:43:50 +0530 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH v7 6/6] drm/msm: iommu: Replace runtime calls with runtime suppliers To: Tomasz Figa 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 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? > > 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