]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
hwmon: (pmbus/tps25990) Don't check for specific errors when parsing properties
authorAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Thu, 19 Feb 2026 14:19:36 +0000 (15:19 +0100)
committerGuenter Roeck <linux@roeck-us.net>
Sun, 12 Apr 2026 14:23:51 +0000 (07:23 -0700)
Instead of checking for the specific error codes (that can be considered
a layering violation to some extent) check for the property existence first
and then either parse it, or apply a default value.

Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20260219141936.2259945-1-andriy.shevchenko@linux.intel.com
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
drivers/hwmon/pmbus/tps25990.c

index c13edd7e1abfc560e722ff3c7f6fc4d14f954939..05c6288ecafccb43c8f4d73b97732e0dd6090254 100644 (file)
@@ -402,12 +402,18 @@ static int tps25990_probe(struct i2c_client *client)
 {
        struct device *dev = &client->dev;
        struct pmbus_driver_info *info;
-       u32 rimon = TPS25990_DEFAULT_RIMON;
+       const char *propname;
+       u32 rimon;
        int ret;
 
-       ret = device_property_read_u32(dev, "ti,rimon-micro-ohms", &rimon);
-       if (ret < 0 && ret != -EINVAL)
-               return dev_err_probe(dev, ret, "failed to get rimon\n");
+       propname = "ti,rimon-micro-ohms";
+       if (device_property_present(dev, propname)) {
+               ret = device_property_read_u32(dev, propname, &rimon);
+               if (ret)
+                       return dev_err_probe(dev, ret, "failed to get %s\n", propname);
+       } else {
+               rimon = TPS25990_DEFAULT_RIMON;
+       }
 
        info = devm_kmemdup(dev, &tps25990_base_info, sizeof(*info), GFP_KERNEL);
        if (!info)