Re: [PATCH] drm/ttm, drm/vmwgfx: Use a configuration option for the TTM dma page pool

2019-05-16 Thread Christian König

Am 16.05.19 um 11:23 schrieb Thomas Hellstrom:

Drivers like vmwgfx may want to test whether the dma page pool is present
or not. Since it's activated by default by TTM if compiled-in, define a
hidden configuration option that the driver can test for.

Cc: Christian König 
Signed-off-by: Thomas Hellstrom 


There are at least also occasions of this in radeon and amdgpu, but 
those can be cleaned up later on.


Reviewed-by: Christian König  for now.

Which tree should we use for merging?

Thanks,
Christian.


---
  drivers/gpu/drm/Kconfig  | 5 +
  drivers/gpu/drm/ttm/Makefile | 4 ++--
  drivers/gpu/drm/ttm/ttm_page_alloc_dma.c | 3 ---
  drivers/gpu/drm/vmwgfx/vmwgfx_drv.c  | 3 +--
  include/drm/ttm/ttm_page_alloc.h | 2 +-
  5 files changed, 9 insertions(+), 8 deletions(-)

diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
index 2267e84d5cb4..f733a9273b3f 100644
--- a/drivers/gpu/drm/Kconfig
+++ b/drivers/gpu/drm/Kconfig
@@ -160,6 +160,11 @@ config DRM_TTM
  GPU memory types. Will be enabled automatically if a device driver
  uses it.
  
+config DRM_TTM_DMA_PAGE_POOL

+bool
+   depends on DRM_TTM && (SWIOTLB || INTEL_IOMMU)
+   default y
+
  config DRM_GEM_CMA_HELPER
bool
depends on DRM
diff --git a/drivers/gpu/drm/ttm/Makefile b/drivers/gpu/drm/ttm/Makefile
index 01fc670ce7a2..caea2a099496 100644
--- a/drivers/gpu/drm/ttm/Makefile
+++ b/drivers/gpu/drm/ttm/Makefile
@@ -4,8 +4,8 @@
  
  ttm-y := ttm_memory.o ttm_tt.o ttm_bo.o \

ttm_bo_util.o ttm_bo_vm.o ttm_module.o \
-   ttm_execbuf_util.o ttm_page_alloc.o ttm_bo_manager.o \
-   ttm_page_alloc_dma.o
+   ttm_execbuf_util.o ttm_page_alloc.o ttm_bo_manager.o
  ttm-$(CONFIG_AGP) += ttm_agp_backend.o
+ttm-$(CONFIG_DRM_TTM_DMA_PAGE_POOL) += ttm_page_alloc_dma.o
  
  obj-$(CONFIG_DRM_TTM) += ttm.o

diff --git a/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c 
b/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
index d594f7520b7b..98d100fd1599 100644
--- a/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
+++ b/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
@@ -33,7 +33,6 @@
   *   when freed).
   */
  
-#if defined(CONFIG_SWIOTLB) || defined(CONFIG_INTEL_IOMMU)

  #define pr_fmt(fmt) "[TTM] " fmt
  
  #include 

@@ -1234,5 +1233,3 @@ int ttm_dma_page_alloc_debugfs(struct seq_file *m, void 
*data)
return 0;
  }
  EXPORT_SYMBOL_GPL(ttm_dma_page_alloc_debugfs);
-
-#endif
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c 
b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
index d59c474be38e..bc259d4df1cb 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
@@ -572,8 +572,7 @@ static int vmw_dma_select_mode(struct vmw_private *dev_priv)
else
dev_priv->map_mode = vmw_dma_map_populate;
  
-	/* No TTM coherent page pool? FIXME: Ask TTM instead! */

-if (!(IS_ENABLED(CONFIG_SWIOTLB) || IS_ENABLED(CONFIG_INTEL_IOMMU)) &&
+if (!IS_ENABLED(CONFIG_DRM_TTM_DMA_PAGE_POOL) &&
(dev_priv->map_mode == vmw_dma_alloc_coherent))
return -EINVAL;
  
diff --git a/include/drm/ttm/ttm_page_alloc.h b/include/drm/ttm/ttm_page_alloc.h

index 4d9b019d253c..a6b6ef5f9bf4 100644
--- a/include/drm/ttm/ttm_page_alloc.h
+++ b/include/drm/ttm/ttm_page_alloc.h
@@ -74,7 +74,7 @@ void ttm_unmap_and_unpopulate_pages(struct device *dev, 
struct ttm_dma_tt *tt);
   */
  int ttm_page_alloc_debugfs(struct seq_file *m, void *data);
  
-#if defined(CONFIG_SWIOTLB) || defined(CONFIG_INTEL_IOMMU)

+#if defined(CONFIG_DRM_TTM_DMA_PAGE_POOL)
  /**
   * Initialize pool allocator.
   */


___
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Re: [PATCH] drm/ttm, drm/vmwgfx: Use a configuration option for the TTM dma page pool

2019-05-16 Thread Thomas Hellstrom
On Thu, 2019-05-16 at 12:05 +0200, Christian König wrote:
> Am 16.05.19 um 11:23 schrieb Thomas Hellstrom:
> > Drivers like vmwgfx may want to test whether the dma page pool is
> > present
> > or not. Since it's activated by default by TTM if compiled-in,
> > define a
> > hidden configuration option that the driver can test for.
> > 
> > Cc: Christian König 
> > Signed-off-by: Thomas Hellstrom 
> 
> There are at least also occasions of this in radeon and amdgpu, but 
> those can be cleaned up later on.
> 
> Reviewed-by: Christian König  for now.
> 
> Which tree should we use for merging?
> 
> Thanks,
> Christian.

We can take it through an AMD tree if it's OK with you. Then it would
be easier to add similar changes to the AMD drivers.

I'll send out v2 with some whitespace cleanup, a config help text and
R-b next.

Thanks,
Thomas





> 
> > ---
> >   drivers/gpu/drm/Kconfig  | 5 +
> >   drivers/gpu/drm/ttm/Makefile | 4 ++--
> >   drivers/gpu/drm/ttm/ttm_page_alloc_dma.c | 3 ---
> >   drivers/gpu/drm/vmwgfx/vmwgfx_drv.c  | 3 +--
> >   include/drm/ttm/ttm_page_alloc.h | 2 +-
> >   5 files changed, 9 insertions(+), 8 deletions(-)
> > 
> > diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
> > index 2267e84d5cb4..f733a9273b3f 100644
> > --- a/drivers/gpu/drm/Kconfig
> > +++ b/drivers/gpu/drm/Kconfig
> > @@ -160,6 +160,11 @@ config DRM_TTM
> >   GPU memory types. Will be enabled automatically if a device
> > driver
> >   uses it.
> >   
> > +config DRM_TTM_DMA_PAGE_POOL
> > +bool
> > +   depends on DRM_TTM && (SWIOTLB || INTEL_IOMMU)
> > +   default y
> > +
> >   config DRM_GEM_CMA_HELPER
> > bool
> > depends on DRM
> > diff --git a/drivers/gpu/drm/ttm/Makefile
> > b/drivers/gpu/drm/ttm/Makefile
> > index 01fc670ce7a2..caea2a099496 100644
> > --- a/drivers/gpu/drm/ttm/Makefile
> > +++ b/drivers/gpu/drm/ttm/Makefile
> > @@ -4,8 +4,8 @@
> >   
> >   ttm-y := ttm_memory.o ttm_tt.o ttm_bo.o \
> > ttm_bo_util.o ttm_bo_vm.o ttm_module.o \
> > -   ttm_execbuf_util.o ttm_page_alloc.o ttm_bo_manager.o \
> > -   ttm_page_alloc_dma.o
> > +   ttm_execbuf_util.o ttm_page_alloc.o ttm_bo_manager.o
> >   ttm-$(CONFIG_AGP) += ttm_agp_backend.o
> > +ttm-$(CONFIG_DRM_TTM_DMA_PAGE_POOL) += ttm_page_alloc_dma.o
> >   
> >   obj-$(CONFIG_DRM_TTM) += ttm.o
> > diff --git a/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
> > b/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
> > index d594f7520b7b..98d100fd1599 100644
> > --- a/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
> > +++ b/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
> > @@ -33,7 +33,6 @@
> >*   when freed).
> >*/
> >   
> > -#if defined(CONFIG_SWIOTLB) || defined(CONFIG_INTEL_IOMMU)
> >   #define pr_fmt(fmt) "[TTM] " fmt
> >   
> >   #include 
> > @@ -1234,5 +1233,3 @@ int ttm_dma_page_alloc_debugfs(struct
> > seq_file *m, void *data)
> > return 0;
> >   }
> >   EXPORT_SYMBOL_GPL(ttm_dma_page_alloc_debugfs);
> > -
> > -#endif
> > diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> > b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> > index d59c474be38e..bc259d4df1cb 100644
> > --- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> > +++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
> > @@ -572,8 +572,7 @@ static int vmw_dma_select_mode(struct
> > vmw_private *dev_priv)
> > else
> > dev_priv->map_mode = vmw_dma_map_populate;
> >   
> > -   /* No TTM coherent page pool? FIXME: Ask TTM instead! */
> > -if (!(IS_ENABLED(CONFIG_SWIOTLB) ||
> > IS_ENABLED(CONFIG_INTEL_IOMMU)) &&
> > +if (!IS_ENABLED(CONFIG_DRM_TTM_DMA_PAGE_POOL) &&
> > (dev_priv->map_mode == vmw_dma_alloc_coherent))
> > return -EINVAL;
> >   
> > diff --git a/include/drm/ttm/ttm_page_alloc.h
> > b/include/drm/ttm/ttm_page_alloc.h
> > index 4d9b019d253c..a6b6ef5f9bf4 100644
> > --- a/include/drm/ttm/ttm_page_alloc.h
> > +++ b/include/drm/ttm/ttm_page_alloc.h
> > @@ -74,7 +74,7 @@ void ttm_unmap_and_unpopulate_pages(struct device
> > *dev, struct ttm_dma_tt *tt);
> >*/
> >   int ttm_page_alloc_debugfs(struct seq_file *m, void *data);
> >   
> > -#if defined(CONFIG_SWIOTLB) || defined(CONFIG_INTEL_IOMMU)
> > +#if defined(CONFIG_DRM_TTM_DMA_PAGE_POOL)
> >   /**
> >* Initialize pool allocator.
> >*/
___
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Re: [PATCH] drm/ttm, drm/vmwgfx: Use a configuration option for the TTM dma page pool

2019-05-16 Thread Christian König

Am 16.05.19 um 13:23 schrieb Thomas Hellstrom:

On Thu, 2019-05-16 at 12:05 +0200, Christian König wrote:

Am 16.05.19 um 11:23 schrieb Thomas Hellstrom:

Drivers like vmwgfx may want to test whether the dma page pool is
present
or not. Since it's activated by default by TTM if compiled-in,
define a
hidden configuration option that the driver can test for.

Cc: Christian König 
Signed-off-by: Thomas Hellstrom 

There are at least also occasions of this in radeon and amdgpu, but
those can be cleaned up later on.

Reviewed-by: Christian König  for now.

Which tree should we use for merging?

Thanks,
Christian.

We can take it through an AMD tree if it's OK with you. Then it would
be easier to add similar changes to the AMD drivers.


Perfectly fine with me, going to pick that up and doing the 
radeon/amdgpu cleanups on top.


Christian.



I'll send out v2 with some whitespace cleanup, a config help text and
R-b next.

Thanks,
Thomas






---
   drivers/gpu/drm/Kconfig  | 5 +
   drivers/gpu/drm/ttm/Makefile | 4 ++--
   drivers/gpu/drm/ttm/ttm_page_alloc_dma.c | 3 ---
   drivers/gpu/drm/vmwgfx/vmwgfx_drv.c  | 3 +--
   include/drm/ttm/ttm_page_alloc.h | 2 +-
   5 files changed, 9 insertions(+), 8 deletions(-)

diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
index 2267e84d5cb4..f733a9273b3f 100644
--- a/drivers/gpu/drm/Kconfig
+++ b/drivers/gpu/drm/Kconfig
@@ -160,6 +160,11 @@ config DRM_TTM
  GPU memory types. Will be enabled automatically if a device
driver
  uses it.
   
+config DRM_TTM_DMA_PAGE_POOL

+bool
+   depends on DRM_TTM && (SWIOTLB || INTEL_IOMMU)
+   default y
+
   config DRM_GEM_CMA_HELPER
bool
depends on DRM
diff --git a/drivers/gpu/drm/ttm/Makefile
b/drivers/gpu/drm/ttm/Makefile
index 01fc670ce7a2..caea2a099496 100644
--- a/drivers/gpu/drm/ttm/Makefile
+++ b/drivers/gpu/drm/ttm/Makefile
@@ -4,8 +4,8 @@
   
   ttm-y := ttm_memory.o ttm_tt.o ttm_bo.o \

ttm_bo_util.o ttm_bo_vm.o ttm_module.o \
-   ttm_execbuf_util.o ttm_page_alloc.o ttm_bo_manager.o \
-   ttm_page_alloc_dma.o
+   ttm_execbuf_util.o ttm_page_alloc.o ttm_bo_manager.o
   ttm-$(CONFIG_AGP) += ttm_agp_backend.o
+ttm-$(CONFIG_DRM_TTM_DMA_PAGE_POOL) += ttm_page_alloc_dma.o
   
   obj-$(CONFIG_DRM_TTM) += ttm.o

diff --git a/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
b/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
index d594f7520b7b..98d100fd1599 100644
--- a/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
+++ b/drivers/gpu/drm/ttm/ttm_page_alloc_dma.c
@@ -33,7 +33,6 @@
*   when freed).
*/
   
-#if defined(CONFIG_SWIOTLB) || defined(CONFIG_INTEL_IOMMU)

   #define pr_fmt(fmt) "[TTM] " fmt
   
   #include 

@@ -1234,5 +1233,3 @@ int ttm_dma_page_alloc_debugfs(struct
seq_file *m, void *data)
return 0;
   }
   EXPORT_SYMBOL_GPL(ttm_dma_page_alloc_debugfs);
-
-#endif
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
index d59c474be38e..bc259d4df1cb 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
@@ -572,8 +572,7 @@ static int vmw_dma_select_mode(struct
vmw_private *dev_priv)
else
dev_priv->map_mode = vmw_dma_map_populate;
   
-	/* No TTM coherent page pool? FIXME: Ask TTM instead! */

-if (!(IS_ENABLED(CONFIG_SWIOTLB) ||
IS_ENABLED(CONFIG_INTEL_IOMMU)) &&
+if (!IS_ENABLED(CONFIG_DRM_TTM_DMA_PAGE_POOL) &&
(dev_priv->map_mode == vmw_dma_alloc_coherent))
return -EINVAL;
   
diff --git a/include/drm/ttm/ttm_page_alloc.h

b/include/drm/ttm/ttm_page_alloc.h
index 4d9b019d253c..a6b6ef5f9bf4 100644
--- a/include/drm/ttm/ttm_page_alloc.h
+++ b/include/drm/ttm/ttm_page_alloc.h
@@ -74,7 +74,7 @@ void ttm_unmap_and_unpopulate_pages(struct device
*dev, struct ttm_dma_tt *tt);
*/
   int ttm_page_alloc_debugfs(struct seq_file *m, void *data);
   
-#if defined(CONFIG_SWIOTLB) || defined(CONFIG_INTEL_IOMMU)

+#if defined(CONFIG_DRM_TTM_DMA_PAGE_POOL)
   /**
* Initialize pool allocator.
*/

___
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel


___
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel