On 05/23/2018 12:31 AM, Christian König wrote:
Am 23.05.2018 um 00:31 schrieb Deepak Sharma:
When vram size <= THRESHOLD(256M) lets use GTT for dumb buffer
allocation. As SG will be enabled with vram size <= 256M
scan out will not be an issue.

v2: Use amdgpu_display_supported_domains to get supported domain.

Signed-off-by: Deepak Sharma <[email protected]>
---
  drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c | 10 ++++++++--
  1 file changed, 8 insertions(+), 2 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c
index 2c8e27370284..63758db5e2ea 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c
@@ -30,6 +30,7 @@
  #include <drm/drmP.h>
  #include <drm/amdgpu_drm.h>
  #include "amdgpu.h"
+#include "amdgpu_display.h"
  void amdgpu_gem_object_free(struct drm_gem_object *gobj)
  {
@@ -749,15 +750,20 @@ int amdgpu_mode_dumb_create(struct drm_file *file_priv,
      struct amdgpu_device *adev = dev->dev_private;
      struct drm_gem_object *gobj;
      uint32_t handle;
+    u32 domain = amdgpu_display_supported_domains(adev);
      int r;
      args->pitch = amdgpu_align_pitch(adev, args->width,
                       DIV_ROUND_UP(args->bpp, 8), 0);
      args->size = (u64)args->pitch * args->height;
      args->size = ALIGN(args->size, PAGE_SIZE);
+    if (domain == (AMDGPU_GEM_DOMAIN_VRAM | AMDGPU_GEM_DOMAIN_GTT)) {
+        domain = AMDGPU_GEM_DOMAIN_VRAM;
+        if (adev->gmc.real_vram_size <= AMDGPU_SG_THRESHOLD)
+            domain = AMDGPU_GEM_DOMAIN_GTT;
+    }

As Michel suggested as well better make that an helper in amdgpu_object.c.

Apart from that looks good to me,
Christian.

I can push another patch to create helper function and use that here as well as in amdgpu_bo_pin_restricted.

otherwise I can push v3 if you want that change in this patch itself.

Thanks,
Deepak


-    r = amdgpu_gem_object_create(adev, args->size, 0,
-                     AMDGPU_GEM_DOMAIN_VRAM,
+    r = amdgpu_gem_object_create(adev, args->size, 0, domain,
                       AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED,
                       false, NULL, &gobj);
      if (r)

_______________________________________________
amd-gfx mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

Reply via email to