All of lore.kernel.org
 help / color / mirror / Atom feed
From: John Hubbard <jhubbard@nvidia.com>
To: Logan Gunthorpe <logang@deltatee.com>,
	<linux-kernel@vger.kernel.org>, <linux-nvme@lists.infradead.org>,
	<linux-block@vger.kernel.org>, <linux-pci@vger.kernel.org>,
	<linux-mm@kvack.org>, <iommu@lists.linux-foundation.org>
Cc: "Stephen Bates" <sbates@raithlin.com>,
	"Christoph Hellwig" <hch@lst.de>,
	"Dan Williams" <dan.j.williams@intel.com>,
	"Jason Gunthorpe" <jgg@ziepe.ca>,
	"Christian König" <christian.koenig@amd.com>,
	"Don Dutile" <ddutile@redhat.com>,
	"Matthew Wilcox" <willy@infradead.org>,
	"Daniel Vetter" <daniel.vetter@ffwll.ch>,
	"Jakowski Andrzej" <andrzej.jakowski@intel.com>,
	"Minturn Dave B" <dave.b.minturn@intel.com>,
	"Jason Ekstrand" <jason@jlekstrand.net>,
	"Dave Hansen" <dave.hansen@linux.intel.com>,
	"Xiong Jianxin" <jianxin.xiong@intel.com>,
	"Bjorn Helgaas" <helgaas@kernel.org>,
	"Ira Weiny" <ira.weiny@intel.com>,
	"Robin Murphy" <robin.murphy@arm.com>
Subject: Re: [PATCH 07/16] PCI/P2PDMA: Make pci_p2pdma_map_type() non-static
Date: Sun, 2 May 2021 15:44:06 -0700	[thread overview]
Message-ID: <c2712ed0-6d44-014a-f669-dfda63d1c861@nvidia.com> (raw)
In-Reply-To: <20210408170123.8788-8-logang@deltatee.com>

On 4/8/21 10:01 AM, Logan Gunthorpe wrote:
> pci_p2pdma_map_type() will be needed by the dma-iommu map_sg
> implementation because it will need to determine the mapping type
> ahead of actually doing the mapping to create the actual iommu mapping.
> 
> Signed-off-by: Logan Gunthorpe <logang@deltatee.com>
> ---
>   drivers/pci/p2pdma.c       | 34 +++++++++++++++++++++++-----------
>   include/linux/pci-p2pdma.h | 15 +++++++++++++++
>   2 files changed, 38 insertions(+), 11 deletions(-)
> 
> diff --git a/drivers/pci/p2pdma.c b/drivers/pci/p2pdma.c
> index bcb1a6d6119d..38c93f57a941 100644
> --- a/drivers/pci/p2pdma.c
> +++ b/drivers/pci/p2pdma.c
> @@ -20,13 +20,6 @@
>   #include <linux/seq_buf.h>
>   #include <linux/xarray.h>
>   
> -enum pci_p2pdma_map_type {
> -	PCI_P2PDMA_MAP_UNKNOWN = 0,
> -	PCI_P2PDMA_MAP_NOT_SUPPORTED,
> -	PCI_P2PDMA_MAP_BUS_ADDR,
> -	PCI_P2PDMA_MAP_THRU_HOST_BRIDGE,
> -};
> -
>   struct pci_p2pdma {
>   	struct gen_pool *pool;
>   	bool p2pmem_published;
> @@ -822,13 +815,30 @@ void pci_p2pmem_publish(struct pci_dev *pdev, bool publish)
>   }
>   EXPORT_SYMBOL_GPL(pci_p2pmem_publish);
>   
> -static enum pci_p2pdma_map_type pci_p2pdma_map_type(struct dev_pagemap *pgmap,
> -						    struct device *dev)
> +/**
> + * pci_p2pdma_map_type - return the type of mapping that should be used for
> + *	a given device and pgmap
> + * @pgmap: the pagemap of a page to determine the mapping type for
> + * @dev: device that is mapping the page
> + * @dma_attrs: the attributes passed to the dma_map operation --
> + *	this is so they can be checked to ensure P2PDMA pages were not
> + *	introduced into an incorrect interface (like dma_map_sg). *
> + *
> + * Returns one of:
> + *	PCI_P2PDMA_MAP_NOT_SUPPORTED - The mapping should not be done
> + *	PCI_P2PDMA_MAP_BUS_ADDR - The mapping should use the PCI bus address
> + *	PCI_P2PDMA_MAP_THRU_HOST_BRIDGE - The mapping should be done directly
> + */
> +enum pci_p2pdma_map_type pci_p2pdma_map_type(struct dev_pagemap *pgmap,
> +		struct device *dev, unsigned long dma_attrs)
>   {
>   	struct pci_dev *provider = to_p2p_pgmap(pgmap)->provider;
>   	enum pci_p2pdma_map_type ret;
>   	struct pci_dev *client;
>   
> +	WARN_ONCE(!(dma_attrs & __DMA_ATTR_PCI_P2PDMA),
> +		  "PCI P2PDMA pages were mapped with dma_map_sg!");

This really ought to also return -EINVAL, assuming that my review suggestions
about return types, in earlier patches, are acceptable.

> +
>   	if (!provider->p2pdma)
>   		return PCI_P2PDMA_MAP_NOT_SUPPORTED;
>   
> @@ -879,7 +889,8 @@ int pci_p2pdma_map_sg_attrs(struct device *dev, struct scatterlist *sg,
>   	struct pci_p2pdma_pagemap *p2p_pgmap =
>   		to_p2p_pgmap(sg_page(sg)->pgmap);
>   
> -	switch (pci_p2pdma_map_type(sg_page(sg)->pgmap, dev)) {
> +	switch (pci_p2pdma_map_type(sg_page(sg)->pgmap, dev,
> +				    __DMA_ATTR_PCI_P2PDMA)) {
>   	case PCI_P2PDMA_MAP_THRU_HOST_BRIDGE:
>   		return dma_map_sg_attrs(dev, sg, nents, dir, attrs);
>   	case PCI_P2PDMA_MAP_BUS_ADDR:
> @@ -904,7 +915,8 @@ void pci_p2pdma_unmap_sg_attrs(struct device *dev, struct scatterlist *sg,
>   {
>   	enum pci_p2pdma_map_type map_type;
>   
> -	map_type = pci_p2pdma_map_type(sg_page(sg)->pgmap, dev);
> +	map_type = pci_p2pdma_map_type(sg_page(sg)->pgmap, dev,
> +				       __DMA_ATTR_PCI_P2PDMA);

These areas might end up looking a bit different, if my suggestion about
applying pci_dev type safety throughout are accepted.

The patch looks generally correct, aside from these details.

thanks,
-- 
John Hubbard
NVIDIA

>   
>   	if (map_type == PCI_P2PDMA_MAP_THRU_HOST_BRIDGE)
>   		dma_unmap_sg_attrs(dev, sg, nents, dir, attrs);
> diff --git a/include/linux/pci-p2pdma.h b/include/linux/pci-p2pdma.h
> index 8318a97c9c61..a06072ac3a52 100644
> --- a/include/linux/pci-p2pdma.h
> +++ b/include/linux/pci-p2pdma.h
> @@ -16,6 +16,13 @@
>   struct block_device;
>   struct scatterlist;
>   
> +enum pci_p2pdma_map_type {
> +	PCI_P2PDMA_MAP_UNKNOWN = 0,
> +	PCI_P2PDMA_MAP_NOT_SUPPORTED,
> +	PCI_P2PDMA_MAP_BUS_ADDR,
> +	PCI_P2PDMA_MAP_THRU_HOST_BRIDGE,
> +};
> +
>   #ifdef CONFIG_PCI_P2PDMA
>   int pci_p2pdma_add_resource(struct pci_dev *pdev, int bar, size_t size,
>   		u64 offset);
> @@ -30,6 +37,8 @@ struct scatterlist *pci_p2pmem_alloc_sgl(struct pci_dev *pdev,
>   					 unsigned int *nents, u32 length);
>   void pci_p2pmem_free_sgl(struct pci_dev *pdev, struct scatterlist *sgl);
>   void pci_p2pmem_publish(struct pci_dev *pdev, bool publish);
> +enum pci_p2pdma_map_type pci_p2pdma_map_type(struct dev_pagemap *pgmap,
> +		struct device *dev, unsigned long dma_attrs);
>   int pci_p2pdma_map_sg_attrs(struct device *dev, struct scatterlist *sg,
>   		int nents, enum dma_data_direction dir, unsigned long attrs);
>   void pci_p2pdma_unmap_sg_attrs(struct device *dev, struct scatterlist *sg,
> @@ -83,6 +92,12 @@ static inline void pci_p2pmem_free_sgl(struct pci_dev *pdev,
>   static inline void pci_p2pmem_publish(struct pci_dev *pdev, bool publish)
>   {
>   }
> +static inline enum pci_p2pdma_map_type pci_p2pdma_map_type(
> +		struct dev_pagemap *pgmap, struct device *dev,
> +		unsigned long dma_attrs)
> +{
> +	return PCI_P2PDMA_MAP_NOT_SUPPORTED;
> +}
>   static inline int pci_p2pdma_map_sg_attrs(struct device *dev,
>   		struct scatterlist *sg, int nents, enum dma_data_direction dir,
>   		unsigned long attrs)
> 


WARNING: multiple messages have this Message-ID (diff)
From: John Hubbard <jhubbard@nvidia.com>
To: Logan Gunthorpe <logang@deltatee.com>,
	<linux-kernel@vger.kernel.org>, <linux-nvme@lists.infradead.org>,
	<linux-block@vger.kernel.org>, <linux-pci@vger.kernel.org>,
	<linux-mm@kvack.org>, <iommu@lists.linux-foundation.org>
Cc: "Stephen Bates" <sbates@raithlin.com>,
	"Christoph Hellwig" <hch@lst.de>,
	"Dan Williams" <dan.j.williams@intel.com>,
	"Jason Gunthorpe" <jgg@ziepe.ca>,
	"Christian König" <christian.koenig@amd.com>,
	"Don Dutile" <ddutile@redhat.com>,
	"Matthew Wilcox" <willy@infradead.org>,
	"Daniel Vetter" <daniel.vetter@ffwll.ch>,
	"Jakowski Andrzej" <andrzej.jakowski@intel.com>,
	"Minturn Dave B" <dave.b.minturn@intel.com>,
	"Jason Ekstrand" <jason@jlekstrand.net>,
	"Dave Hansen" <dave.hansen@linux.intel.com>,
	"Xiong Jianxin" <jianxin.xiong@intel.com>,
	"Bjorn Helgaas" <helgaas@kernel.org>,
	"Ira Weiny" <ira.weiny@intel.com>,
	"Robin Murphy" <robin.murphy@arm.com>
Subject: Re: [PATCH 07/16] PCI/P2PDMA: Make pci_p2pdma_map_type() non-static
Date: Sun, 2 May 2021 15:44:06 -0700	[thread overview]
Message-ID: <c2712ed0-6d44-014a-f669-dfda63d1c861@nvidia.com> (raw)
In-Reply-To: <20210408170123.8788-8-logang@deltatee.com>

On 4/8/21 10:01 AM, Logan Gunthorpe wrote:
> pci_p2pdma_map_type() will be needed by the dma-iommu map_sg
> implementation because it will need to determine the mapping type
> ahead of actually doing the mapping to create the actual iommu mapping.
> 
> Signed-off-by: Logan Gunthorpe <logang@deltatee.com>
> ---
>   drivers/pci/p2pdma.c       | 34 +++++++++++++++++++++++-----------
>   include/linux/pci-p2pdma.h | 15 +++++++++++++++
>   2 files changed, 38 insertions(+), 11 deletions(-)
> 
> diff --git a/drivers/pci/p2pdma.c b/drivers/pci/p2pdma.c
> index bcb1a6d6119d..38c93f57a941 100644
> --- a/drivers/pci/p2pdma.c
> +++ b/drivers/pci/p2pdma.c
> @@ -20,13 +20,6 @@
>   #include <linux/seq_buf.h>
>   #include <linux/xarray.h>
>   
> -enum pci_p2pdma_map_type {
> -	PCI_P2PDMA_MAP_UNKNOWN = 0,
> -	PCI_P2PDMA_MAP_NOT_SUPPORTED,
> -	PCI_P2PDMA_MAP_BUS_ADDR,
> -	PCI_P2PDMA_MAP_THRU_HOST_BRIDGE,
> -};
> -
>   struct pci_p2pdma {
>   	struct gen_pool *pool;
>   	bool p2pmem_published;
> @@ -822,13 +815,30 @@ void pci_p2pmem_publish(struct pci_dev *pdev, bool publish)
>   }
>   EXPORT_SYMBOL_GPL(pci_p2pmem_publish);
>   
> -static enum pci_p2pdma_map_type pci_p2pdma_map_type(struct dev_pagemap *pgmap,
> -						    struct device *dev)
> +/**
> + * pci_p2pdma_map_type - return the type of mapping that should be used for
> + *	a given device and pgmap
> + * @pgmap: the pagemap of a page to determine the mapping type for
> + * @dev: device that is mapping the page
> + * @dma_attrs: the attributes passed to the dma_map operation --
> + *	this is so they can be checked to ensure P2PDMA pages were not
> + *	introduced into an incorrect interface (like dma_map_sg). *
> + *
> + * Returns one of:
> + *	PCI_P2PDMA_MAP_NOT_SUPPORTED - The mapping should not be done
> + *	PCI_P2PDMA_MAP_BUS_ADDR - The mapping should use the PCI bus address
> + *	PCI_P2PDMA_MAP_THRU_HOST_BRIDGE - The mapping should be done directly
> + */
> +enum pci_p2pdma_map_type pci_p2pdma_map_type(struct dev_pagemap *pgmap,
> +		struct device *dev, unsigned long dma_attrs)
>   {
>   	struct pci_dev *provider = to_p2p_pgmap(pgmap)->provider;
>   	enum pci_p2pdma_map_type ret;
>   	struct pci_dev *client;
>   
> +	WARN_ONCE(!(dma_attrs & __DMA_ATTR_PCI_P2PDMA),
> +		  "PCI P2PDMA pages were mapped with dma_map_sg!");

This really ought to also return -EINVAL, assuming that my review suggestions
about return types, in earlier patches, are acceptable.

> +
>   	if (!provider->p2pdma)
>   		return PCI_P2PDMA_MAP_NOT_SUPPORTED;
>   
> @@ -879,7 +889,8 @@ int pci_p2pdma_map_sg_attrs(struct device *dev, struct scatterlist *sg,
>   	struct pci_p2pdma_pagemap *p2p_pgmap =
>   		to_p2p_pgmap(sg_page(sg)->pgmap);
>   
> -	switch (pci_p2pdma_map_type(sg_page(sg)->pgmap, dev)) {
> +	switch (pci_p2pdma_map_type(sg_page(sg)->pgmap, dev,
> +				    __DMA_ATTR_PCI_P2PDMA)) {
>   	case PCI_P2PDMA_MAP_THRU_HOST_BRIDGE:
>   		return dma_map_sg_attrs(dev, sg, nents, dir, attrs);
>   	case PCI_P2PDMA_MAP_BUS_ADDR:
> @@ -904,7 +915,8 @@ void pci_p2pdma_unmap_sg_attrs(struct device *dev, struct scatterlist *sg,
>   {
>   	enum pci_p2pdma_map_type map_type;
>   
> -	map_type = pci_p2pdma_map_type(sg_page(sg)->pgmap, dev);
> +	map_type = pci_p2pdma_map_type(sg_page(sg)->pgmap, dev,
> +				       __DMA_ATTR_PCI_P2PDMA);

These areas might end up looking a bit different, if my suggestion about
applying pci_dev type safety throughout are accepted.

The patch looks generally correct, aside from these details.

thanks,
-- 
John Hubbard
NVIDIA

>   
>   	if (map_type == PCI_P2PDMA_MAP_THRU_HOST_BRIDGE)
>   		dma_unmap_sg_attrs(dev, sg, nents, dir, attrs);
> diff --git a/include/linux/pci-p2pdma.h b/include/linux/pci-p2pdma.h
> index 8318a97c9c61..a06072ac3a52 100644
> --- a/include/linux/pci-p2pdma.h
> +++ b/include/linux/pci-p2pdma.h
> @@ -16,6 +16,13 @@
>   struct block_device;
>   struct scatterlist;
>   
> +enum pci_p2pdma_map_type {
> +	PCI_P2PDMA_MAP_UNKNOWN = 0,
> +	PCI_P2PDMA_MAP_NOT_SUPPORTED,
> +	PCI_P2PDMA_MAP_BUS_ADDR,
> +	PCI_P2PDMA_MAP_THRU_HOST_BRIDGE,
> +};
> +
>   #ifdef CONFIG_PCI_P2PDMA
>   int pci_p2pdma_add_resource(struct pci_dev *pdev, int bar, size_t size,
>   		u64 offset);
> @@ -30,6 +37,8 @@ struct scatterlist *pci_p2pmem_alloc_sgl(struct pci_dev *pdev,
>   					 unsigned int *nents, u32 length);
>   void pci_p2pmem_free_sgl(struct pci_dev *pdev, struct scatterlist *sgl);
>   void pci_p2pmem_publish(struct pci_dev *pdev, bool publish);
> +enum pci_p2pdma_map_type pci_p2pdma_map_type(struct dev_pagemap *pgmap,
> +		struct device *dev, unsigned long dma_attrs);
>   int pci_p2pdma_map_sg_attrs(struct device *dev, struct scatterlist *sg,
>   		int nents, enum dma_data_direction dir, unsigned long attrs);
>   void pci_p2pdma_unmap_sg_attrs(struct device *dev, struct scatterlist *sg,
> @@ -83,6 +92,12 @@ static inline void pci_p2pmem_free_sgl(struct pci_dev *pdev,
>   static inline void pci_p2pmem_publish(struct pci_dev *pdev, bool publish)
>   {
>   }
> +static inline enum pci_p2pdma_map_type pci_p2pdma_map_type(
> +		struct dev_pagemap *pgmap, struct device *dev,
> +		unsigned long dma_attrs)
> +{
> +	return PCI_P2PDMA_MAP_NOT_SUPPORTED;
> +}
>   static inline int pci_p2pdma_map_sg_attrs(struct device *dev,
>   		struct scatterlist *sg, int nents, enum dma_data_direction dir,
>   		unsigned long attrs)
> 


_______________________________________________
Linux-nvme mailing list
Linux-nvme@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-nvme

WARNING: multiple messages have this Message-ID (diff)
From: John Hubbard <jhubbard@nvidia.com>
To: Logan Gunthorpe <logang@deltatee.com>,
	<linux-kernel@vger.kernel.org>, <linux-nvme@lists.infradead.org>,
	<linux-block@vger.kernel.org>, <linux-pci@vger.kernel.org>,
	<linux-mm@kvack.org>, <iommu@lists.linux-foundation.org>
Cc: "Minturn Dave B" <dave.b.minturn@intel.com>,
	"Ira Weiny" <ira.weiny@intel.com>,
	"Daniel Vetter" <daniel.vetter@ffwll.ch>,
	"Dave Hansen" <dave.hansen@linux.intel.com>,
	"Robin Murphy" <robin.murphy@arm.com>,
	"Matthew Wilcox" <willy@infradead.org>,
	"Christian König" <christian.koenig@amd.com>,
	"Jason Gunthorpe" <jgg@ziepe.ca>,
	"Jason Ekstrand" <jason@jlekstrand.net>,
	"Bjorn Helgaas" <helgaas@kernel.org>,
	"Dan Williams" <dan.j.williams@intel.com>,
	"Stephen Bates" <sbates@raithlin.com>,
	"Jakowski Andrzej" <andrzej.jakowski@intel.com>,
	"Christoph Hellwig" <hch@lst.de>,
	"Xiong Jianxin" <jianxin.xiong@intel.com>
Subject: Re: [PATCH 07/16] PCI/P2PDMA: Make pci_p2pdma_map_type() non-static
Date: Sun, 2 May 2021 15:44:06 -0700	[thread overview]
Message-ID: <c2712ed0-6d44-014a-f669-dfda63d1c861@nvidia.com> (raw)
In-Reply-To: <20210408170123.8788-8-logang@deltatee.com>

On 4/8/21 10:01 AM, Logan Gunthorpe wrote:
> pci_p2pdma_map_type() will be needed by the dma-iommu map_sg
> implementation because it will need to determine the mapping type
> ahead of actually doing the mapping to create the actual iommu mapping.
> 
> Signed-off-by: Logan Gunthorpe <logang@deltatee.com>
> ---
>   drivers/pci/p2pdma.c       | 34 +++++++++++++++++++++++-----------
>   include/linux/pci-p2pdma.h | 15 +++++++++++++++
>   2 files changed, 38 insertions(+), 11 deletions(-)
> 
> diff --git a/drivers/pci/p2pdma.c b/drivers/pci/p2pdma.c
> index bcb1a6d6119d..38c93f57a941 100644
> --- a/drivers/pci/p2pdma.c
> +++ b/drivers/pci/p2pdma.c
> @@ -20,13 +20,6 @@
>   #include <linux/seq_buf.h>
>   #include <linux/xarray.h>
>   
> -enum pci_p2pdma_map_type {
> -	PCI_P2PDMA_MAP_UNKNOWN = 0,
> -	PCI_P2PDMA_MAP_NOT_SUPPORTED,
> -	PCI_P2PDMA_MAP_BUS_ADDR,
> -	PCI_P2PDMA_MAP_THRU_HOST_BRIDGE,
> -};
> -
>   struct pci_p2pdma {
>   	struct gen_pool *pool;
>   	bool p2pmem_published;
> @@ -822,13 +815,30 @@ void pci_p2pmem_publish(struct pci_dev *pdev, bool publish)
>   }
>   EXPORT_SYMBOL_GPL(pci_p2pmem_publish);
>   
> -static enum pci_p2pdma_map_type pci_p2pdma_map_type(struct dev_pagemap *pgmap,
> -						    struct device *dev)
> +/**
> + * pci_p2pdma_map_type - return the type of mapping that should be used for
> + *	a given device and pgmap
> + * @pgmap: the pagemap of a page to determine the mapping type for
> + * @dev: device that is mapping the page
> + * @dma_attrs: the attributes passed to the dma_map operation --
> + *	this is so they can be checked to ensure P2PDMA pages were not
> + *	introduced into an incorrect interface (like dma_map_sg). *
> + *
> + * Returns one of:
> + *	PCI_P2PDMA_MAP_NOT_SUPPORTED - The mapping should not be done
> + *	PCI_P2PDMA_MAP_BUS_ADDR - The mapping should use the PCI bus address
> + *	PCI_P2PDMA_MAP_THRU_HOST_BRIDGE - The mapping should be done directly
> + */
> +enum pci_p2pdma_map_type pci_p2pdma_map_type(struct dev_pagemap *pgmap,
> +		struct device *dev, unsigned long dma_attrs)
>   {
>   	struct pci_dev *provider = to_p2p_pgmap(pgmap)->provider;
>   	enum pci_p2pdma_map_type ret;
>   	struct pci_dev *client;
>   
> +	WARN_ONCE(!(dma_attrs & __DMA_ATTR_PCI_P2PDMA),
> +		  "PCI P2PDMA pages were mapped with dma_map_sg!");

This really ought to also return -EINVAL, assuming that my review suggestions
about return types, in earlier patches, are acceptable.

> +
>   	if (!provider->p2pdma)
>   		return PCI_P2PDMA_MAP_NOT_SUPPORTED;
>   
> @@ -879,7 +889,8 @@ int pci_p2pdma_map_sg_attrs(struct device *dev, struct scatterlist *sg,
>   	struct pci_p2pdma_pagemap *p2p_pgmap =
>   		to_p2p_pgmap(sg_page(sg)->pgmap);
>   
> -	switch (pci_p2pdma_map_type(sg_page(sg)->pgmap, dev)) {
> +	switch (pci_p2pdma_map_type(sg_page(sg)->pgmap, dev,
> +				    __DMA_ATTR_PCI_P2PDMA)) {
>   	case PCI_P2PDMA_MAP_THRU_HOST_BRIDGE:
>   		return dma_map_sg_attrs(dev, sg, nents, dir, attrs);
>   	case PCI_P2PDMA_MAP_BUS_ADDR:
> @@ -904,7 +915,8 @@ void pci_p2pdma_unmap_sg_attrs(struct device *dev, struct scatterlist *sg,
>   {
>   	enum pci_p2pdma_map_type map_type;
>   
> -	map_type = pci_p2pdma_map_type(sg_page(sg)->pgmap, dev);
> +	map_type = pci_p2pdma_map_type(sg_page(sg)->pgmap, dev,
> +				       __DMA_ATTR_PCI_P2PDMA);

These areas might end up looking a bit different, if my suggestion about
applying pci_dev type safety throughout are accepted.

The patch looks generally correct, aside from these details.

thanks,
-- 
John Hubbard
NVIDIA

>   
>   	if (map_type == PCI_P2PDMA_MAP_THRU_HOST_BRIDGE)
>   		dma_unmap_sg_attrs(dev, sg, nents, dir, attrs);
> diff --git a/include/linux/pci-p2pdma.h b/include/linux/pci-p2pdma.h
> index 8318a97c9c61..a06072ac3a52 100644
> --- a/include/linux/pci-p2pdma.h
> +++ b/include/linux/pci-p2pdma.h
> @@ -16,6 +16,13 @@
>   struct block_device;
>   struct scatterlist;
>   
> +enum pci_p2pdma_map_type {
> +	PCI_P2PDMA_MAP_UNKNOWN = 0,
> +	PCI_P2PDMA_MAP_NOT_SUPPORTED,
> +	PCI_P2PDMA_MAP_BUS_ADDR,
> +	PCI_P2PDMA_MAP_THRU_HOST_BRIDGE,
> +};
> +
>   #ifdef CONFIG_PCI_P2PDMA
>   int pci_p2pdma_add_resource(struct pci_dev *pdev, int bar, size_t size,
>   		u64 offset);
> @@ -30,6 +37,8 @@ struct scatterlist *pci_p2pmem_alloc_sgl(struct pci_dev *pdev,
>   					 unsigned int *nents, u32 length);
>   void pci_p2pmem_free_sgl(struct pci_dev *pdev, struct scatterlist *sgl);
>   void pci_p2pmem_publish(struct pci_dev *pdev, bool publish);
> +enum pci_p2pdma_map_type pci_p2pdma_map_type(struct dev_pagemap *pgmap,
> +		struct device *dev, unsigned long dma_attrs);
>   int pci_p2pdma_map_sg_attrs(struct device *dev, struct scatterlist *sg,
>   		int nents, enum dma_data_direction dir, unsigned long attrs);
>   void pci_p2pdma_unmap_sg_attrs(struct device *dev, struct scatterlist *sg,
> @@ -83,6 +92,12 @@ static inline void pci_p2pmem_free_sgl(struct pci_dev *pdev,
>   static inline void pci_p2pmem_publish(struct pci_dev *pdev, bool publish)
>   {
>   }
> +static inline enum pci_p2pdma_map_type pci_p2pdma_map_type(
> +		struct dev_pagemap *pgmap, struct device *dev,
> +		unsigned long dma_attrs)
> +{
> +	return PCI_P2PDMA_MAP_NOT_SUPPORTED;
> +}
>   static inline int pci_p2pdma_map_sg_attrs(struct device *dev,
>   		struct scatterlist *sg, int nents, enum dma_data_direction dir,
>   		unsigned long attrs)
> 

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

  reply	other threads:[~2021-05-02 22:44 UTC|newest]

Thread overview: 297+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-04-08 17:01 [PATCH 00/16] Add new DMA mapping operation for P2PDMA Logan Gunthorpe
2021-04-08 17:01 ` Logan Gunthorpe
2021-04-08 17:01 ` Logan Gunthorpe
2021-04-08 17:01 ` [PATCH 01/16] PCI/P2PDMA: Pass gfp_mask flags to upstream_bridge_distance_warn() Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-02  3:58   ` John Hubbard
2021-05-02  3:58     ` John Hubbard
2021-05-02  3:58     ` John Hubbard
2021-05-03 15:57     ` Logan Gunthorpe
2021-05-03 15:57       ` Logan Gunthorpe
2021-05-03 15:57       ` Logan Gunthorpe
2021-05-03 18:17       ` John Hubbard
2021-05-03 18:17         ` John Hubbard
2021-05-03 18:17         ` John Hubbard
2021-05-03 18:20         ` Logan Gunthorpe
2021-05-03 18:20           ` Logan Gunthorpe
2021-05-03 18:20           ` Logan Gunthorpe
2021-05-03 18:23           ` John Hubbard
2021-05-03 18:23             ` John Hubbard
2021-05-03 18:23             ` John Hubbard
2021-05-03 18:24         ` Christoph Hellwig
2021-05-03 18:24           ` Christoph Hellwig
2021-05-03 18:24           ` Christoph Hellwig
2021-05-11 16:05     ` Don Dutile
2021-05-11 16:05       ` Don Dutile
2021-05-11 16:05       ` Don Dutile
2021-05-11 16:12       ` Logan Gunthorpe
2021-05-11 16:12         ` Logan Gunthorpe
2021-05-11 16:12         ` Logan Gunthorpe
2021-05-11 16:23         ` Don Dutile
2021-05-11 16:23           ` Don Dutile
2021-05-11 16:23           ` Don Dutile
2021-04-08 17:01 ` [PATCH 02/16] PCI/P2PDMA: Avoid pci_get_slot() which sleeps Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-02  5:35   ` John Hubbard
2021-05-02  5:35     ` John Hubbard
2021-05-02  5:35     ` John Hubbard
2021-05-03 16:08     ` Logan Gunthorpe
2021-05-03 16:08       ` Logan Gunthorpe
2021-05-03 16:08       ` Logan Gunthorpe
2021-05-03 18:20       ` John Hubbard
2021-05-03 18:20         ` John Hubbard
2021-05-03 18:20         ` John Hubbard
2021-05-03 18:25       ` Christoph Hellwig
2021-05-03 18:25         ` Christoph Hellwig
2021-05-03 18:25         ` Christoph Hellwig
2021-05-11 16:05     ` Don Dutile
2021-05-11 16:05       ` Don Dutile
2021-05-11 16:05       ` Don Dutile
2021-05-11 16:16       ` Logan Gunthorpe
2021-05-11 16:16         ` Logan Gunthorpe
2021-05-11 16:16         ` Logan Gunthorpe
2021-05-11 16:05   ` Don Dutile
2021-05-11 16:05     ` Don Dutile
2021-05-11 16:05     ` Don Dutile
2021-05-11 16:14     ` Logan Gunthorpe
2021-05-11 16:14       ` Logan Gunthorpe
2021-05-11 16:14       ` Logan Gunthorpe
2021-04-08 17:01 ` [PATCH 03/16] PCI/P2PDMA: Attempt to set map_type if it has not been set Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-02 19:58   ` John Hubbard
2021-05-02 19:58     ` John Hubbard
2021-05-02 19:58     ` John Hubbard
2021-05-03 16:17     ` Logan Gunthorpe
2021-05-03 16:17       ` Logan Gunthorpe
2021-05-03 16:17       ` Logan Gunthorpe
2021-05-03 18:22       ` John Hubbard
2021-05-03 18:22         ` John Hubbard
2021-05-03 18:22         ` John Hubbard
2021-05-03 18:35       ` Christoph Hellwig
2021-05-03 18:35         ` Christoph Hellwig
2021-05-03 18:35         ` Christoph Hellwig
2021-05-03 18:46         ` Logan Gunthorpe
2021-05-03 18:46           ` Logan Gunthorpe
2021-05-03 18:46           ` Logan Gunthorpe
2021-05-11 16:05     ` Don Dutile
2021-05-11 16:05       ` Don Dutile
2021-05-11 16:05       ` Don Dutile
2021-04-08 17:01 ` [PATCH 04/16] PCI/P2PDMA: Refactor pci_p2pdma_map_type() to take pagmap and device Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-02 20:41   ` John Hubbard
2021-05-02 20:41     ` John Hubbard
2021-05-02 20:41     ` John Hubbard
2021-05-03 16:30     ` Logan Gunthorpe
2021-05-03 16:30       ` Logan Gunthorpe
2021-05-03 16:30       ` Logan Gunthorpe
2021-05-03 18:31       ` John Hubbard
2021-05-03 18:31         ` John Hubbard
2021-05-03 18:31         ` John Hubbard
2021-05-03 18:56         ` Logan Gunthorpe
2021-05-03 18:56           ` Logan Gunthorpe
2021-05-03 18:56           ` Logan Gunthorpe
2021-05-03 21:54           ` John Hubbard
2021-05-03 21:54             ` John Hubbard
2021-05-03 21:54             ` John Hubbard
2021-05-03 22:57             ` Jason Gunthorpe
2021-05-03 22:57               ` Jason Gunthorpe
2021-05-03 22:57               ` Jason Gunthorpe
2021-05-03 23:40               ` John Hubbard
2021-05-03 23:40                 ` John Hubbard
2021-05-03 23:40                 ` John Hubbard
2021-04-08 17:01 ` [PATCH 05/16] dma-mapping: Introduce dma_map_sg_p2pdma() Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-27 19:22   ` Jason Gunthorpe
2021-04-27 19:22     ` Jason Gunthorpe
2021-04-27 19:22     ` Jason Gunthorpe
2021-04-27 22:49     ` Logan Gunthorpe
2021-04-27 22:49       ` Logan Gunthorpe
2021-04-27 22:49       ` Logan Gunthorpe
2021-04-27 19:31   ` Jason Gunthorpe
2021-04-27 19:31     ` Jason Gunthorpe
2021-04-27 19:31     ` Jason Gunthorpe
2021-04-27 22:55     ` Logan Gunthorpe
2021-04-27 22:55       ` Logan Gunthorpe
2021-04-27 22:55       ` Logan Gunthorpe
2021-04-27 23:01       ` Jason Gunthorpe
2021-04-27 23:01         ` Jason Gunthorpe
2021-04-27 23:01         ` Jason Gunthorpe
2021-05-03 18:28         ` Christoph Hellwig
2021-05-03 18:28           ` Christoph Hellwig
2021-05-03 18:28           ` Christoph Hellwig
2021-05-03 18:31           ` Logan Gunthorpe
2021-05-03 18:31             ` Logan Gunthorpe
2021-05-03 18:31             ` Logan Gunthorpe
2021-05-02 21:23   ` John Hubbard
2021-05-02 21:23     ` John Hubbard
2021-05-02 21:23     ` John Hubbard
2021-05-03 16:38     ` Logan Gunthorpe
2021-05-03 16:38       ` Logan Gunthorpe
2021-05-03 16:38       ` Logan Gunthorpe
2021-05-11 16:05   ` Don Dutile
2021-05-11 16:05     ` Don Dutile
2021-05-11 16:05     ` Don Dutile
2021-04-08 17:01 ` [PATCH 06/16] lib/scatterlist: Add flag for indicating P2PDMA segments in an SGL Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-02 22:34   ` John Hubbard
2021-05-02 22:34     ` John Hubbard
2021-05-02 22:34     ` John Hubbard
2021-04-08 17:01 ` [PATCH 07/16] PCI/P2PDMA: Make pci_p2pdma_map_type() non-static Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-02 22:44   ` John Hubbard [this message]
2021-05-02 22:44     ` John Hubbard
2021-05-02 22:44     ` John Hubbard
2021-05-03 16:39     ` Logan Gunthorpe
2021-05-03 16:39       ` Logan Gunthorpe
2021-05-03 16:39       ` Logan Gunthorpe
2021-05-11 16:06   ` Don Dutile
2021-05-11 16:06     ` Don Dutile
2021-05-11 16:06     ` Don Dutile
2021-05-11 16:17     ` Logan Gunthorpe
2021-05-11 16:17       ` Logan Gunthorpe
2021-05-11 16:17       ` Logan Gunthorpe
2021-04-08 17:01 ` [PATCH 08/16] PCI/P2PDMA: Introduce helpers for dma_map_sg implementations Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-02 22:52   ` John Hubbard
2021-05-02 22:52     ` John Hubbard
2021-05-02 22:52     ` John Hubbard
2021-05-03  0:50   ` John Hubbard
2021-05-03  0:50     ` John Hubbard
2021-05-03  0:50     ` John Hubbard
2021-05-03 17:15     ` Logan Gunthorpe
2021-05-03 17:15       ` Logan Gunthorpe
2021-05-03 17:15       ` Logan Gunthorpe
2021-04-08 17:01 ` [PATCH 09/16] dma-direct: Support PCI P2PDMA pages in dma-direct map_sg Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-27 19:33   ` Jason Gunthorpe
2021-04-27 19:33     ` Jason Gunthorpe
2021-04-27 19:33     ` Jason Gunthorpe
2021-04-27 19:40     ` Jason Gunthorpe
2021-04-27 19:40       ` Jason Gunthorpe
2021-04-27 19:40       ` Jason Gunthorpe
2021-04-27 22:56       ` Logan Gunthorpe
2021-04-27 22:56         ` Logan Gunthorpe
2021-04-27 22:56         ` Logan Gunthorpe
2021-05-02 23:28   ` John Hubbard
2021-05-02 23:28     ` John Hubbard
2021-05-02 23:28     ` John Hubbard
2021-05-02 23:32     ` John Hubbard
2021-05-02 23:32       ` John Hubbard
2021-05-02 23:32       ` John Hubbard
2021-05-03 17:06       ` Logan Gunthorpe
2021-05-03 17:06         ` Logan Gunthorpe
2021-05-03 17:06         ` Logan Gunthorpe
2021-05-03 16:55     ` Logan Gunthorpe
2021-05-03 16:55       ` Logan Gunthorpe
2021-05-03 16:55       ` Logan Gunthorpe
2021-05-04  0:12       ` John Hubbard
2021-05-04  0:12         ` John Hubbard
2021-05-04  0:12         ` John Hubbard
2021-05-03 17:04     ` Logan Gunthorpe
2021-05-03 17:04       ` Logan Gunthorpe
2021-05-03 17:04       ` Logan Gunthorpe
2021-05-04  0:01       ` John Hubbard
2021-05-04  0:01         ` John Hubbard
2021-05-04  0:01         ` John Hubbard
2021-04-08 17:01 ` [PATCH 10/16] dma-mapping: Add flags to dma_map_ops to indicate PCI P2PDMA support Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-03  0:32   ` John Hubbard
2021-05-03  0:32     ` John Hubbard
2021-05-03  0:32     ` John Hubbard
2021-05-03 17:09     ` Logan Gunthorpe
2021-05-03 17:09       ` Logan Gunthorpe
2021-05-03 17:09       ` Logan Gunthorpe
2021-05-11 16:06   ` Don Dutile
2021-05-11 16:06     ` Don Dutile
2021-05-11 16:06     ` Don Dutile
2021-05-11 16:19     ` Logan Gunthorpe
2021-05-11 16:19       ` Logan Gunthorpe
2021-05-11 16:19       ` Logan Gunthorpe
2021-04-08 17:01 ` [PATCH 11/16] iommu/dma: Support PCI P2PDMA pages in dma-iommu map_sg Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-27 19:43   ` Jason Gunthorpe
2021-04-27 19:43     ` Jason Gunthorpe
2021-04-27 19:43     ` Jason Gunthorpe
2021-04-27 22:59     ` Logan Gunthorpe
2021-04-27 22:59       ` Logan Gunthorpe
2021-04-27 22:59       ` Logan Gunthorpe
2021-05-03  1:14   ` John Hubbard
2021-05-03  1:14     ` John Hubbard
2021-05-03  1:14     ` John Hubbard
2021-05-06 23:59     ` Logan Gunthorpe
2021-05-06 23:59       ` Logan Gunthorpe
2021-05-06 23:59       ` Logan Gunthorpe
2021-05-11 16:06   ` Don Dutile
2021-05-11 16:06     ` Don Dutile
2021-05-11 16:06     ` Don Dutile
2021-05-11 16:35     ` Logan Gunthorpe
2021-05-11 16:35       ` Logan Gunthorpe
2021-05-11 16:35       ` Logan Gunthorpe
2021-04-08 17:01 ` [PATCH 12/16] nvme-pci: Check DMA ops when indicating support for PCI P2PDMA Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-03  1:29   ` John Hubbard
2021-05-03  1:29     ` John Hubbard
2021-05-03  1:29     ` John Hubbard
2021-05-03 17:17     ` Logan Gunthorpe
2021-05-03 17:17       ` Logan Gunthorpe
2021-05-03 17:17       ` Logan Gunthorpe
2021-05-04  0:17       ` John Hubbard
2021-05-04  0:17         ` John Hubbard
2021-05-04  0:17         ` John Hubbard
2021-04-08 17:01 ` [PATCH 13/16] nvme-pci: Convert to using dma_map_sg_p2pdma for p2pdma pages Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-05-03  1:34   ` John Hubbard
2021-05-03  1:34     ` John Hubbard
2021-05-03  1:34     ` John Hubbard
2021-05-03 17:19     ` Logan Gunthorpe
2021-05-03 17:19       ` Logan Gunthorpe
2021-05-03 17:19       ` Logan Gunthorpe
2021-05-04  0:26       ` John Hubbard
2021-05-04  0:26         ` John Hubbard
2021-05-04  0:26         ` John Hubbard
2021-04-08 17:01 ` [PATCH 14/16] nvme-rdma: Ensure dma support when using p2pdma Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-27 19:47   ` Jason Gunthorpe
2021-04-27 19:47     ` Jason Gunthorpe
2021-04-27 19:47     ` Jason Gunthorpe
2021-04-27 22:59     ` Logan Gunthorpe
2021-04-27 22:59       ` Logan Gunthorpe
2021-04-27 22:59       ` Logan Gunthorpe
2021-05-03  1:37   ` John Hubbard
2021-05-03  1:37     ` John Hubbard
2021-05-03  1:37     ` John Hubbard
2021-04-08 17:01 ` [PATCH 15/16] RDMA/rw: use dma_map_sg_p2pdma() Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01 ` [PATCH 16/16] PCI/P2PDMA: Remove pci_p2pdma_[un]map_sg() Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-08 17:01   ` Logan Gunthorpe
2021-04-27 19:28 ` [PATCH 00/16] Add new DMA mapping operation for P2PDMA Jason Gunthorpe
2021-04-27 19:28   ` Jason Gunthorpe
2021-04-27 19:28   ` Jason Gunthorpe
2021-04-27 20:21   ` John Hubbard
2021-04-27 20:21     ` John Hubbard
2021-04-27 20:21     ` John Hubbard
2021-04-27 20:48     ` Dan Williams
2021-04-27 20:48       ` Dan Williams
2021-04-27 20:48       ` Dan Williams
2021-05-02  1:22 ` John Hubbard
2021-05-02  1:22   ` John Hubbard
2021-05-02  1:22   ` John Hubbard
2021-05-11 16:05 ` Don Dutile
2021-05-11 16:05   ` Don Dutile
2021-05-11 16:05   ` Don Dutile

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=c2712ed0-6d44-014a-f669-dfda63d1c861@nvidia.com \
    --to=jhubbard@nvidia.com \
    --cc=andrzej.jakowski@intel.com \
    --cc=christian.koenig@amd.com \
    --cc=dan.j.williams@intel.com \
    --cc=daniel.vetter@ffwll.ch \
    --cc=dave.b.minturn@intel.com \
    --cc=dave.hansen@linux.intel.com \
    --cc=ddutile@redhat.com \
    --cc=hch@lst.de \
    --cc=helgaas@kernel.org \
    --cc=iommu@lists.linux-foundation.org \
    --cc=ira.weiny@intel.com \
    --cc=jason@jlekstrand.net \
    --cc=jgg@ziepe.ca \
    --cc=jianxin.xiong@intel.com \
    --cc=linux-block@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mm@kvack.org \
    --cc=linux-nvme@lists.infradead.org \
    --cc=linux-pci@vger.kernel.org \
    --cc=logang@deltatee.com \
    --cc=robin.murphy@arm.com \
    --cc=sbates@raithlin.com \
    --cc=willy@infradead.org \
    /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.