Commit fd81d7e9 authored by Andy Shevchenko's avatar Andy Shevchenko Committed by Jacek Anaszewski

leds: Switch to use fwnode instead of be stuck with OF one

There is no need to be stuck with OF node when we may use agnostic
firmware node instead.

It allows users to get property if needed independently of provider.

Note, some OF parts are left because %pfw [1] is in progress.

[1]: https://lore.kernel.org/patchwork/cover/1054863/Signed-off-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: default avatarJacek Anaszewski <jacek.anaszewski@gmail.com>
parent ae6c4c70
...@@ -14,7 +14,7 @@ ...@@ -14,7 +14,7 @@
#include <linux/leds.h> #include <linux/leds.h>
#include <linux/list.h> #include <linux/list.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of.h> #include <linux/property.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/timer.h> #include <linux/timer.h>
...@@ -277,7 +277,7 @@ int led_classdev_register_ext(struct device *parent, ...@@ -277,7 +277,7 @@ int led_classdev_register_ext(struct device *parent,
return PTR_ERR(led_cdev->dev); return PTR_ERR(led_cdev->dev);
} }
if (init_data && init_data->fwnode) if (init_data && init_data->fwnode)
led_cdev->dev->of_node = to_of_node(init_data->fwnode); led_cdev->dev->fwnode = init_data->fwnode;
if (ret) if (ret)
dev_warn(parent, "Led %s renamed to %s due to name collision", dev_warn(parent, "Led %s renamed to %s due to name collision",
......
...@@ -324,14 +324,11 @@ EXPORT_SYMBOL_GPL(led_update_brightness); ...@@ -324,14 +324,11 @@ EXPORT_SYMBOL_GPL(led_update_brightness);
u32 *led_get_default_pattern(struct led_classdev *led_cdev, unsigned int *size) u32 *led_get_default_pattern(struct led_classdev *led_cdev, unsigned int *size)
{ {
struct device_node *np = dev_of_node(led_cdev->dev); struct fwnode_handle *fwnode = led_cdev->dev->fwnode;
u32 *pattern; u32 *pattern;
int count; int count;
if (!np) count = fwnode_property_count_u32(fwnode, "led-pattern");
return NULL;
count = of_property_count_u32_elems(np, "led-pattern");
if (count < 0) if (count < 0)
return NULL; return NULL;
...@@ -339,7 +336,7 @@ u32 *led_get_default_pattern(struct led_classdev *led_cdev, unsigned int *size) ...@@ -339,7 +336,7 @@ u32 *led_get_default_pattern(struct led_classdev *led_cdev, unsigned int *size)
if (!pattern) if (!pattern)
return NULL; return NULL;
if (of_property_read_u32_array(np, "led-pattern", pattern, count)) { if (fwnode_property_read_u32_array(fwnode, "led-pattern", pattern, count)) {
kfree(pattern); kfree(pattern);
return NULL; return NULL;
} }
......
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