drm/amd: Simplify the bo size check funciton
authorMa Jun <Jun.Ma2@amd.com>
Fri, 25 Aug 2023 03:11:51 +0000 (11:11 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 30 Aug 2023 19:51:16 +0000 (15:51 -0400)
Simplify the code logic of size check function amdgpu_bo_validate_size

Signed-off-by: Ma Jun <Jun.Ma2@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_object.c

index ace837cfa0a6bc850c0c706376194eb2d324d5ad..cef920a93924b60140f40fb5020871a3e0c883eb 100644 (file)
@@ -459,7 +459,7 @@ void amdgpu_bo_free_kernel(struct amdgpu_bo **bo, u64 *gpu_addr,
                *cpu_addr = NULL;
 }
 
-/* Validate bo size is bit bigger then the request domain */
+/* Validate bo size is bit bigger than the request domain */
 static bool amdgpu_bo_validate_size(struct amdgpu_device *adev,
                                          unsigned long size, u32 domain)
 {
@@ -469,29 +469,24 @@ static bool amdgpu_bo_validate_size(struct amdgpu_device *adev,
         * If GTT is part of requested domains the check must succeed to
         * allow fall back to GTT.
         */
-       if (domain & AMDGPU_GEM_DOMAIN_GTT) {
+       if (domain & AMDGPU_GEM_DOMAIN_GTT)
                man = ttm_manager_type(&adev->mman.bdev, TTM_PL_TT);
-
-               if (man && size < man->size)
-                       return true;
-               else if (!man)
-                       WARN_ON_ONCE("GTT domain requested but GTT mem manager uninitialized");
-               goto fail;
-       } else if (domain & AMDGPU_GEM_DOMAIN_VRAM) {
+       else if (domain & AMDGPU_GEM_DOMAIN_VRAM)
                man = ttm_manager_type(&adev->mman.bdev, TTM_PL_VRAM);
+       else
+               return true;
 
-               if (man && size < man->size)
-                       return true;
-               goto fail;
+       if (!man) {
+               if (domain & AMDGPU_GEM_DOMAIN_GTT)
+                       WARN_ON_ONCE("GTT domain requested but GTT mem manager uninitialized");
+               return false;
        }
 
        /* TODO add more domains checks, such as AMDGPU_GEM_DOMAIN_CPU, _DOMAIN_DOORBELL */
-       return true;
+       if (size < man->size)
+               return true;
 
-fail:
-       if (man)
-               DRM_DEBUG("BO size %lu > total memory in domain: %llu\n", size,
-                         man->size);
+       DRM_DEBUG("BO size %lu > total memory in domain: %llu\n", size, man->size);
        return false;
 }