]> www.infradead.org Git - users/hch/misc.git/commitdiff
drm/amdgpu: Fix logic to fetch supported NPS modes
authorLijo Lazar <lijo.lazar@amd.com>
Tue, 25 Feb 2025 10:51:51 +0000 (16:21 +0530)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 27 Feb 2025 21:50:03 +0000 (16:50 -0500)
Correct the logic to find supported NPS modes from firmware.

Signed-off-by: Lijo Lazar <lijo.lazar@amd.com>
Reported-by: Ava Zhang <niandong.zhang@amd.com>
Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com>
Fixes: 30eb41f5d1a7 ("drm/amdgpu: Use firmware supported NPS modes")
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c

index ccb31e724b555bdc6d3423ccf3b1a2709a38519f..783e0c3b86b4c4a56fbbfa2cf7ca1a66df61a1de 100644 (file)
@@ -1607,9 +1607,8 @@ static void gmc_v9_0_init_nps_details(struct amdgpu_device *adev)
 
        /* Mode detected by hardware and supported modes available */
        if ((mode != UNKNOWN_MEMORY_PARTITION_MODE) && supp_modes) {
-               for (i = AMDGPU_NPS1_PARTITION_MODE;
-                    supp_modes && i <= AMDGPU_NPS8_PARTITION_MODE; i++) {
-                       if (supp_modes & BIT(i - 1))
+               while ((i = ffs(supp_modes))) {
+                       if (AMDGPU_ALL_NPS_MASK & BIT(i))
                                adev->gmc.supported_nps_modes |= BIT(i);
                        supp_modes &= supp_modes - 1;
                }