]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
drm/amdgpu: Add smu v13_0_14 ip block
authorHawking Zhang <Hawking.Zhang@amd.com>
Tue, 30 Apr 2024 16:12:34 +0000 (00:12 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 2 May 2024 19:49:11 +0000 (15:49 -0400)
Add smu v13_0_14 ip block support

Signed-off-by: Hawking Zhang <Hawking.Zhang@amd.com>
Reviewed-by: Le Ma <Le.Ma@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_aca.c
drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c
drivers/gpu/drm/amd/amdgpu/amdgpu_fru_eeprom.c
drivers/gpu/drm/amd/amdgpu/amdgpu_mca.c
drivers/gpu/drm/amd/amdgpu/amdgpu_ras_eeprom.c
drivers/gpu/drm/amd/amdgpu/amdgpu_reset.c
drivers/gpu/drm/amd/amdgpu/soc15.c
drivers/gpu/drm/amd/pm/swsmu/amdgpu_smu.c
drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0.c
drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_6_ppt.c

index c50202215f6b19f5360d200ecce280856ff89cde..28febf33fb1bc3830b5ac3a72c3943c65cf9706d 100644 (file)
@@ -892,7 +892,9 @@ DEFINE_DEBUGFS_ATTRIBUTE(aca_debug_mode_fops, NULL, amdgpu_aca_smu_debug_mode_se
 void amdgpu_aca_smu_debugfs_init(struct amdgpu_device *adev, struct dentry *root)
 {
 #if defined(CONFIG_DEBUG_FS)
-       if (!root || adev->ip_versions[MP1_HWIP][0] != IP_VERSION(13, 0, 6))
+       if (!root ||
+           (adev->ip_versions[MP1_HWIP][0] != IP_VERSION(13, 0, 6) &&
+            adev->ip_versions[MP1_HWIP][0] != IP_VERSION(13, 0, 14)))
                return;
 
        debugfs_create_file("aca_debug_mode", 0200, root, adev, &aca_debug_mode_fops);
index f4fefda7e7d849372b8be909c3ca936f2cf9273a..572c6ac27ccc3c13b0f0570c4ef79c1e613fcdf9 100644 (file)
@@ -1910,6 +1910,7 @@ static int amdgpu_discovery_set_smu_ip_blocks(struct amdgpu_device *adev)
        case IP_VERSION(13, 0, 8):
        case IP_VERSION(13, 0, 10):
        case IP_VERSION(13, 0, 11):
+       case IP_VERSION(13, 0, 14):
                amdgpu_device_ip_block_add(adev, &smu_v13_0_ip_block);
                break;
        case IP_VERSION(14, 0, 0):
index a08c148b13f92aa9bc0c158d0caf633c5d2043f4..ceb5163480f4c2f5103088cb28956eb972ef785f 100644 (file)
@@ -100,6 +100,7 @@ static bool is_fru_eeprom_supported(struct amdgpu_device *adev, u32 *fru_addr)
                                *fru_addr = FRU_EEPROM_MADDR_6;
                return true;
        case IP_VERSION(13, 0, 6):
+       case IP_VERSION(13, 0, 14):
                        if (fru_addr)
                                *fru_addr = FRU_EEPROM_MADDR_8;
                        return true;
index a111751b978184154be95befc414326a815505f8..7b7040ec61bd743ff77393ab5e11afb5ebb38636 100644 (file)
@@ -609,7 +609,9 @@ DEFINE_DEBUGFS_ATTRIBUTE(mca_debug_mode_fops, NULL, amdgpu_mca_smu_debug_mode_se
 void amdgpu_mca_smu_debugfs_init(struct amdgpu_device *adev, struct dentry *root)
 {
 #if defined(CONFIG_DEBUG_FS)
-       if (!root || amdgpu_ip_version(adev, MP1_HWIP, 0) != IP_VERSION(13, 0, 6))
+       if (!root ||
+           (amdgpu_ip_version(adev, MP1_HWIP, 0) != IP_VERSION(13, 0, 6) &&
+            amdgpu_ip_version(adev, MP1_HWIP, 0) != IP_VERSION(13, 0, 14)))
                return;
 
        debugfs_create_file("mca_debug_mode", 0200, root, adev, &mca_debug_mode_fops);
index 06a62a8a992e9b647a4e88087192f7f5ddc58da3..9b789dcc2bd170df6e54359cedbdd7df1270b6ac 100644 (file)
@@ -161,6 +161,7 @@ static bool __is_ras_eeprom_supported(struct amdgpu_device *adev)
        case IP_VERSION(13, 0, 10):
                return true;
        case IP_VERSION(13, 0, 6):
+       case IP_VERSION(13, 0, 14):
                return (adev->gmc.is_app_apu) ? false : true;
        default:
                return false;
@@ -222,6 +223,7 @@ static bool __get_eeprom_i2c_addr(struct amdgpu_device *adev,
                return true;
        case IP_VERSION(13, 0, 6):
        case IP_VERSION(13, 0, 10):
+       case IP_VERSION(13, 0, 14):
                control->i2c_address = EEPROM_I2C_MADDR_4;
                return true;
        default:
index ea4873f6ccd19680ebfc352be49286aa40ddd70a..bfdde772b7ee04dd160f3872b6ec216318074ffb 100644 (file)
@@ -33,6 +33,7 @@ int amdgpu_reset_init(struct amdgpu_device *adev)
        switch (amdgpu_ip_version(adev, MP1_HWIP, 0)) {
        case IP_VERSION(13, 0, 2):
        case IP_VERSION(13, 0, 6):
+       case IP_VERSION(13, 0, 14):
                ret = aldebaran_reset_init(adev);
                break;
        case IP_VERSION(11, 0, 7):
@@ -55,6 +56,7 @@ int amdgpu_reset_fini(struct amdgpu_device *adev)
        switch (amdgpu_ip_version(adev, MP1_HWIP, 0)) {
        case IP_VERSION(13, 0, 2):
        case IP_VERSION(13, 0, 6):
+       case IP_VERSION(13, 0, 14):
                ret = aldebaran_reset_fini(adev);
                break;
        case IP_VERSION(11, 0, 7):
index 55ee5ac828794c1e2cd40f20143c06b08ba74301..5169795df38c2ac4269cef2e5dd3e24e0d062fb5 100644 (file)
@@ -326,7 +326,8 @@ static u32 soc15_get_xclk(struct amdgpu_device *adev)
 
        if (amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(12, 0, 0) ||
            amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(12, 0, 1) ||
-           amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 6))
+           amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 6) ||
+           amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 14))
                return 10000;
        if (amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(10, 0, 0) ||
            amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(10, 0, 1))
@@ -554,6 +555,7 @@ soc15_asic_reset_method(struct amdgpu_device *adev)
                        return AMD_RESET_METHOD_MODE2;
                break;
        case IP_VERSION(13, 0, 6):
+       case IP_VERSION(13, 0, 14):
                /* Use gpu_recovery param to target a reset method.
                 * Enable triggering of GPU reset only if specified
                 * by module parameter.
index 7789b313285c4b478cb5f96b627642796aadc95f..bdf9f80311870790d44db386bd0fdc94c6a51bc4 100644 (file)
@@ -705,6 +705,7 @@ static int smu_set_funcs(struct amdgpu_device *adev)
                smu_v13_0_0_set_ppt_funcs(smu);
                break;
        case IP_VERSION(13, 0, 6):
+       case IP_VERSION(13, 0, 14):
                smu_v13_0_6_set_ppt_funcs(smu);
                /* Enable pp_od_clk_voltage node */
                smu->od_enabled = true;
@@ -2716,6 +2717,7 @@ int smu_get_power_limit(void *handle,
                        switch (amdgpu_ip_version(adev, MP1_HWIP, 0)) {
                        case IP_VERSION(13, 0, 2):
                        case IP_VERSION(13, 0, 6):
+                       case IP_VERSION(13, 0, 14):
                        case IP_VERSION(11, 0, 7):
                        case IP_VERSION(11, 0, 11):
                        case IP_VERSION(11, 0, 12):
index ed5a7a83c9e27f025235c2d50bb864a83aa26340..0fd25b72a40c2bce257b7328e81d8b251ac215ac 100644 (file)
@@ -271,7 +271,8 @@ int smu_v13_0_check_fw_version(struct smu_context *smu)
        smu_minor = (smu_version >> 8) & 0xff;
        smu_debug = (smu_version >> 0) & 0xff;
        if (smu->is_apu ||
-           amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 6))
+           amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 6) ||
+           amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 14))
                adev->pm.fw_version = smu_version;
 
        /* only for dGPU w/ SMU13*/
index a923e44451d62e33c4bfa5b9b0805c9fdcab80fa..051092f1b1b4a0a9d346fe9c46bc3aa102d64b38 100644 (file)
@@ -68,6 +68,7 @@
 #undef pr_debug
 
 MODULE_FIRMWARE("amdgpu/smu_13_0_6.bin");
+MODULE_FIRMWARE("amdgpu/smu_13_0_14.bin");
 
 #define to_amdgpu_device(x) (container_of(x, struct amdgpu_device, pm.smu_i2c))
 
@@ -462,8 +463,10 @@ static ssize_t smu_v13_0_6_get_pm_metrics(struct smu_context *smu,
 
        memset(&pm_metrics->common_header, 0,
               sizeof(pm_metrics->common_header));
-       pm_metrics->common_header.mp1_ip_discovery_version =
-               IP_VERSION(13, 0, 6);
+       if (amdgpu_ip_version(smu->adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 6))
+               pm_metrics->common_header.mp1_ip_discovery_version = IP_VERSION(13, 0, 6);
+       if (amdgpu_ip_version(smu->adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 14))
+               pm_metrics->common_header.mp1_ip_discovery_version = IP_VERSION(13, 0, 14);
        pm_metrics->common_header.pmfw_version = pmfw_version;
        pm_metrics->common_header.pmmetrics_version = table_version;
        pm_metrics->common_header.structure_size =