Received: by 2002:ac0:8845:0:0:0:0:0 with SMTP id g63csp2166536img; Wed, 27 Feb 2019 11:31:21 -0800 (PST) X-Google-Smtp-Source: AHgI3IandjnbILfzX1196rxrgfaUxYDVdS9pE5y0nBeRgzRJOVwWyEfO6WZtZL/A6VWmHIOXfeXz X-Received: by 2002:a65:6298:: with SMTP id f24mr4536770pgv.183.1551295881493; Wed, 27 Feb 2019 11:31:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551295881; cv=none; d=google.com; s=arc-20160816; b=DWh2woJ/wc8LI4sb4YWMorZmOepHndtf4QijDJ8FNEzqZz/l7ZBkfNGZoVTLlGN8la 4Gi6h/LqFFCvKc5ZARGGUKP2ru32ar6tjg5ju08WqMPTB+d883e41fuaC9w9nMP+WZ8p SuY/B0QhRnNfZwNxSCQW7b7UjG+BrR+dU1esnbygHQ1ZSBf/v6D+6NZkRE1LPrrSUrVL KoEZTHHP1eJsG84UbO1Fy3BLCgfrEY6UHoOtNyDRfdshyuiIK2t4clDhr5aPH2wOriL7 6taVFGt/h3yru+X84iVd3MHoRkLy1naSNzBoBmURaz0P6Rz+m5a8Nu08uiZmCfCDkalt obhw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=z9QNz5ZyuHX9MzIw2kc+bV7n+3uQbeF9u+gdSB3WNRw=; b=od0hBiYq8eNDBlbZn/w6fFlArw9ZxCqsoQIiaS4uHAqyTXwlQuJzU28DfeaM3U347s 1ezQPaN93gs+Atg/PsCf6m0rOdtQDebEbpFbJrcwO2OlcB4i14nEUdMbKtXiJmgDYCGp kPvleTrmLELoxKZ1AZ68TiWocafyS+jNL9SrlK7jhPXapF6uTf9mFOmIh6pFeZuXnSkV HRvEa7UCnQ2NMC/ahkW3NpW2kNhWPstx1VptxVpeG87rTYCEShmZor/B8cmGfYvmSxkp xE4ujGUU+QbfFYi2r7dkYRivYqNqhvrf2bM09MvEVBZ0YnUENPyxtoTrpAqy5ZJLQ2ku FIkg== ARC-Authentication-Results: i=1; mx.google.com; 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 p1si12266690pgl.364.2019.02.27.11.31.05; Wed, 27 Feb 2019 11:31: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; 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 S1730215AbfB0TaP (ORCPT + 99 others); Wed, 27 Feb 2019 14:30:15 -0500 Received: from foss.arm.com ([217.140.101.70]:38696 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726419AbfB0TaP (ORCPT ); Wed, 27 Feb 2019 14:30:15 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 78898A78; Wed, 27 Feb 2019 11:30:14 -0800 (PST) Received: from [10.1.196.75] (e110467-lin.cambridge.arm.com [10.1.196.75]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id AD5F43F703; Wed, 27 Feb 2019 11:30:11 -0800 (PST) Subject: Re: [PATCH 04/13] iommu/mediatek: Add device_link between the consumer and the larb devices To: Yong Wu , Joerg Roedel , Greg Kroah-Hartman , Matthias Brugger , Rob Herring Cc: youlin.pei@mediatek.com, devicetree@vger.kernel.org, Nicolas Boichat , arnd@arndb.de, srv_heupstream@mediatek.com, Will Deacon , linux-kernel@vger.kernel.org, Tomasz Figa , iommu@lists.linux-foundation.org, linux-mediatek@lists.infradead.org, yingjoe.chen@mediatek.com, linux-arm-kernel@lists.infradead.org References: <1546318276-18993-1-git-send-email-yong.wu@mediatek.com> <1546318276-18993-5-git-send-email-yong.wu@mediatek.com> From: Robin Murphy Message-ID: <709d7d66-9610-eeb3-128e-e2156bcfb616@arm.com> Date: Wed, 27 Feb 2019 19:30:10 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: <1546318276-18993-5-git-send-email-yong.wu@mediatek.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 01/01/2019 04:51, Yong Wu wrote: > MediaTek IOMMU don't have its power-domain. all the consumer connect > with smi-larb, then connect with smi-common. > > M4U > | > smi-common > | > ------------- > | | ... > | | > larb1 larb2 > | | > vdec venc > > When the consumer works, it should enable the smi-larb's power which > also need enable the smi-common's power firstly. > > Thus, First of all, use the device link connect the consumer and the > smi-larbs. then add device link between the smi-larb and smi-common. > > This patch adds device_link between the consumer and the larbs. > > Suggested-by: Tomasz Figa > Signed-off-by: Yong Wu > --- > drivers/iommu/mtk_iommu.c | 15 +++++++++++++-- > drivers/iommu/mtk_iommu_v1.c | 14 ++++++++++++-- > 2 files changed, 25 insertions(+), 4 deletions(-) > > diff --git a/drivers/iommu/mtk_iommu.c b/drivers/iommu/mtk_iommu.c > index 202e41b..735ae8d 100644 > --- a/drivers/iommu/mtk_iommu.c > +++ b/drivers/iommu/mtk_iommu.c > @@ -247,6 +247,7 @@ static void mtk_iommu_config(struct mtk_iommu_data *data, > struct mtk_smi_larb_iommu *larb_mmu; > unsigned int larbid, portid; > struct iommu_fwspec *fwspec = dev_iommu_fwspec_get(dev); > + struct device_link *link; > int i; > > for (i = 0; i < fwspec->num_ids; ++i) { > @@ -257,10 +258,20 @@ static void mtk_iommu_config(struct mtk_iommu_data *data, > dev_dbg(dev, "%s iommu port: %d\n", > enable ? "enable" : "disable", portid); > > - if (enable) > + if (enable) { > larb_mmu->mmu |= MTK_SMI_MMU_EN(portid); > - else > + /* Link the consumer with the larb device(supplier) */ > + link = device_link_add(dev, larb_mmu->dev, > + DL_FLAG_PM_RUNTIME | > + DL_FLAG_AUTOREMOVE_CONSUMER); This looks technically wrong, since we get here from mtk_iommu_attach_device(), and in theory a device could get attached to any number of domains over its lifetime, so adding a link at this point when there's no corresponding cleanup on detach is definitely unbalanced. If you want this layer to manage the link on behalf of the consumer, it would probably be better to do it at the point of mtk_iommu_add_device(), and either track it for manual cleanup in mtk_iommu_remove_device() or rely on AUTOREMOVE_SUPPLIER. Robin. > + if (!link) { > + dev_err(dev, "Unable to link %s\n", > + dev_name(larb_mmu->dev)); > + return; > + } > + } else { > larb_mmu->mmu &= ~MTK_SMI_MMU_EN(portid); > + } > } > } > > diff --git a/drivers/iommu/mtk_iommu_v1.c b/drivers/iommu/mtk_iommu_v1.c > index 9386aee..022bad9 100644 > --- a/drivers/iommu/mtk_iommu_v1.c > +++ b/drivers/iommu/mtk_iommu_v1.c > @@ -201,6 +201,7 @@ static void mtk_iommu_config(struct mtk_iommu_data *data, > struct mtk_smi_larb_iommu *larb_mmu; > unsigned int larbid, portid; > struct iommu_fwspec *fwspec = dev_iommu_fwspec_get(dev); > + struct device_link *link; > int i; > > for (i = 0; i < fwspec->num_ids; ++i) { > @@ -211,10 +212,19 @@ static void mtk_iommu_config(struct mtk_iommu_data *data, > dev_dbg(dev, "%s iommu port: %d\n", > enable ? "enable" : "disable", portid); > > - if (enable) > + if (enable) { > larb_mmu->mmu |= MTK_SMI_MMU_EN(portid); > - else > + link = device_link_add(dev, larb_mmu->dev, > + DL_FLAG_PM_RUNTIME | > + DL_FLAG_AUTOREMOVE_CONSUMER); > + if (!link) { > + dev_err(dev, "Unable to link %s\n", > + dev_name(larb_mmu->dev)); > + return; > + } > + } else { > larb_mmu->mmu &= ~MTK_SMI_MMU_EN(portid); > + } > } > } > >