]> git.baikalelectronics.ru Git - kernel.git/commitdiff
thermal/core: fix error code in __thermal_cooling_device_register()
authorDan Carpenter <dan.carpenter@oracle.com>
Fri, 28 Oct 2022 15:02:34 +0000 (18:02 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 1 Feb 2023 07:34:26 +0000 (08:34 +0100)
[ Upstream commit 4e2729ef5aa8400c15a84a9de558217efc8ec7d8 ]

Return an error pointer if ->get_max_state() fails.  The current code
returns NULL which will cause an oops in the callers.

Fixes: 743160b98189 ("thermal: Validate new state in cur_state_store()")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Stable-dep-of: f165a55dea80 ("thermal: core: call put_device() only after device_register() fails")
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/thermal/thermal_core.c

index 328da2f1d3393b557d7692f4806231b28be0d08a..449e60c4a1b69e2cc3fa7f36bb657c0873585de1 100644 (file)
@@ -892,7 +892,8 @@ __thermal_cooling_device_register(struct device_node *np,
        cdev->device.class = &thermal_class;
        cdev->devdata = devdata;
 
-       if (cdev->ops->get_max_state(cdev, &cdev->max_state))
+       ret = cdev->ops->get_max_state(cdev, &cdev->max_state);
+       if (ret)
                goto out_kfree_type;
 
        thermal_cooling_device_setup_sysfs(cdev);