drm/amd/pm: Add default feature number definition
authorLijo Lazar <lijo.lazar@amd.com>
Mon, 19 Jan 2026 13:02:19 +0000 (18:32 +0530)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 3 Feb 2026 21:46:20 +0000 (16:46 -0500)
The number of default features could be different from the actual width
of the bitmap. Use a different definition for it. Also increase the max
width of bitmap to 128.

Signed-off-by: Lijo Lazar <lijo.lazar@amd.com>
Reviewed-by: Asad Kamal <asad.kamal@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/pm/swsmu/amdgpu_smu.c
drivers/gpu/drm/amd/pm/swsmu/inc/amdgpu_smu.h
drivers/gpu/drm/amd/pm/swsmu/smu11/smu_v11_0.c
drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0.c
drivers/gpu/drm/amd/pm/swsmu/smu14/smu_v14_0.c
drivers/gpu/drm/amd/pm/swsmu/smu15/smu_v15_0.c
drivers/gpu/drm/amd/pm/swsmu/smu_cmn.c

index 797da21..9f52b7b 100644 (file)
@@ -1355,7 +1355,7 @@ static int smu_sw_init(struct amdgpu_ip_block *ip_block)
        int i, ret;
 
        smu->pool_size = adev->pm.smu_prv_buffer_size;
-       smu_feature_init(smu, SMU_FEATURE_MAX);
+       smu_feature_init(smu, SMU_FEATURE_NUM_DEFAULT);
 
        INIT_WORK(&smu->throttling_logging_work, smu_throttling_logging_work_fn);
        INIT_WORK(&smu->interrupt_work, smu_interrupt_work_fn);
index 4019ef8..512493a 100644 (file)
@@ -471,7 +471,8 @@ struct smu_power_context {
        struct smu_power_gate power_gate;
 };
 
-#define SMU_FEATURE_MAX        (64)
+#define SMU_FEATURE_NUM_DEFAULT (64)
+#define SMU_FEATURE_MAX (128)
 
 struct smu_feature_bits {
        DECLARE_BITMAP(bits, SMU_FEATURE_MAX);
index 1d0f9f8..56efcfa 100644 (file)
@@ -751,7 +751,7 @@ int smu_v11_0_set_allowed_mask(struct smu_context *smu)
        uint32_t feature_mask[2];
 
        if (smu_feature_list_is_empty(smu, SMU_FEATURE_LIST_ALLOWED) ||
-           feature->feature_num < 64) {
+           feature->feature_num < SMU_FEATURE_NUM_DEFAULT) {
                ret = -EINVAL;
                goto failed;
        }
index 3b0aa6a..63a65ea 100644 (file)
@@ -762,7 +762,7 @@ int smu_v13_0_set_allowed_mask(struct smu_context *smu)
        uint32_t feature_mask[2];
 
        if (smu_feature_list_is_empty(smu, SMU_FEATURE_LIST_ALLOWED) ||
-           feature->feature_num < 64)
+           feature->feature_num < SMU_FEATURE_NUM_DEFAULT)
                return -EINVAL;
 
        smu_feature_list_to_arr32(smu, SMU_FEATURE_LIST_ALLOWED, feature_mask);
index cabbd23..7dc6687 100644 (file)
@@ -747,7 +747,7 @@ int smu_v14_0_set_allowed_mask(struct smu_context *smu)
        uint32_t feature_mask[2];
 
        if (smu_feature_list_is_empty(smu, SMU_FEATURE_LIST_ALLOWED) ||
-           feature->feature_num < 64)
+           feature->feature_num < SMU_FEATURE_NUM_DEFAULT)
                return -EINVAL;
 
        smu_feature_list_to_arr32(smu, SMU_FEATURE_LIST_ALLOWED, feature_mask);
index d77eaac..a2854d5 100644 (file)
@@ -716,7 +716,7 @@ int smu_v15_0_set_allowed_mask(struct smu_context *smu)
        uint32_t feature_mask[2];
 
        if (smu_feature_list_is_empty(smu, SMU_FEATURE_LIST_ALLOWED) ||
-           feature->feature_num < 64)
+           feature->feature_num < SMU_FEATURE_NUM_DEFAULT)
                return -EINVAL;
 
        smu_feature_list_to_arr32(smu, SMU_FEATURE_LIST_ALLOWED, feature_mask);
index a9e0b52..6fd50c2 100644 (file)
@@ -794,7 +794,8 @@ int smu_cmn_get_enabled_mask(struct smu_context *smu,
        }
 
        if (!ret)
-               smu_feature_bits_from_arr32(feature_mask, features, 64);
+               smu_feature_bits_from_arr32(feature_mask, features,
+                                           SMU_FEATURE_NUM_DEFAULT);
 
        return ret;
 }
@@ -909,7 +910,8 @@ size_t smu_cmn_get_pp_feature_mask(struct smu_context *smu,
        size += sysfs_emit_at(buf, size, "%-2s. %-20s  %-3s : %-s\n",
                        "No", "Feature", "Bit", "State");
 
-       for (feature_index = 0; feature_index < SMU_FEATURE_MAX; feature_index++) {
+       for (feature_index = 0; feature_index < smu->smu_feature.feature_num;
+            feature_index++) {
                if (sort_feature[feature_index] < 0)
                        continue;