Received: by 10.223.185.116 with SMTP id b49csp1512575wrg; Wed, 14 Feb 2018 19:19:12 -0800 (PST) X-Google-Smtp-Source: AH8x226j9eaKgJ2CjDrhKUWDvWdHSHa34eokYtJyHlabH2vSEymYozMqOBOqdl0+d2Hy2ZAyRexz X-Received: by 10.98.20.77 with SMTP id 74mr1216308pfu.45.1518664752804; Wed, 14 Feb 2018 19:19:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518664752; cv=none; d=google.com; s=arc-20160816; b=WD2oH6CcdJzTN2AVmA6HYDeh6L2eBRFs1djt8azCNd8vrHevCTwG29hMR7kmQIduUf 98yWwmxkP1WRMGjDq6qsiK6upKuL1ERNE+OC8FunwmdIcUR24eKW1dIPTFC4ba4iHmSf 4wKnTBmw9spmUs3jgc5rHZfYRQUHyhE6EASE0mZdBehTElIjj2JrawFokc5iuujnKV9f +ulSh5WevY/wrNTVlsMdv56x8tiHwk7HepgiirBT5Ud5AAiktVOhWzGxH2OerfBWIAL7 ZtEScYUUbiEr0vAIoOVt+rkrvFHWWQe6z/mDQ3aTC1xybUM23sLZVVpQwPZQW7uYeMmA Wndg== 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=64ye8nEqQIfw7wwo8Zv2ELKRTzG2cyr5SIku8cx38qQ=; b=MWGwmVuHcrLzKt+v9ofQdwlbJLsPZ8ZHAM4Zxq6jI3oR6UQEpqW+kjITVZPD6Q8fzW Swoxmp6uI/JSTQHtcNbDL1tTZ3lghruFfyWfmOXWgy3uuUkmfRE0x/uIUk4/jM/cxmFm H/Pid/uMTwoClMKUmMJc4mZUb5iQ5EnEfeMjCTtRObaRDJcXw90YPetUhF5sW/a7sPI0 JnCpMx4eJ0i+hPSmntLdVfvWh7iEgFvSfVU81K6/7UlGPdDGelwp4PbuLG0GO+kt/ih6 bS64g2DmvYkj3iiLkUSdX72NeMsX4CvZoIuiJ8sUSyN0Oybui3wODV6ZU0L2PiS6RqPo rMaw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=akFIzmvs; 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 i67si1727043pfj.212.2018.02.14.19.18.57; Wed, 14 Feb 2018 19:19:12 -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=akFIzmvs; 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 S1032563AbeBODSP (ORCPT + 99 others); Wed, 14 Feb 2018 22:18:15 -0500 Received: from mail-vk0-f48.google.com ([209.85.213.48]:45780 "EHLO mail-vk0-f48.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1032598AbeBODSM (ORCPT ); Wed, 14 Feb 2018 22:18:12 -0500 Received: by mail-vk0-f48.google.com with SMTP id j204so14149130vke.12 for ; Wed, 14 Feb 2018 19:18:12 -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=64ye8nEqQIfw7wwo8Zv2ELKRTzG2cyr5SIku8cx38qQ=; b=akFIzmvsvmYeFo+W21KRxevwYnDx92hUaIkj8+PYg2tPNCcc8OikZ3VWDAZqylnVqw XWDPbRDFHhtGpxr9l+N2cVvFkZQSbFFMb1O+BQumxH5vEr8hHmE4iNzX2CBkEcEMRgZY rnwIDH+g+mbwfYQTrtJw/v64q7RTMYyxpfmPE= 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=64ye8nEqQIfw7wwo8Zv2ELKRTzG2cyr5SIku8cx38qQ=; b=VYztk3+rR11zwtOhWrAXJ7GNUeOMjODb7Fj28Yex//8YZmRPWDXezzF/zwKF9wskTI DIwcuRlzplv1xOqyIPY2IUHEICrjSAinyU3iFCZMnHn5ZekKS1fvUo8nUcm1EuEVBJnt +//Aw+0GPSD+B+1vr2T+zAV1G5tbvubnH/a2OsOAQD1RoxPxo7twE2fI8lrm6ENaw+Pi 3NsLCUlrnj3IFfhh36BiS1jUVdDoOFY3I7PCLntmKgJePqFtPdWTopEZP7lbBAm8Gpnd 1bPscVIEv73NdEcPWv9J0iZbpp3/Cc25jV8qza+w1OPVNj9CvR64c5Fz1mnisWJC6PB/ nIIA== X-Gm-Message-State: APf1xPAxJ3IBoFf5fzTEL86HEf3vy1WsrguOKDovJmtG8dEq2kVUgN/W guOxjGxOcnivauSo7wVuhXnIVPW0MKc= X-Received: by 10.31.13.143 with SMTP id 137mr1093470vkn.33.1518664691441; Wed, 14 Feb 2018 19:18:11 -0800 (PST) Received: from mail-vk0-f48.google.com (mail-vk0-f48.google.com. [209.85.213.48]) by smtp.gmail.com with ESMTPSA id e187sm2702626vkg.5.2018.02.14.19.18.09 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 14 Feb 2018 19:18:10 -0800 (PST) Received: by mail-vk0-f48.google.com with SMTP id o204so2263801vkd.13 for ; Wed, 14 Feb 2018 19:18:09 -0800 (PST) X-Received: by 10.31.77.135 with SMTP id a129mr1164806vkb.36.1518664688780; Wed, 14 Feb 2018 19:18:08 -0800 (PST) MIME-Version: 1.0 Received: by 10.176.0.68 with HTTP; Wed, 14 Feb 2018 19:17:48 -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: Thu, 15 Feb 2018 12:17:48 +0900 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH v7 6/6] drm/msm: iommu: Replace runtime calls with runtime suppliers To: Robin Murphy Cc: Vivek Gautam , Will Deacon , Rob Clark , "list@263.net:IOMMU DRIVERS" , Joerg Roedel , Rob Herring , Mark Rutland , "Rafael J. Wysocki" , devicetree@vger.kernel.org, Linux Kernel Mailing List , Linux PM , dri-devel , freedreno , David Airlie , Greg KH , Stephen Boyd , linux-arm-msm , jcrouse@codeaurora.org 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 Thu, Feb 15, 2018 at 1:03 AM, Robin Murphy wrote: > On 14/02/18 10:33, Vivek Gautam wrote: >> >> On Wed, Feb 14, 2018 at 2:46 PM, Tomasz Figa wrote: >> >> Adding Jordan to this thread as well. >> >>> 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. >> >> >> Hi Robin, Will >> >> Does adding pm_runtime_get() in map/unmap sounds good to you? > > > Given that we spent significant effort last year removing as much locking as > we possibly could from the map/unmap path to minimise the significant > performance impact it was having on networking/storage/etc. workloads, I > really don't want to introduce more for the sake of one specific use-case, > so no. Could you elaborate on what kind of locking you are concerned about? As I explained before, the normally happening fast path would lock dev->power_lock only for the brief moment of incrementing the runtime PM usage counter. Best regards, Tomasz