From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752866AbbJZFX4 (ORCPT ); Mon, 26 Oct 2015 01:23:56 -0400 Received: from mailgw01.mediatek.com ([218.249.47.110]:24048 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1750790AbbJZFXy (ORCPT ); Mon, 26 Oct 2015 01:23:54 -0400 X-Listener-Flag: 11101 Message-ID: <1445837021.24436.8.camel@mhfsdcap03> Subject: Re: [PATCH v5 5/6] iommu/mediatek: Add mt8173 IOMMU driver From: Yong Wu To: Joerg Roedel CC: Thierry Reding , Mark Rutland , Matthias Brugger , "Robin Murphy" , Will Deacon , "Daniel Kurtz" , Tomasz Figa , Lucas Stach , Rob Herring , "Catalin Marinas" , , Sasha Hauer , , , , , , , , , Sricharan R , , , Date: Mon, 26 Oct 2015 13:23:41 +0800 In-Reply-To: <20151014125309.GO27420@8bytes.org> References: <1444357388-30257-1-git-send-email-yong.wu@mediatek.com> <1444357388-30257-6-git-send-email-yong.wu@mediatek.com> <20151014125309.GO27420@8bytes.org> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.2.3-0ubuntu6 Content-Transfer-Encoding: 7bit MIME-Version: 1.0 X-MTK: N Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 2015-10-14 at 14:53 +0200, Joerg Roedel wrote: > On Fri, Oct 09, 2015 at 10:23:07AM +0800, Yong Wu wrote: > > + /* > > + * There is a domain for each a iommu device in normal case. > > + * But MTK only has one iommu domain called the m4u domain which all > > + * the multimedia HW share. Here we reserve one as the m4u domain and > > + * free the others. > > + * > > + * And the attach_device that from __iommu_setup_dma_ops > > + * will be called earlier than probe. > > + */ > > Okay, with this being the case, you need to put all devices behind one > IOMMU into the same iommu-group, because the IOMMU can't really isolate > the devices from each other. > > > +static int mtk_iommu_add_device(struct device *dev) > > +{ > > + struct iommu_group *group; > > + struct mtk_iommu_client_priv *priv; > > + struct mtk_iommu_domain *m4udom; > > + struct iommu_domain *domain; > > + int ret; > > + > > + if (!dev->archdata.iommu) /* Not a iommu client device */ > > + return -ENODEV; > > + > > + group = iommu_group_get(dev); > > + if (!group) { > > + group = iommu_group_alloc(); > > + if (IS_ERR(group)) { > > + dev_err(dev, "Failed to allocate IOMMU group\n"); > > + return PTR_ERR(group); > > + } > > + } > > + > > + ret = iommu_group_add_device(group, dev); > > + if (ret) { > > + dev_err(dev, "Failed to add IOMMU group\n"); > > + goto err_group_put; > > + } > > + > > + domain = iommu_get_domain_for_dev(dev); > > + if (!domain) { > > + /* > > + * Get the m4u iommu domain from the m4u device. > > + * Attach all the client devices into the m4u domain. > > + */ > > + priv = dev->archdata.iommu; > > + m4udom = dev_get_drvdata(priv->m4udev); > > + ret = iommu_attach_group(&m4udom->domain, group); > > + if (ret) > > + dev_err(dev, "Failed to attach IOMMU group\n"); > > + } > > + > > +err_group_put: > > + iommu_group_put(group); > > + return ret; > > +} > > Here it looks like you are allocating one group for each device. As I > said, all devices need to be in one group. > > Joerg > Thanks for this suggestion. I have put all the iommu client devices into the same iommu group, the code looks like below. And I will send this in the next version after the Short descriptor is reviewed. static int mtk_iommu_add_device(struct device *dev) { struct iommu_group *group; struct mtk_iommu_client_priv *priv; struct mtk_iommu_domain *m4udom; struct iommu_domain *domain; int ret; priv = dev->archdata.iommu; if (!priv) /* Not a iommu client device */ return -ENODEV; m4udom = dev_get_drvdata(priv->m4udev); group = iommu_group_get(dev); if (!group) { /* * All the iommu client devices are in the m4u domain, * they all are in the same m4u iommu-group too here. */ if (!m4udom->m4u_group) { group = iommu_group_alloc(); if (IS_ERR(group)) { dev_err(dev, "Failed to allocate IOMMU group\n"); return PTR_ERR(group); } m4udom->m4u_group = group; } else { group = m4udom->m4u_group; } } ret = iommu_group_add_device(group, dev); if (ret) { dev_err(dev, "Failed to add IOMMU group\n"); goto err_group_put; } domain = iommu_get_domain_for_dev(dev); if (!domain) ret = iommu_attach_group(&m4udom->domain, group); err_group_put: iommu_group_put(group); return ret; }