diff options
author | Chunming Zhou <david1.zhou@amd.com> | 2018-03-16 00:29:38 -0400 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2018-03-22 15:42:33 -0400 |
commit | cc15dfaa85e8dfc763f22caca54fa097e377ea27 (patch) | |
tree | ae2a983d60876449e2f9f9e75a57869b5ce5ea9a /drivers/gpu/drm/amd | |
parent | b6356df3eb9ad9ae12efb4ec37d5615065e51d8b (diff) |
drm/amdgpu: Don't change preferred domian when fallback GTT v5
v2: add sanity checking
v3: make code open
v4: also handle visible to invisible fallback
v5: Since two fallback cases, re-use goto retry
Signed-off-by: Chunming Zhou <david1.zhou@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd')
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c | 16 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | 18 |
2 files changed, 17 insertions, 17 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c index 46b9ea4e6103..28c2706e48d7 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c | |||
@@ -56,23 +56,11 @@ int amdgpu_gem_object_create(struct amdgpu_device *adev, unsigned long size, | |||
56 | alignment = PAGE_SIZE; | 56 | alignment = PAGE_SIZE; |
57 | } | 57 | } |
58 | 58 | ||
59 | retry: | ||
60 | r = amdgpu_bo_create(adev, size, alignment, initial_domain, | 59 | r = amdgpu_bo_create(adev, size, alignment, initial_domain, |
61 | flags, type, resv, &bo); | 60 | flags, type, resv, &bo); |
62 | if (r) { | 61 | if (r) { |
63 | if (r != -ERESTARTSYS) { | 62 | DRM_DEBUG("Failed to allocate GEM object (%ld, %d, %u, %d)\n", |
64 | if (flags & AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED) { | 63 | size, initial_domain, alignment, r); |
65 | flags &= ~AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED; | ||
66 | goto retry; | ||
67 | } | ||
68 | |||
69 | if (initial_domain == AMDGPU_GEM_DOMAIN_VRAM) { | ||
70 | initial_domain |= AMDGPU_GEM_DOMAIN_GTT; | ||
71 | goto retry; | ||
72 | } | ||
73 | DRM_DEBUG("Failed to allocate GEM object (%ld, %d, %u, %d)\n", | ||
74 | size, initial_domain, alignment, r); | ||
75 | } | ||
76 | return r; | 64 | return r; |
77 | } | 65 | } |
78 | *obj = &bo->gem_base; | 66 | *obj = &bo->gem_base; |
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c index 6d08cde8443c..fac4b6067efd 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | |||
@@ -356,6 +356,7 @@ static int amdgpu_bo_do_create(struct amdgpu_device *adev, unsigned long size, | |||
356 | struct amdgpu_bo *bo; | 356 | struct amdgpu_bo *bo; |
357 | unsigned long page_align; | 357 | unsigned long page_align; |
358 | size_t acc_size; | 358 | size_t acc_size; |
359 | u32 domains; | ||
359 | int r; | 360 | int r; |
360 | 361 | ||
361 | page_align = roundup(byte_align, PAGE_SIZE) >> PAGE_SHIFT; | 362 | page_align = roundup(byte_align, PAGE_SIZE) >> PAGE_SHIFT; |
@@ -417,12 +418,23 @@ static int amdgpu_bo_do_create(struct amdgpu_device *adev, unsigned long size, | |||
417 | #endif | 418 | #endif |
418 | 419 | ||
419 | bo->tbo.bdev = &adev->mman.bdev; | 420 | bo->tbo.bdev = &adev->mman.bdev; |
420 | amdgpu_ttm_placement_from_domain(bo, domain); | 421 | domains = bo->preferred_domains; |
421 | 422 | retry: | |
423 | amdgpu_ttm_placement_from_domain(bo, domains); | ||
422 | r = ttm_bo_init_reserved(&adev->mman.bdev, &bo->tbo, size, type, | 424 | r = ttm_bo_init_reserved(&adev->mman.bdev, &bo->tbo, size, type, |
423 | &bo->placement, page_align, &ctx, acc_size, | 425 | &bo->placement, page_align, &ctx, acc_size, |
424 | NULL, resv, &amdgpu_ttm_bo_destroy); | 426 | NULL, resv, &amdgpu_ttm_bo_destroy); |
425 | if (unlikely(r != 0)) | 427 | |
428 | if (unlikely(r && r != -ERESTARTSYS)) { | ||
429 | if (bo->flags & AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED) { | ||
430 | bo->flags &= ~AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED; | ||
431 | goto retry; | ||
432 | } else if (domains != bo->preferred_domains) { | ||
433 | domains = bo->allowed_domains; | ||
434 | goto retry; | ||
435 | } | ||
436 | } | ||
437 | if (unlikely(r)) | ||
426 | return r; | 438 | return r; |
427 | 439 | ||
428 | if (adev->gmc.visible_vram_size < adev->gmc.real_vram_size && | 440 | if (adev->gmc.visible_vram_size < adev->gmc.real_vram_size && |