]> www.infradead.org Git - users/hch/misc.git/commitdiff
drm/amd/pm: Free SMUv13.0.6 resources on failure
authorLijo Lazar <lijo.lazar@amd.com>
Tue, 12 Aug 2025 07:51:49 +0000 (13:21 +0530)
committerAlex Deucher <alexander.deucher@amd.com>
Fri, 15 Aug 2025 17:05:14 +0000 (13:05 -0400)
Free the resources allocated if smu_v13_0_12_tables_init fails.

Signed-off-by: Lijo Lazar <lijo.lazar@amd.com>
Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com>
Fixes: 5bf93e1d6efd ("drm/amd/pm: Add caching to SMUv13.0.12 temp metric")
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_12_ppt.c
drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_6_ppt.c

index ea2682f9d579d5bbf20cf1e4365da145a95afcf5..32fd0be05cffb7f58e6e8ce0f916a9f8b4922097 100644 (file)
@@ -161,8 +161,10 @@ int smu_v13_0_12_tables_init(struct smu_context *smu)
        /* Initialize GPU board temperature metrics */
        ret = smu_table_cache_init(smu, SMU_TABLE_GPUBOARD_TEMP_METRICS,
                                   sizeof(*gpuboard_temp_metrics), 50);
-       if (ret)
+       if (ret) {
+               smu_table_cache_fini(smu, SMU_TABLE_BASEBOARD_TEMP_METRICS);
                return ret;
+       }
        cache = &(tables[SMU_TABLE_GPUBOARD_TEMP_METRICS].cache);
        gpuboard_temp_metrics = (struct amdgpu_gpuboard_temp_metrics_v1_0 *)cache->buffer;
        smu_cmn_init_gpuboard_temp_metrics(gpuboard_temp_metrics, 1, 0);
index cc59d884025ff8cc468b1fd84d8718867fbc772e..627a8188d86805fa941de2051ca84337723d73b0 100644 (file)
@@ -537,6 +537,7 @@ static int smu_v13_0_6_tables_init(struct smu_context *smu)
        struct smu_table *tables = smu_table->tables;
        struct amdgpu_device *adev = smu->adev;
        int gpu_metrcs_size = METRICS_TABLE_SIZE;
+       int ret;
 
        if (!(adev->flags & AMD_IS_APU))
                SMU_TABLE_INIT(tables, SMU_TABLE_PMSTATUSLOG, SMU13_TOOL_SIZE,
@@ -573,8 +574,15 @@ static int smu_v13_0_6_tables_init(struct smu_context *smu)
                return -ENOMEM;
        }
 
-       if (amdgpu_ip_version(smu->adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 12))
-               return smu_v13_0_12_tables_init(smu);
+       if (amdgpu_ip_version(smu->adev, MP1_HWIP, 0) ==
+           IP_VERSION(13, 0, 12)) {
+               ret = smu_v13_0_12_tables_init(smu);
+               if (ret) {
+                       kfree(smu_table->metrics_table);
+                       kfree(smu_table->gpu_metrics_table);
+                       return ret;
+               }
+       }
 
        return 0;
 }