Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2997109AbdDZJ0t (ORCPT ); Wed, 26 Apr 2017 05:26:49 -0400 Received: from mail-wm0-f68.google.com ([74.125.82.68]:33433 "EHLO mail-wm0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1957819AbdDZJMk (ORCPT ); Wed, 26 Apr 2017 05:12:40 -0400 MIME-Version: 1.0 In-Reply-To: <1493114272-30093-1-git-send-email-sunil.kovvuri@gmail.com> References: <1493114272-30093-1-git-send-email-sunil.kovvuri@gmail.com> From: Sunil Kovvuri Date: Wed, 26 Apr 2017 14:42:38 +0530 Message-ID: Subject: Re: [PATCH v2] iommu/arm-smmu: Return IOVA in iova_to_phys when SMMU is bypassed To: Will Deacon , iommu@lists.linux-foundation.org Cc: LAKML , LKML , robert.richter@cavium.com, Sunil Goutham , jcm@redhat.com Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1828 Lines: 58 On Tue, Apr 25, 2017 at 3:27 PM, wrote: > From: Sunil Goutham > > For software initiated address translation, when domain type is > IOMMU_DOMAIN_IDENTITY i.e SMMU is bypassed, mimic HW behavior > i.e return the same IOVA as translated address. > > This patch is an extension to Will Deacon's patchset > "Implement SMMU passthrough using the default domain". > > Signed-off-by: Sunil Goutham > --- > > V2 > - As per Will's suggestion applied fix to SMMUv3 driver as well. > > drivers/iommu/arm-smmu-v3.c | 3 +++ > drivers/iommu/arm-smmu.c | 3 +++ > 2 files changed, 6 insertions(+) > > diff --git a/drivers/iommu/arm-smmu-v3.c b/drivers/iommu/arm-smmu-v3.c > index 05b4592..d412bdd 100644 > --- a/drivers/iommu/arm-smmu-v3.c > +++ b/drivers/iommu/arm-smmu-v3.c > @@ -1714,6 +1714,9 @@ arm_smmu_iova_to_phys(struct iommu_domain *domain, dma_addr_t iova) > struct arm_smmu_domain *smmu_domain = to_smmu_domain(domain); > struct io_pgtable_ops *ops = smmu_domain->pgtbl_ops; > > + if (domain->type == IOMMU_DOMAIN_IDENTITY) > + return iova; > + > if (!ops) > return 0; > > diff --git a/drivers/iommu/arm-smmu.c b/drivers/iommu/arm-smmu.c > index bfab4f7..81088cd 100644 > --- a/drivers/iommu/arm-smmu.c > +++ b/drivers/iommu/arm-smmu.c > @@ -1459,6 +1459,9 @@ static phys_addr_t arm_smmu_iova_to_phys(struct iommu_domain *domain, > struct arm_smmu_domain *smmu_domain = to_smmu_domain(domain); > struct io_pgtable_ops *ops= smmu_domain->pgtbl_ops; > > + if (domain->type == IOMMU_DOMAIN_IDENTITY) > + return iova; > + > if (!ops) > return 0; > > -- > 2.7.4 > Will, if you are okay with the patch, can you please ACK. Thanks, Sunil.