drm/amdgpu: Return error on invalid compute mode
authorLijo Lazar <lijo.lazar@amd.com>
Tue, 7 Mar 2023 05:06:08 +0000 (10:36 +0530)
committerAlex Deucher <alexander.deucher@amd.com>
Fri, 9 Jun 2023 13:57:50 +0000 (09:57 -0400)
Return error if an invalid compute partition mode is requested.

Signed-off-by: Lijo Lazar <lijo.lazar@amd.com>
Reviewed-by: Le Ma <le.ma@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/aqua_vanjaram_reg_init.c
drivers/gpu/drm/amd/amdgpu/gfx_v9_4_3.c

index a165b51e9e58faca2fc7d214695e14d3a175e8a9..848049db00ab1ab20024f90d4a6d5b6da20cc303 100644 (file)
@@ -328,10 +328,14 @@ static int aqua_vanjaram_switch_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr,
        adev = xcp_mgr->adev;
        num_xcc = NUM_XCC(adev->gfx.xcc_mask);
 
-       if (mode == AMDGPU_AUTO_COMPUTE_PARTITION_MODE)
+       if (mode == AMDGPU_AUTO_COMPUTE_PARTITION_MODE) {
                mode = __aqua_vanjaram_get_auto_mode(xcp_mgr);
-       else if (!__aqua_vanjaram_is_valid_mode(xcp_mgr, mode))
+       } else if (!__aqua_vanjaram_is_valid_mode(xcp_mgr, mode)) {
+               dev_err(adev->dev,
+                       "Invalid compute partition mode requested, requested: %s, available memory partitions: %d",
+                       amdgpu_gfx_compute_mode_desc(mode), adev->gmc.num_mem_partitions);
                return -EINVAL;
+       }
 
        if (adev->kfd.init_complete)
                flags |= AMDGPU_XCP_OPS_KFD;
index 81ab3cd2f229661e94702bec8c643050cd37a2ef..d0ddcd751432f9bd9ad56f590dd2a1e549a3a4eb 100644 (file)
@@ -1933,7 +1933,11 @@ static int gfx_v9_4_3_cp_resume(struct amdgpu_device *adev)
        if (amdgpu_xcp_query_partition_mode(adev->xcp_mgr,
                                            AMDGPU_XCP_FL_NONE) ==
            AMDGPU_UNKNOWN_COMPUTE_PARTITION_MODE)
-               amdgpu_xcp_switch_partition_mode(adev->xcp_mgr, amdgpu_user_partt_mode);
+               r = amdgpu_xcp_switch_partition_mode(adev->xcp_mgr,
+                                                    amdgpu_user_partt_mode);
+
+       if (r)
+               return r;
 
        num_xcc = NUM_XCC(adev->gfx.xcc_mask);
        for (i = 0; i < num_xcc; i++) {