]> git.apps.os.sepia.ceph.com Git - ceph-client.git/commitdiff
thermal/drivers/tegra: Fix crash when getting critical temp
authorJon Hunter <jonathanh@nvidia.com>
Mon, 10 Oct 2022 15:03:11 +0000 (16:03 +0100)
committerDaniel Lezcano <daniel.lezcano@kernel.org>
Fri, 6 Jan 2023 13:14:48 +0000 (14:14 +0100)
Commit 13bea86623be ("thermal/of: Remove of_thermal_get_crit_temp()")
removed the function of_thermal_get_crit_temp() and this is causing a
NULL pointer deference crash when attempting to call the 'get_crit_temp'
function pointer because this function pointer is no longer initialised.
Fix this by replacing the call to the 'get_crit_temp' function pointer
with a call to the function thermal_zone_get_crit_temp() instead.

Fixes: 13bea86623be ("thermal/of: Remove of_thermal_get_crit_temp()")
Signed-off-by: Jon Hunter <jonathanh@nvidia.com>
Link: https://lore.kernel.org/r/20221010150311.40384-1-jonathanh@nvidia.com
Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
drivers/thermal/tegra/soctherm.c

index d2e454902689ee69e9b7e3f9b758c9b40a754bd0..4203e74e2f797f374c7dbd8e060d8d0116e8cb71 100644 (file)
@@ -742,7 +742,7 @@ static int tegra_soctherm_set_hwtrips(struct device *dev,
        /* Get thermtrips. If missing, try to get critical trips. */
        temperature = tsensor_group_thermtrip_get(ts, sg->id);
        if (min_low_temp == temperature)
-               if (tz->ops->get_crit_temp(tz, &temperature))
+               if (thermal_zone_get_crit_temp(tz, &temperature))
                        temperature = max_high_temp;
 
        ret = thermtrip_program(dev, sg, temperature);