All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Alex Xu \(Hello71\) via iommu" <iommu@lists.linux-foundation.org>
To: Christoph Hellwig <hch@lst.de>, iommu@lists.linux-foundation.org
Cc: thomas.lendacky@amd.com, robin.murphy@arm.com
Subject: Re: [PATCH] dma-mapping: move pgprot_decrypted out of dma_pgprot
Date: Thu, 31 Mar 2022 12:13:19 -0400	[thread overview]
Message-ID: <1648742102.xmws9oicm6.none@localhost> (raw)
In-Reply-To: <20220331060627.2872150-1-hch@lst.de>

Excerpts from Christoph Hellwig's message of March 31, 2022 2:06 am:
> pgprot_decrypted is used by AMD SME systems to allow access to memory
> that was set to not encrypted using set_memory_decrypted.  That only
> happens for dma-direct memory as the IOMMU solves the addressing
> challenges for the encryption bit using its own remapping.
> 
> Move the pgprot_decrypted call out of dma_pgprot which is also used
> by the IOMMU mappings and into dma-direct so that it is only used with
> memory that was set decrypted.
> 
> Fixes: 5ff79fddf0ef ("dma-mapping: remove CONFIG_DMA_REMAP")
> Reported-by: Alex Xu (Hello71) <alex_y_xu@yahoo.ca>
> Signed-off-by: Christoph Hellwig <hch@lst.de>
> ---
>  kernel/dma/direct.c  | 10 ++++++++--
>  kernel/dma/mapping.c |  2 --
>  2 files changed, 8 insertions(+), 4 deletions(-)
> 
> diff --git a/kernel/dma/direct.c b/kernel/dma/direct.c
> index 35a1d29d6a2e9..9743c6ccce1a9 100644
> --- a/kernel/dma/direct.c
> +++ b/kernel/dma/direct.c
> @@ -277,12 +277,16 @@ void *dma_direct_alloc(struct device *dev, size_t size,
>  	}
>  
>  	if (remap) {
> +		pgprot_t prot = dma_pgprot(dev, PAGE_KERNEL, attrs);
> +
> +		if (force_dma_unencrypted(dev))
> +			prot = pgprot_decrypted(prot);
> +
>  		/* remove any dirty cache lines on the kernel alias */
>  		arch_dma_prep_coherent(page, size);
>  
>  		/* create a coherent mapping */
> -		ret = dma_common_contiguous_remap(page, size,
> -				dma_pgprot(dev, PAGE_KERNEL, attrs),
> +		ret = dma_common_contiguous_remap(page, size, prot,
>  				__builtin_return_address(0));
>  		if (!ret)
>  			goto out_free_pages;
> @@ -535,6 +539,8 @@ int dma_direct_mmap(struct device *dev, struct vm_area_struct *vma,
>  	int ret = -ENXIO;
>  
>  	vma->vm_page_prot = dma_pgprot(dev, vma->vm_page_prot, attrs);
> +	if (force_dma_unencrypted(dev))
> +		vma->vm_page_prot = pgprot_decrypted(vma->vm_page_prot);
>  
>  	if (dma_mmap_from_dev_coherent(dev, vma, cpu_addr, size, &ret))
>  		return ret;
> diff --git a/kernel/dma/mapping.c b/kernel/dma/mapping.c
> index 559461a826bab..db7244291b745 100644
> --- a/kernel/dma/mapping.c
> +++ b/kernel/dma/mapping.c
> @@ -407,8 +407,6 @@ EXPORT_SYMBOL(dma_get_sgtable_attrs);
>   */
>  pgprot_t dma_pgprot(struct device *dev, pgprot_t prot, unsigned long attrs)
>  {
> -	if (force_dma_unencrypted(dev))
> -		prot = pgprot_decrypted(prot);
>  	if (dev_is_dma_coherent(dev))
>  		return prot;
>  #ifdef CONFIG_ARCH_HAS_DMA_WRITE_COMBINE
> -- 
> 2.30.2
> 
> 

Tested-by: Alex Xu (Hello71) <alex_y_xu@yahoo.ca>

Thanks,
Alex.
_______________________________________________
iommu mailing list
iommu@lists.linux-foundation.org
https://lists.linuxfoundation.org/mailman/listinfo/iommu

  reply	other threads:[~2022-03-31 16:23 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-03-31  6:06 [PATCH] dma-mapping: move pgprot_decrypted out of dma_pgprot Christoph Hellwig
2022-03-31 16:13 ` Alex Xu (Hello71) via iommu [this message]
2022-03-31 16:26   ` 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=1648742102.xmws9oicm6.none@localhost \
    --to=iommu@lists.linux-foundation.org \
    --cc=alex_y_xu@yahoo.ca \
    --cc=hch@lst.de \
    --cc=robin.murphy@arm.com \
    --cc=thomas.lendacky@amd.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.