drm/amd/pm: support pp_dpm_pcie on smu v14.0.2/3
authorKenneth Feng <kenneth.feng@amd.com>
Sat, 11 May 2024 07:35:23 +0000 (15:35 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Fri, 17 May 2024 21:40:38 +0000 (17:40 -0400)
support pp_dpm_pcie on smu v14.0.2/3

Signed-off-by: Kenneth Feng <kenneth.feng@amd.com>
Reviewed-by: Jack Gui <Jack.Gui@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/pm/swsmu/inc/smu_v14_0.h
drivers/gpu/drm/amd/pm/swsmu/smu14/smu_v14_0.c
drivers/gpu/drm/amd/pm/swsmu/smu14/smu_v14_0_2_ppt.c

index 2617d94b4c4de1b65afeac99b350577bd326c88e..3d34b3869df69e6c6b70b4e2e3939e0f5d8f6aeb 100644 (file)
 
 #define SMU14_TOOL_SIZE                        0x19000
 
+extern const int decoded_link_speed[5];
+extern const int decoded_link_width[7];
+
+#define DECODE_GEN_SPEED(gen_speed_idx)                (decoded_link_speed[gen_speed_idx])
+#define DECODE_LANE_WIDTH(lane_width_idx)      (decoded_link_width[lane_width_idx])
+
 struct smu_14_0_max_sustainable_clocks {
        uint32_t display_clock;
        uint32_t phy_clock;
index fe6834f1648b99245eab02b9b44e03db250d0b72..fbfe9cae0e054af8cae3a4b0d2aeb095881685d3 100644 (file)
@@ -46,6 +46,8 @@
 #define regMP1_SMN_IH_SW_INT_CTRL_mp1_14_0_0            0x0342
 #define regMP1_SMN_IH_SW_INT_CTRL_mp1_14_0_0_BASE_IDX   0
 
+const int decoded_link_speed[5] = {1, 2, 3, 4, 5};
+const int decoded_link_width[7] = {0, 1, 2, 4, 8, 12, 16};
 /*
  * DO NOT use these for err/warn/info/debug messages.
  * Use dev_err, dev_warn, dev_info and dev_dbg instead.
index b594b748de473605258e5d1d7d4e389561d05d0d..1fbceb85d3197c03ea7ec141096553092d7e177d 100644 (file)
@@ -1036,6 +1036,8 @@ static int smu_v14_0_2_print_clk_levels(struct smu_context *smu,
        struct smu_dpm_context *smu_dpm = &smu->smu_dpm;
        struct smu_14_0_dpm_context *dpm_context = smu_dpm->dpm_context;
        struct smu_14_0_dpm_table *single_dpm_table;
+       struct smu_14_0_pcie_table *pcie_table;
+       uint32_t gen_speed, lane_width;
        int i, curr_freq, size = 0;
        int ret = 0;
 
@@ -1126,7 +1128,35 @@ static int smu_v14_0_2_print_clk_levels(struct smu_context *smu,
                }
                break;
        case SMU_PCIE:
-               // TODO
+               ret = smu_v14_0_2_get_smu_metrics_data(smu,
+                                                      METRICS_PCIE_RATE,
+                                                      &gen_speed);
+               if (ret)
+                       return ret;
+
+               ret = smu_v14_0_2_get_smu_metrics_data(smu,
+                                                      METRICS_PCIE_WIDTH,
+                                                      &lane_width);
+               if (ret)
+                       return ret;
+
+               pcie_table = &(dpm_context->dpm_tables.pcie_table);
+               for (i = 0; i < pcie_table->num_of_link_levels; i++)
+                       size += sysfs_emit_at(buf, size, "%d: %s %s %dMhz %s\n", i,
+                                       (pcie_table->pcie_gen[i] == 0) ? "2.5GT/s," :
+                                       (pcie_table->pcie_gen[i] == 1) ? "5.0GT/s," :
+                                       (pcie_table->pcie_gen[i] == 2) ? "8.0GT/s," :
+                                       (pcie_table->pcie_gen[i] == 3) ? "16.0GT/s," : "",
+                                       (pcie_table->pcie_lane[i] == 1) ? "x1" :
+                                       (pcie_table->pcie_lane[i] == 2) ? "x2" :
+                                       (pcie_table->pcie_lane[i] == 3) ? "x4" :
+                                       (pcie_table->pcie_lane[i] == 4) ? "x8" :
+                                       (pcie_table->pcie_lane[i] == 5) ? "x12" :
+                                       (pcie_table->pcie_lane[i] == 6) ? "x16" : "",
+                                       pcie_table->clk_freq[i],
+                                       (gen_speed == DECODE_GEN_SPEED(pcie_table->pcie_gen[i])) &&
+                                       (lane_width == DECODE_LANE_WIDTH(pcie_table->pcie_lane[i])) ?
+                                       "*" : "");
                break;
 
        default: