mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-12-31 03:39:33 -05:00
iio: light: tsl2772: Make use of device properties
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>
This commit is contained in:
committed by
Jonathan Cameron
parent
87b7b07bf0
commit
f5c822c060
@@ -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 @@ static int tsl2772_get_prox(struct iio_dev *indio_dev)
|
||||
|
||||
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;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user