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

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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 <christian.koenig@xxxxxxx>
Signed-off-by: Thomas Hellstrom <thellstrom@xxxxxxxxxx>
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 <christian.koenig@xxxxxxx> 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 <linux/dma-mapping.h>
@@ -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@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/dri-devel

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




[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux