Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5343586imu; Sun, 25 Nov 2018 22:04:21 -0800 (PST) X-Google-Smtp-Source: AJdET5eVaEagIQ0zcyBvDZsurp/oX4x7jxSENYO6Ihb3jbZ5EkFHr1RjGQg9pWWoWTLgiOXG48xS X-Received: by 2002:a62:870e:: with SMTP id i14mr27018881pfe.41.1543212261544; Sun, 25 Nov 2018 22:04:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543212261; cv=none; d=google.com; s=arc-20160816; b=v7i+iYsWeNziKv4LXCKex3ITy1amg29UZxklybPH+txhGbQYu41YWKq648T5N2OvCa rmg5VSkoKAWoWw0uWCZ6/L35BAtHD5rKE7ALhUK8Hc9/9UuTtj0FkA7hN2bd9GQQ8OZZ +Spu6g/9E+SAzOyFOFznHH4F4tK1MLn4RV+Ki0A3C0CVnzsSwz81oW7s0irrFcxHmZCl /iZ4vVndaiw8KVWac40LklfX46BmHuTvS0GjSrKWldpDL/7KdiEWS57yEr5XjSt4B+Lo +G73Yv+KVm4UeikVJ2e+KELRTPvgGM1/zzU0MJGuAqWfM8xIMIFIAndmWl2GRfHofTnI od4g== 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:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature; bh=FCd6c1IRybDk93cm2T7MKf/Yqq7aHi684GLH0Ia+IOg=; b=coe9R2/RSEizHBuZbqjs8dSdgZw83J2No+ELZ68t6BlEhHk5eLDzgN3h52jknQ4cXP ///pmoDauL69X4eVPmRe0sWCuKjyqtVK6XsTXbLXMh7C4YJwwhN++L97VOYfWvUme94P r2uZoBIrrils3Ci7pQ+b+GEGETwCqX9QbMGUw5+WjCRMsauQtRkh31CRK0XmKoDPAqOE oBGrQqlnapHeT4/ViuXq3yTqVTDDCmcj7fB+eE/HKTQw54SPa6QCkEIOXP7wQ10Q4nnx qG/lmTq9L+Q8Sz6c8NoagCWFIIzJAcz5Z1NuA73QXm7B8/JfBdJoSgJEtNwHzoSueLR6 cvcw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=WrFVehrw; dkim=pass header.i=@codeaurora.org header.s=default header.b=eo0aeECo; 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 m30si30020072pff.158.2018.11.25.22.04.06; Sun, 25 Nov 2018 22:04:21 -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=WrFVehrw; dkim=pass header.i=@codeaurora.org header.s=default header.b=eo0aeECo; 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 S1726248AbeKZQ4Z (ORCPT + 99 others); Mon, 26 Nov 2018 11:56:25 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:39410 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726145AbeKZQ4Y (ORCPT ); Mon, 26 Nov 2018 11:56:24 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 87C586086B; Mon, 26 Nov 2018 06:03:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1543212202; bh=TtMPE2NKj0InUGwHDyByTBIeSUegY40+/tfqcG3xP0U=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=WrFVehrw2FC51qLfo6AwKCP1afd0rL7nQYpe/DQHLmCQD+XgvhfJAPJ1R8wqNB+5a gYOeBtlg+4HptetjKtaXsWhoRlS5BziyPfRiGMAm9wuZvIS4I5uhhe0QGWkKQ5JuCQ Vyxo6h1/3BdOqdV4p5eSu1w5NCJ4IqAYI4DvHUbo= 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 93D9B602BD; Mon, 26 Nov 2018 06:03:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1543212201; bh=TtMPE2NKj0InUGwHDyByTBIeSUegY40+/tfqcG3xP0U=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=eo0aeECo3Ujhrfn0M54YfcJZklMVWUWJ4I6FrSgBZa8/1QO2/cPytCP7xsbTosvyV AV4bmaH1RYki+ISl6bGtIiZ/qLDI7baZp7tuFq5zRx9YDtwIeauGDobghxXqVCusZM q/b1xk7/InnU7O/tN5AWkMc0yvdZ12KnSolensMc= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 93D9B602BD 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 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 , iommu@lists.linux-foundation.org, 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> From: Vivek Gautam Message-ID: <9064c01e-cef0-9306-078a-8d303cd6614b@codeaurora.org> Date: Mon, 26 Nov 2018 11:33:15 +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: <20181123183555.GE21183@arm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit 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/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. Thanks Vivek > > Will