Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5646219imu; Mon, 26 Nov 2018 03:28:46 -0800 (PST) X-Google-Smtp-Source: AFSGD/V5ACQ9Hstj4GSA3a1UrG8F05YaG/q96zk7swLX2HMcBUVmn/YBI0mvqoJTL89LF0JwsB+M X-Received: by 2002:a63:5407:: with SMTP id i7mr24435567pgb.413.1543231726514; Mon, 26 Nov 2018 03:28:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543231726; cv=none; d=google.com; s=arc-20160816; b=vShEqY2FiJqjhUr0USvvrJqdXBtJLh18HSECw9sxIXdJB6vyuHEjeXfDtcJ/DCfuAY T/TQp/SZrBJ3B+cWiW0kn2B8Nh/iAg9RXRNV+Z9o2ZMVENZqnOylYYiNDhBeOJBkwJUI 1Xs5+IEue9c3JO7ihjf3Uw+CFSU3xtuE8Dk9Hh8oZ68qYRV3gbo2TpIjr/2Sl3eMTNHc lGzOqUfZoDZBMOpeZK32okggXkEXRzrXxvzqrUGP/0r0l1ck/P6HwKA4UzxOdbppI3IZ VQDsjaqVxpEogoIfLEJ9RjwE7QcPmo27HXj03mRk5LKCwdeI4NPa3MuSi+CPevT3KRwV 2Xtg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject:dmarc-filter :dkim-signature:dkim-signature; bh=lUyWX5XX93nSmsWgfx0KkEcHDARt2mevveWL3YdgJAQ=; b=DaVdgHV4gcoJDon03Em9UBLaFI+E/Ez+OAGCSS1nZ1LbJvFkqIBflXIcm5vzuCh5+L ub96dvGPH3xrOl2MAsF/hMPbIMOZJG0FtgCEJsZJfSifW8x7LropHsziZRWtn46IWq58 RJTMz0ooEyOvcmoWumn9xCe+4RRhIKpAHEEn4sn2PH+WZs2RsL4f+TmWhME80s3np3yH W0V8/oltY7FvNmTicBAFQlGAqbP03Z2VpMSCiEmgk7X00pIotV+7LiM7ZgRRoOCzDnT5 Gi+U5rVi2zktNnScqHiat/CRWZElrRR/00eJrzJyp4d5yXDIxFlly/dJPRZaKbbW/3d2 KXZw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b="dZUd+Z/f"; dkim=pass header.i=@codeaurora.org header.s=default header.b=fwPa2yJ4; 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 n28si14741pfb.88.2018.11.26.03.28.19; Mon, 26 Nov 2018 03:28:46 -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="dZUd+Z/f"; dkim=pass header.i=@codeaurora.org header.s=default header.b=fwPa2yJ4; 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 S1726713AbeKZWUl (ORCPT + 99 others); Mon, 26 Nov 2018 17:20:41 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:56578 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726263AbeKZWUl (ORCPT ); Mon, 26 Nov 2018 17:20:41 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 5F1AC61340; Mon, 26 Nov 2018 11:26:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1543231610; bh=S2TovgHbTmonJkPtnYyIkOIPJcN8+A5P8wvW9NqSomc=; h=Subject:From:To:Cc:References:Date:In-Reply-To:From; b=dZUd+Z/fPihcFhQdtPvgEvwl8Ejs/edplVztJD+e3SX3nnF0ntp1j+ZSYrnWNIJNL cVw9LH+fFM4WNhy93k58Nf0IgvrpHOqB/yhMDbor44eLT4E8hNyrD6KAt/rgzEx/+Q kNnnz1Blypg4a0NqEogqmN0TAA5CmJ1cioX4GPD4= 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.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED autolearn=no autolearn_force=no version=3.4.0 Received: from [10.79.40.201] (blr-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.18.19]) (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 6BD576132B; Mon, 26 Nov 2018 11:26:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1543231609; bh=S2TovgHbTmonJkPtnYyIkOIPJcN8+A5P8wvW9NqSomc=; h=Subject:From:To:Cc:References:Date:In-Reply-To:From; b=fwPa2yJ4xEBaqarClY8i2xM2ynP00tw2azFNnbr5ItfKYs4H/HoKn8AyBHP922rj1 6wM62cl5u1gKmF7UMFyLjXLkL2NLcLkoOUCFwU8DacK3DIRjE+AR9nCC8Lahnx/Jv9 N6btaVpTzZYw2E8CTQDAsMvmvBx1urYDrFyCUXaI= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 6BD576132B 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 Subject: Re: [RESEND PATCH v17 2/5] iommu/arm-smmu: Invoke pm_runtime during probe, add/remove device From: Vivek Gautam To: Will Deacon Cc: Mark Rutland , "open list:OPEN FIRMWARE AND FLATTENED DEVICE TREE BINDINGS" , alex.williamson@redhat.com, Linux PM , sboyd@kernel.org, freedreno , "Rafael J. Wysocki" , open list , "list@263.net:IOMMU DRIVERS" , Joerg Roedel , robh+dt , linux-arm-msm , Robin Murphy References: <20181116112430.31248-1-vivek.gautam@codeaurora.org> <20181116112430.31248-3-vivek.gautam@codeaurora.org> <20181121173757.GA9801@arm.com> <20181123183555.GE21183@arm.com> <9064c01e-cef0-9306-078a-8d303cd6614b@codeaurora.org> Message-ID: Date: Mon, 26 Nov 2018 16:56:42 +0530 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <9064c01e-cef0-9306-078a-8d303cd6614b@codeaurora.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/26/2018 11:33 AM, Vivek Gautam wrote: > > > On 11/24/2018 12:06 AM, Will Deacon wrote: >> On Thu, Nov 22, 2018 at 05:32:24PM +0530, Vivek Gautam wrote: >>> Hi Will, >>> >>> On Wed, Nov 21, 2018 at 11:09 PM Will Deacon >>> wrote: >>>> On Fri, Nov 16, 2018 at 04:54:27PM +0530, Vivek Gautam wrote: >>>>> From: Sricharan R >>>>> >>>>> The smmu device probe/remove and add/remove master device callbacks >>>>> gets called when the smmu is not linked to its master, that is >>>>> without >>>>> the context of the master device. So calling runtime apis in those >>>>> places >>>>> separately. >>>>> Global locks are also initialized before enabling runtime pm as the >>>>> runtime_resume() calls device_reset() which does tlb_sync_global() >>>>> that ultimately requires locks to be initialized. >>>>> >>>>> Signed-off-by: Sricharan R >>>>> [vivek: Cleanup pm runtime calls] >>>>> Signed-off-by: Vivek Gautam >>>>> Reviewed-by: Tomasz Figa >>>>> Tested-by: Srinivas Kandagatla >>>>> Reviewed-by: Robin Murphy >>>>> --- >>>>>   drivers/iommu/arm-smmu.c | 101 >>>>> ++++++++++++++++++++++++++++++++++++++++++----- >>>>>   1 file changed, 91 insertions(+), 10 deletions(-) >>>> Given that you're doing the get/put in the TLBI ops unconditionally: >>>> >>>>>   static void arm_smmu_flush_iotlb_all(struct iommu_domain *domain) >>>>>   { >>>>>        struct arm_smmu_domain *smmu_domain = to_smmu_domain(domain); >>>>> +     struct arm_smmu_device *smmu = smmu_domain->smmu; >>>>> >>>>> -     if (smmu_domain->tlb_ops) >>>>> +     if (smmu_domain->tlb_ops) { >>>>> +             arm_smmu_rpm_get(smmu); >>>>> smmu_domain->tlb_ops->tlb_flush_all(smmu_domain); >>>>> +             arm_smmu_rpm_put(smmu); >>>>> +     } >>>>>   } >>>>> >>>>>   static void arm_smmu_iotlb_sync(struct iommu_domain *domain) >>>>>   { >>>>>        struct arm_smmu_domain *smmu_domain = to_smmu_domain(domain); >>>>> +     struct arm_smmu_device *smmu = smmu_domain->smmu; >>>>> >>>>> -     if (smmu_domain->tlb_ops) >>>>> +     if (smmu_domain->tlb_ops) { >>>>> +             arm_smmu_rpm_get(smmu); >>>>> smmu_domain->tlb_ops->tlb_sync(smmu_domain); >>>>> +             arm_smmu_rpm_put(smmu); >>>>> +     } >>>> Why do you need them around the map/unmap calls as well? >>> We still have .tlb_add_flush path? >> Ok, so we could add the ops around that as well. Right now, we've got >> the runtime pm hooks crossing two parts of the API. > > Sure, will do that then, and remove the runtime pm hooks from map/unmap. I missed this earlier - We are adding runtime pm hooks in the 'iommu_ops' callbacks and not really to 'tlb_ops'. So how the runtime pm hooks crossing the paths? '.map/.unmap' iommu_ops don't call '.flush_iotlb_all' or '.iotlb_sync' iommu_ops anywhere. E.g., only callers to domain->ops->flush_iotlb_all() are: iommu_dma_flush_iotlb_all(), or iommu_flush_tlb_all() which are not in map/unmap paths. Regards Vivek > > Thanks > Vivek >> >> Will >