All of lore.kernel.org
 help / color / mirror / Atom feed
From: Robin Murphy <robin.murphy@arm.com>
To: Christoph Hellwig <hch@lst.de>
Cc: Joerg Roedel <joro@8bytes.org>,
	Catalin Marinas <catalin.marinas@arm.com>,
	Will Deacon <will.deacon@arm.com>,
	Tom Lendacky <thomas.lendacky@amd.com>,
	iommu@lists.linux-foundation.org,
	linux-arm-kernel@lists.infradead.org,
	linux-kernel@vger.kernel.org
Subject: Re: [PATCH 06/21] dma-iommu: use for_each_sg in iommu_dma_alloc
Date: Fri, 5 Apr 2019 19:08:34 +0100	[thread overview]
Message-ID: <e0143e7a-bfcd-36fb-ffe4-754cc1202fa3@arm.com> (raw)
In-Reply-To: <20190327080448.5500-7-hch@lst.de>

On 27/03/2019 08:04, Christoph Hellwig wrote:
> arch_dma_prep_coherent can handle physically contiguous ranges larger
> than PAGE_SIZE just fine, which means we don't need a page-based
> iterator.

Heh, I got several minutes into writing a "but highmem..." reply before 
finding csky's arch_dma_prep_coherent() implementation. And of course 
that's why it specifically takes a page instead of any addresses. In 
hindsight I now have no idea why I didn't just write the flush_page() 
logic to work that way in the first place...

Reviewed-by: Robin Murphy <robin.murphy@arm.com>

> Signed-off-by: Christoph Hellwig <hch@lst.de>
> ---
>   drivers/iommu/dma-iommu.c | 14 +++++---------
>   1 file changed, 5 insertions(+), 9 deletions(-)
> 
> diff --git a/drivers/iommu/dma-iommu.c b/drivers/iommu/dma-iommu.c
> index 77d704c8f565..f915cb7c46e6 100644
> --- a/drivers/iommu/dma-iommu.c
> +++ b/drivers/iommu/dma-iommu.c
> @@ -577,15 +577,11 @@ struct page **iommu_dma_alloc(struct device *dev, size_t size, gfp_t gfp,
>   		goto out_free_iova;
>   
>   	if (!(prot & IOMMU_CACHE)) {
> -		struct sg_mapping_iter miter;
> -		/*
> -		 * The CPU-centric flushing implied by SG_MITER_TO_SG isn't
> -		 * sufficient here, so skip it by using the "wrong" direction.
> -		 */
> -		sg_miter_start(&miter, sgt.sgl, sgt.orig_nents, SG_MITER_FROM_SG);
> -		while (sg_miter_next(&miter))
> -			arch_dma_prep_coherent(miter.page, PAGE_SIZE);
> -		sg_miter_stop(&miter);
> +		struct scatterlist *sg;
> +		int i;
> +
> +		for_each_sg(sgt.sgl, sg, sgt.orig_nents, i)
> +			arch_dma_prep_coherent(sg_page(sg), sg->length);
>   	}
>   
>   	if (iommu_map_sg(domain, iova, sgt.sgl, sgt.orig_nents, prot)
> 

WARNING: multiple messages have this Message-ID (diff)
From: Robin Murphy <robin.murphy@arm.com>
To: Christoph Hellwig <hch@lst.de>
Cc: Tom Lendacky <thomas.lendacky@amd.com>,
	Catalin Marinas <catalin.marinas@arm.com>,
	Will Deacon <will.deacon@arm.com>,
	linux-kernel@vger.kernel.org, iommu@lists.linux-foundation.org,
	linux-arm-kernel@lists.infradead.org
Subject: Re: [PATCH 06/21] dma-iommu: use for_each_sg in iommu_dma_alloc
Date: Fri, 5 Apr 2019 19:08:34 +0100	[thread overview]
Message-ID: <e0143e7a-bfcd-36fb-ffe4-754cc1202fa3@arm.com> (raw)
Message-ID: <20190405180834.ZDa5SVv8Mtu5pZ6tGBmTfIuCE15LBovG42bAAj_ZylM@z> (raw)
In-Reply-To: <20190327080448.5500-7-hch@lst.de>

On 27/03/2019 08:04, Christoph Hellwig wrote:
> arch_dma_prep_coherent can handle physically contiguous ranges larger
> than PAGE_SIZE just fine, which means we don't need a page-based
> iterator.

Heh, I got several minutes into writing a "but highmem..." reply before 
finding csky's arch_dma_prep_coherent() implementation. And of course 
that's why it specifically takes a page instead of any addresses. In 
hindsight I now have no idea why I didn't just write the flush_page() 
logic to work that way in the first place...

Reviewed-by: Robin Murphy <robin.murphy@arm.com>

> Signed-off-by: Christoph Hellwig <hch@lst.de>
> ---
>   drivers/iommu/dma-iommu.c | 14 +++++---------
>   1 file changed, 5 insertions(+), 9 deletions(-)
> 
> diff --git a/drivers/iommu/dma-iommu.c b/drivers/iommu/dma-iommu.c
> index 77d704c8f565..f915cb7c46e6 100644
> --- a/drivers/iommu/dma-iommu.c
> +++ b/drivers/iommu/dma-iommu.c
> @@ -577,15 +577,11 @@ struct page **iommu_dma_alloc(struct device *dev, size_t size, gfp_t gfp,
>   		goto out_free_iova;
>   
>   	if (!(prot & IOMMU_CACHE)) {
> -		struct sg_mapping_iter miter;
> -		/*
> -		 * The CPU-centric flushing implied by SG_MITER_TO_SG isn't
> -		 * sufficient here, so skip it by using the "wrong" direction.
> -		 */
> -		sg_miter_start(&miter, sgt.sgl, sgt.orig_nents, SG_MITER_FROM_SG);
> -		while (sg_miter_next(&miter))
> -			arch_dma_prep_coherent(miter.page, PAGE_SIZE);
> -		sg_miter_stop(&miter);
> +		struct scatterlist *sg;
> +		int i;
> +
> +		for_each_sg(sgt.sgl, sg, sgt.orig_nents, i)
> +			arch_dma_prep_coherent(sg_page(sg), sg->length);
>   	}
>   
>   	if (iommu_map_sg(domain, iova, sgt.sgl, sgt.orig_nents, prot)
> 
_______________________________________________
iommu mailing list
iommu@lists.linux-foundation.org
https://lists.linuxfoundation.org/mailman/listinfo/iommu

WARNING: multiple messages have this Message-ID (diff)
From: Robin Murphy <robin.murphy@arm.com>
To: Christoph Hellwig <hch@lst.de>
Cc: Tom Lendacky <thomas.lendacky@amd.com>,
	Catalin Marinas <catalin.marinas@arm.com>,
	Joerg Roedel <joro@8bytes.org>, Will Deacon <will.deacon@arm.com>,
	linux-kernel@vger.kernel.org, iommu@lists.linux-foundation.org,
	linux-arm-kernel@lists.infradead.org
Subject: Re: [PATCH 06/21] dma-iommu: use for_each_sg in iommu_dma_alloc
Date: Fri, 5 Apr 2019 19:08:34 +0100	[thread overview]
Message-ID: <e0143e7a-bfcd-36fb-ffe4-754cc1202fa3@arm.com> (raw)
In-Reply-To: <20190327080448.5500-7-hch@lst.de>

On 27/03/2019 08:04, Christoph Hellwig wrote:
> arch_dma_prep_coherent can handle physically contiguous ranges larger
> than PAGE_SIZE just fine, which means we don't need a page-based
> iterator.

Heh, I got several minutes into writing a "but highmem..." reply before 
finding csky's arch_dma_prep_coherent() implementation. And of course 
that's why it specifically takes a page instead of any addresses. In 
hindsight I now have no idea why I didn't just write the flush_page() 
logic to work that way in the first place...

Reviewed-by: Robin Murphy <robin.murphy@arm.com>

> Signed-off-by: Christoph Hellwig <hch@lst.de>
> ---
>   drivers/iommu/dma-iommu.c | 14 +++++---------
>   1 file changed, 5 insertions(+), 9 deletions(-)
> 
> diff --git a/drivers/iommu/dma-iommu.c b/drivers/iommu/dma-iommu.c
> index 77d704c8f565..f915cb7c46e6 100644
> --- a/drivers/iommu/dma-iommu.c
> +++ b/drivers/iommu/dma-iommu.c
> @@ -577,15 +577,11 @@ struct page **iommu_dma_alloc(struct device *dev, size_t size, gfp_t gfp,
>   		goto out_free_iova;
>   
>   	if (!(prot & IOMMU_CACHE)) {
> -		struct sg_mapping_iter miter;
> -		/*
> -		 * The CPU-centric flushing implied by SG_MITER_TO_SG isn't
> -		 * sufficient here, so skip it by using the "wrong" direction.
> -		 */
> -		sg_miter_start(&miter, sgt.sgl, sgt.orig_nents, SG_MITER_FROM_SG);
> -		while (sg_miter_next(&miter))
> -			arch_dma_prep_coherent(miter.page, PAGE_SIZE);
> -		sg_miter_stop(&miter);
> +		struct scatterlist *sg;
> +		int i;
> +
> +		for_each_sg(sgt.sgl, sg, sgt.orig_nents, i)
> +			arch_dma_prep_coherent(sg_page(sg), sg->length);
>   	}
>   
>   	if (iommu_map_sg(domain, iova, sgt.sgl, sgt.orig_nents, prot)
> 

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

  reply	other threads:[~2019-04-05 18:08 UTC|newest]

Thread overview: 168+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-03-27  8:04 implement generic dma_map_ops for IOMMUs v2 [rebase + resend] Christoph Hellwig
2019-03-27  8:04 ` Christoph Hellwig
2019-03-27  8:04 ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 01/21] arm64/iommu: handle non-remapped addresses in ->mmap and ->get_sgtable Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-05 17:16   ` Robin Murphy
2019-04-05 17:16     ` Robin Murphy
2019-04-05 17:16     ` Robin Murphy
2019-03-27  8:04 ` [PATCH 02/21] arm64/iommu: improve mmap bounds checking Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-05 17:30   ` Robin Murphy
2019-04-05 17:30     ` Robin Murphy
2019-04-05 17:30     ` Robin Murphy
2019-04-07  6:59     ` Christoph Hellwig
2019-04-07  6:59       ` Christoph Hellwig
2019-04-07  6:59       ` Christoph Hellwig
2019-04-09 15:12       ` Robin Murphy
2019-04-09 15:12         ` Robin Murphy
2019-04-09 15:12         ` Robin Murphy
2019-04-09 17:09         ` Christoph Hellwig
2019-04-09 17:09           ` Christoph Hellwig
2019-04-09 17:09           ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 04/21] dma-iommu: cleanup dma-iommu.h Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-05 17:42   ` Robin Murphy
2019-04-05 17:42     ` Robin Murphy
2019-04-05 17:42     ` Robin Murphy
2019-04-09 17:10     ` Christoph Hellwig
2019-04-09 17:10       ` Christoph Hellwig
2019-04-09 17:10       ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 05/21] dma-iommu: remove the flush_page callback Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-05 17:46   ` Robin Murphy
2019-04-05 17:46     ` Robin Murphy
2019-04-05 17:46     ` Robin Murphy
2019-03-27  8:04 ` [PATCH 06/21] dma-iommu: use for_each_sg in iommu_dma_alloc Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-05 18:08   ` Robin Murphy [this message]
2019-04-05 18:08     ` Robin Murphy
2019-04-05 18:08     ` Robin Murphy
     [not found] ` <20190327080448.5500-1-hch-jcswGhMUV9g@public.gmane.org>
2019-03-27  8:04   ` [PATCH 03/21] dma-mapping: add a Kconfig symbol to indicated arch_dma_prep_coherent presence Christoph Hellwig
2019-03-27  8:04     ` Christoph Hellwig
2019-03-27  8:04     ` Christoph Hellwig
2019-04-05 17:41     ` Robin Murphy
2019-04-05 17:41       ` Robin Murphy
2019-04-05 17:41       ` Robin Murphy
2019-03-27  8:04   ` [PATCH 07/21] dma-iommu: move the arm64 wrappers to common code Christoph Hellwig
2019-03-27  8:04     ` Christoph Hellwig
2019-03-27  8:04     ` Christoph Hellwig
2019-04-09 15:07     ` Robin Murphy
2019-04-09 15:07       ` Robin Murphy
2019-04-09 15:07       ` Robin Murphy
2019-04-09 17:15       ` Christoph Hellwig
2019-04-09 17:15         ` Christoph Hellwig
2019-04-09 17:15         ` Christoph Hellwig
     [not found]       ` <67573dd3-72c7-692d-bc1a-7edb49ff9551-5wv7dgnIgG8@public.gmane.org>
2019-04-09 17:23         ` Christoph Hellwig
2019-04-09 17:23           ` Christoph Hellwig
2019-04-09 17:23           ` Christoph Hellwig
2019-04-09 17:23           ` Christoph Hellwig
2019-04-09 17:33           ` Robin Murphy
2019-04-09 17:33             ` Robin Murphy
2019-04-09 17:33             ` Robin Murphy
2019-03-27  8:04 ` [PATCH 08/21] dma-iommu: refactor iommu_dma_mmap Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-09 15:29   ` Robin Murphy
2019-04-09 15:29     ` Robin Murphy
2019-04-09 15:29     ` Robin Murphy
     [not found]     ` <adf139e2-a595-fa08-e287-f358c06d7e91-5wv7dgnIgG8@public.gmane.org>
2019-04-09 17:25       ` Christoph Hellwig
2019-04-09 17:25         ` Christoph Hellwig
2019-04-09 17:25         ` Christoph Hellwig
2019-04-09 17:25         ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 09/21] dma-iommu: refactor iommu_dma_get_sgtable Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-09 15:49   ` Robin Murphy
2019-04-09 15:49     ` Robin Murphy
2019-04-09 15:49     ` Robin Murphy
2019-04-09 17:26     ` Christoph Hellwig
2019-04-09 17:26       ` Christoph Hellwig
2019-04-09 17:26       ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 10/21] dma-iommu: move __iommu_dma_map Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-09 15:54   ` Robin Murphy
2019-04-09 15:54     ` Robin Murphy
2019-04-09 15:54     ` Robin Murphy
2019-03-27  8:04 ` [PATCH 11/21] dma-iommu: refactor page array remap helpers Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-09 16:38   ` Robin Murphy
2019-04-09 16:38     ` Robin Murphy
2019-04-09 16:38     ` Robin Murphy
2019-03-27  8:04 ` [PATCH 12/21] dma-iommu: factor atomic pool allocations into helpers Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-09 17:59   ` Robin Murphy
2019-04-09 17:59     ` Robin Murphy
2019-04-09 17:59     ` Robin Murphy
2019-04-10  6:11     ` Christoph Hellwig
2019-04-10  6:11       ` Christoph Hellwig
2019-04-10  6:11       ` Christoph Hellwig
2019-04-17  6:33       ` Christoph Hellwig
2019-04-17  6:33         ` Christoph Hellwig
2019-04-17  6:33         ` Christoph Hellwig
2019-04-17 11:54         ` Robin Murphy
2019-04-17 11:54           ` Robin Murphy
2019-04-17 11:54           ` Robin Murphy
2019-04-18 15:06         ` Robin Murphy
2019-04-18 15:06           ` Robin Murphy
2019-04-18 15:06           ` Robin Murphy
2019-04-18 16:35           ` Christoph Hellwig
2019-04-18 16:35             ` Christoph Hellwig
2019-04-18 16:35             ` Christoph Hellwig
2019-04-18 16:35             ` Christoph Hellwig
2019-04-18 16:41             ` Robin Murphy
2019-04-18 16:41               ` Robin Murphy
2019-04-18 16:41               ` Robin Murphy
2019-04-19  9:07               ` Christoph Hellwig
2019-04-19  9:07                 ` Christoph Hellwig
2019-04-19  9:07                 ` Christoph Hellwig
2019-04-19  9:07                 ` Christoph Hellwig
2019-04-23  9:48                 ` Robin Murphy
2019-04-23  9:48                   ` Robin Murphy
2019-04-23  9:48                   ` Robin Murphy
2019-04-18 18:15             ` Robin Murphy
2019-04-18 18:15               ` Robin Murphy
2019-04-18 18:15               ` Robin Murphy
2019-04-19  8:23               ` Christoph Hellwig
2019-04-19  8:23                 ` Christoph Hellwig
2019-04-19  8:23                 ` Christoph Hellwig
2019-04-19  8:23                 ` Christoph Hellwig
     [not found]                 ` <20190419082348.GA22299-jcswGhMUV9g@public.gmane.org>
2019-04-23 10:01                   ` Robin Murphy
2019-04-23 10:01                     ` Robin Murphy
2019-04-23 10:01                     ` Robin Murphy
2019-04-23 10:01                     ` Robin Murphy
2019-04-23 14:52                     ` Christoph Hellwig
2019-04-23 14:52                       ` Christoph Hellwig
2019-04-23 14:52                       ` Christoph Hellwig
2019-04-29 11:49                     ` Christoph Hellwig
2019-04-29 11:49                       ` Christoph Hellwig
2019-04-29 11:49                       ` Christoph Hellwig
2019-04-29 12:02                       ` Robin Murphy
2019-04-29 12:02                         ` Robin Murphy
2019-04-29 12:02                         ` Robin Murphy
2019-04-29 12:02                         ` Robin Murphy
2019-04-22 18:03               ` Christoph Hellwig
2019-04-22 18:03                 ` Christoph Hellwig
2019-04-22 18:03                 ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 13/21] dma-iommu: factor contiguous " Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 14/21] dma-iommu: refactor iommu_dma_free Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 15/21] dma-iommu: don't remap contiguous allocations for coherent devices Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 16/21] dma-iommu: factor contiguous remapped allocations into helpers Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 17/21] dma-iommu: refactor iommu_dma_alloc Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 18/21] dma-iommu: don't depend on CONFIG_DMA_DIRECT_REMAP Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 19/21] dma-iommu: switch copyright boilerplace to SPDX Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-03-27  8:04 ` [PATCH 20/21] arm64: switch copyright boilerplace to SPDX in dma-mapping.c Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
2019-04-01  6:28   ` Mukesh Ojha
2019-04-01  6:28     ` Mukesh Ojha
2019-04-01  9:39     ` Robin Murphy
2019-04-01  9:39       ` Robin Murphy
2019-03-27  8:04 ` [PATCH 21/21] arm64: trim includes " Christoph Hellwig
2019-03-27  8:04   ` Christoph Hellwig
  -- strict thread matches above, loose matches on Subject: below --
2019-02-13 18:28 implement generic dma_map_ops for IOMMUs v2 Christoph Hellwig
2019-02-13 18:29 ` [PATCH 06/21] dma-iommu: use for_each_sg in iommu_dma_alloc Christoph Hellwig
2019-02-13 18:29   ` Christoph Hellwig

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=e0143e7a-bfcd-36fb-ffe4-754cc1202fa3@arm.com \
    --to=robin.murphy@arm.com \
    --cc=catalin.marinas@arm.com \
    --cc=hch@lst.de \
    --cc=iommu@lists.linux-foundation.org \
    --cc=joro@8bytes.org \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=thomas.lendacky@amd.com \
    --cc=will.deacon@arm.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.