Commit 81114fc3 authored by Eliav Farber's avatar Eliav Farber Committed by Guenter Roeck

hwmon: (mr75203) fix VM sensor allocation when "intel,vm-map" not defined

Bug - in case "intel,vm-map" is missing in device-tree ,'num' is set
to 0, and no voltage channel infos are allocated.

The reason num is set to 0 when "intel,vm-map" is missing is to set the
entire pvt->vm_idx[] with incremental channel numbers, but it didn't
take into consideration that same num is used later in devm_kcalloc().

If "intel,vm-map" does exist there is no need to set the unspecified
channels with incremental numbers, because the unspecified channels
can't be accessed in pvt_read_in() which is the only other place besides
the probe functions that uses pvt->vm_idx[].

This change fixes the bug by moving the incremental channel numbers
setting to be done only if "intel,vm-map" property is defined (starting
loop from 0), and removing 'num = 0'.

Fixes: 9d823351 ("hwmon: Add hardware monitoring driver for Moortec MR75203 PVT controller")
Signed-off-by: default avatarEliav Farber <farbere@amazon.com>
Reviewed-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20220908152449.35457-3-farbere@amazon.comSigned-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
parent d0b34d5b
...@@ -584,7 +584,12 @@ static int mr75203_probe(struct platform_device *pdev) ...@@ -584,7 +584,12 @@ static int mr75203_probe(struct platform_device *pdev)
ret = device_property_read_u8_array(dev, "intel,vm-map", ret = device_property_read_u8_array(dev, "intel,vm-map",
pvt->vm_idx, vm_num); pvt->vm_idx, vm_num);
if (ret) { if (ret) {
num = 0; /*
* Incase intel,vm-map property is not defined, we
* assume incremental channel numbers.
*/
for (i = 0; i < vm_num; i++)
pvt->vm_idx[i] = i;
} else { } else {
for (i = 0; i < vm_num; i++) for (i = 0; i < vm_num; i++)
if (pvt->vm_idx[i] >= vm_num || if (pvt->vm_idx[i] >= vm_num ||
...@@ -594,13 +599,6 @@ static int mr75203_probe(struct platform_device *pdev) ...@@ -594,13 +599,6 @@ static int mr75203_probe(struct platform_device *pdev)
} }
} }
/*
* Incase intel,vm-map property is not defined, we assume
* incremental channel numbers.
*/
for (i = num; i < vm_num; i++)
pvt->vm_idx[i] = i;
in_config = devm_kcalloc(dev, num + 1, in_config = devm_kcalloc(dev, num + 1,
sizeof(*in_config), GFP_KERNEL); sizeof(*in_config), GFP_KERNEL);
if (!in_config) if (!in_config)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment