iio: light: tsl2772: Make use of device properties
authorAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Wed, 13 Apr 2022 18:14:02 +0000 (21:14 +0300)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Thu, 28 Apr 2022 18:22:55 +0000 (19:22 +0100)
Convert the module to be property provider agnostic and allow
it to be used on non-OF platforms.

While at it, reuse temporary device pointer in the same function.

Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20220413181402.19582-1-andriy.shevchenko@linux.intel.com
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
drivers/iio/light/tsl2772.c

index 729f14d9f2a4bb18cc65e311d7450fb9d9485298..dd9051f1cc1a0a957d470ebc33630cf718100819 100644 (file)
@@ -15,7 +15,9 @@
 #include <linux/kernel.h>
 #include <linux/module.h>
 #include <linux/mutex.h>
+#include <linux/property.h>
 #include <linux/slab.h>
+
 #include <linux/iio/events.h>
 #include <linux/iio/iio.h>
 #include <linux/iio/sysfs.h>
@@ -549,10 +551,10 @@ prox_poll_err:
 
 static int tsl2772_read_prox_led_current(struct tsl2772_chip *chip)
 {
-       struct device_node *of_node = chip->client->dev.of_node;
+       struct device *dev = &chip->client->dev;
        int ret, tmp, i;
 
-       ret = of_property_read_u32(of_node, "led-max-microamp", &tmp);
+       ret = device_property_read_u32(dev, "led-max-microamp", &tmp);
        if (ret < 0)
                return ret;
 
@@ -563,20 +565,18 @@ static int tsl2772_read_prox_led_current(struct tsl2772_chip *chip)
                }
        }
 
-       dev_err(&chip->client->dev, "Invalid value %d for led-max-microamp\n",
-               tmp);
+       dev_err(dev, "Invalid value %d for led-max-microamp\n", tmp);
 
        return -EINVAL;
-
 }
 
 static int tsl2772_read_prox_diodes(struct tsl2772_chip *chip)
 {
-       struct device_node *of_node = chip->client->dev.of_node;
+       struct device *dev = &chip->client->dev;
        int i, ret, num_leds, prox_diode_mask;
        u32 leds[TSL2772_MAX_PROX_LEDS];
 
-       ret = of_property_count_u32_elems(of_node, "amstaos,proximity-diodes");
+       ret = device_property_count_u32(dev, "amstaos,proximity-diodes");
        if (ret < 0)
                return ret;
 
@@ -584,12 +584,9 @@ static int tsl2772_read_prox_diodes(struct tsl2772_chip *chip)
        if (num_leds > TSL2772_MAX_PROX_LEDS)
                num_leds = TSL2772_MAX_PROX_LEDS;
 
-       ret = of_property_read_u32_array(of_node, "amstaos,proximity-diodes",
-                                        leds, num_leds);
+       ret = device_property_read_u32_array(dev, "amstaos,proximity-diodes", leds, num_leds);
        if (ret < 0) {
-               dev_err(&chip->client->dev,
-                       "Invalid value for amstaos,proximity-diodes: %d.\n",
-                       ret);
+               dev_err(dev, "Invalid value for amstaos,proximity-diodes: %d.\n", ret);
                return ret;
        }
 
@@ -600,9 +597,7 @@ static int tsl2772_read_prox_diodes(struct tsl2772_chip *chip)
                else if (leds[i] == 1)
                        prox_diode_mask |= TSL2772_DIODE1;
                else {
-                       dev_err(&chip->client->dev,
-                               "Invalid value %d in amstaos,proximity-diodes.\n",
-                               leds[i]);
+                       dev_err(dev, "Invalid value %d in amstaos,proximity-diodes.\n", leds[i]);
                        return -EINVAL;
                }
        }