amdgpu/pm: Fix incorrect variable for size of clocks array
authorDarren Powell <darren.powell@amd.com>
Sat, 30 Apr 2022 01:20:52 +0000 (21:20 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 22 Jun 2022 20:55:12 +0000 (16:55 -0400)
 [v2]
No Changes, added RB
 [v1]
Size of pp_clock_levels_with_latency is PP_MAX_CLOCK_LEVELS, not MAX_NUM_CLOCKS.
Both are currently defined as 16, modifying in case one value is modified in future
Changed code in both arcturus and aldabaran.

Also removed unneeded var count, and used min_t function

Signed-off-by: Darren Powell <darren.powell@amd.com>
Reviewed-by: Lijo Lazar <lijo.lazar@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/pm/swsmu/smu11/arcturus_ppt.c
drivers/gpu/drm/amd/pm/swsmu/smu13/aldebaran_ppt.c

index bfabcd3..4450055 100644 (file)
@@ -573,12 +573,13 @@ static int arcturus_get_clk_table(struct smu_context *smu,
                        struct pp_clock_levels_with_latency *clocks,
                        struct smu_11_0_dpm_table *dpm_table)
 {
-       int i, count;
+       uint32_t i;
 
-       count = (dpm_table->count > MAX_NUM_CLOCKS) ? MAX_NUM_CLOCKS : dpm_table->count;
-       clocks->num_levels = count;
+       clocks->num_levels = min_t(uint32_t,
+                                  dpm_table->count,
+                                  (uint32_t)PP_MAX_CLOCK_LEVELS);
 
-       for (i = 0; i < count; i++) {
+       for (i = 0; i < clocks->num_levels; i++) {
                clocks->data[i].clocks_in_khz =
                        dpm_table->dpm_levels[i].value * 1000;
                clocks->data[i].latency_in_us = 0;
index 1133edd..cc96a5b 100644 (file)
@@ -555,12 +555,13 @@ static int aldebaran_get_clk_table(struct smu_context *smu,
                                   struct pp_clock_levels_with_latency *clocks,
                                   struct smu_13_0_dpm_table *dpm_table)
 {
-       int i, count;
+       uint32_t i;
 
-       count = (dpm_table->count > MAX_NUM_CLOCKS) ? MAX_NUM_CLOCKS : dpm_table->count;
-       clocks->num_levels = count;
+       clocks->num_levels = min_t(uint32_t,
+                                  dpm_table->count,
+                                  (uint32_t)PP_MAX_CLOCK_LEVELS);
 
-       for (i = 0; i < count; i++) {
+       for (i = 0; i < clocks->num_levels; i++) {
                clocks->data[i].clocks_in_khz =
                        dpm_table->dpm_levels[i].value * 1000;
                clocks->data[i].latency_in_us = 0;