mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-09 11:23:09 -04:00
platform/x86: alienware-wmi-wmax: Fix uninitialized variable due to bad error handling
wmax_thermal_information() may also return -ENOMSG, which would leave
`id` uninitialized in thermal_profile_probe.
Reorder and modify logic to catch all errors.
Reported-by: Dan Carpenter <dan.carpenter@linaro.org>
Closes: https://lore.kernel.org/r/Z_-KVqNbD9ygvE2X@stanley.mountain
Fixes: 27e9e63398 ("platform/x86: alienware-wmi: Refactor thermal control methods")
Signed-off-by: Kurt Borja <kuurtb@gmail.com>
Link: https://lore.kernel.org/r/20250416-smatch-fix-v1-1-35491b462d8f@gmail.com
Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
This commit is contained in:
committed by
Ilpo Järvinen
parent
8d6955ed76
commit
4a8e04e2bd
@@ -655,12 +655,10 @@ static int thermal_profile_probe(void *drvdata, unsigned long *choices)
|
||||
for (u32 i = 0; i < sys_desc[3]; i++) {
|
||||
ret = wmax_thermal_information(priv->wdev, WMAX_OPERATION_LIST_IDS,
|
||||
i + first_mode, &out_data);
|
||||
|
||||
if (ret == -EIO)
|
||||
return ret;
|
||||
|
||||
if (ret == -EBADRQC)
|
||||
break;
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
if (!is_wmax_thermal_code(out_data))
|
||||
continue;
|
||||
|
||||
Reference in New Issue
Block a user