From: Lucas Magasweran Date: Tue, 8 May 2018 11:43:33 +0000 (-0700) Subject: hwmon: (core) check parent dev != NULL when chip != NULL X-Git-Tag: v4.19~944^2~9 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=59df4f4e8e0b9a0abb14ad5128d36d844c3e2689;p=platform%2Fkernel%2Flinux-rpi.git hwmon: (core) check parent dev != NULL when chip != NULL hwmon_device_register_with_info() registration API requires a non-NULL parent device when chip is non-NULL. This commit adds a check and documents this requirement. Signed-off-by: Lucas Magasweran Signed-off-by: Guenter Roeck --- diff --git a/Documentation/hwmon/hwmon-kernel-api.txt b/Documentation/hwmon/hwmon-kernel-api.txt index 53a8066..eb7a78a 100644 --- a/Documentation/hwmon/hwmon-kernel-api.txt +++ b/Documentation/hwmon/hwmon-kernel-api.txt @@ -71,7 +71,8 @@ hwmon_device_register_with_info is the most comprehensive and preferred means to register a hardware monitoring device. It creates the standard sysfs attributes in the hardware monitoring core, letting the driver focus on reading from and writing to the chip instead of having to bother with sysfs attributes. -Its parameters are described in more detail below. +The parent device parameter cannot be NULL with non-NULL chip info. Its +parameters are described in more detail below. devm_hwmon_device_register_with_info is similar to hwmon_device_register_with_info. However, it is device managed, meaning the diff --git a/drivers/hwmon/hwmon.c b/drivers/hwmon/hwmon.c index 32083e4..e88c019 100644 --- a/drivers/hwmon/hwmon.c +++ b/drivers/hwmon/hwmon.c @@ -698,6 +698,9 @@ hwmon_device_register_with_info(struct device *dev, const char *name, if (chip && (!chip->ops || !chip->ops->is_visible || !chip->info)) return ERR_PTR(-EINVAL); + if (chip && !dev) + return ERR_PTR(-EINVAL); + return __hwmon_device_register(dev, name, drvdata, chip, extra_groups); } EXPORT_SYMBOL_GPL(hwmon_device_register_with_info);