Hi Sakari,

I've come across this patch only by a chance. I believe that merging
leds-as3645a.c patches via media tree is not going to be a persistent
pattern. At least we haven't agreed on that, and in any case I should
have a possibility to give my ack for this patch.

Would you mind also adding linux-leds list on cc when touching areas
related to LED/flash devices?

Thanks in advance.

Best regards,
Jacek Anaszewski

On 09/08/2017 03:18 PM, Sakari Ailus wrote:
> Switch the as3645a from OF to the fwnode property API. Also add ACPI
> support.
> 
> Signed-off-by: Sakari Ailus <sakari.ai...@linux.intel.com>
> ---
>  drivers/leds/leds-as3645a.c | 81 
> +++++++++++++++++++++++++--------------------
>  1 file changed, 46 insertions(+), 35 deletions(-)
> 
> diff --git a/drivers/leds/leds-as3645a.c b/drivers/leds/leds-as3645a.c
> index 605e0c64e974..2e73c3f818f1 100644
> --- a/drivers/leds/leds-as3645a.c
> +++ b/drivers/leds/leds-as3645a.c
> @@ -25,7 +25,7 @@
>  #include <linux/leds.h>
>  #include <linux/module.h>
>  #include <linux/mutex.h>
> -#include <linux/of.h>
> +#include <linux/property.h>
>  #include <linux/slab.h>
>  
>  #include <media/v4l2-flash-led-class.h>
> @@ -148,8 +148,8 @@ struct as3645a {
>       struct v4l2_flash *vf;
>       struct v4l2_flash *vfind;
>  
> -     struct device_node *flash_node;
> -     struct device_node *indicator_node;
> +     struct fwnode_handle *flash_node;
> +     struct fwnode_handle *indicator_node;
>  
>       struct as3645a_config cfg;
>  
> @@ -492,30 +492,33 @@ static int as3645a_detect(struct as3645a *flash)
>  
>  static int as3645a_parse_node(struct as3645a *flash,
>                             struct as3645a_names *names,
> -                           struct device_node *node)
> +                           struct fwnode_handle *fwnode)
>  {
>       struct as3645a_config *cfg = &flash->cfg;
> -     struct device_node *child;
> +     struct fwnode_handle *child;
>       const char *name;
> +     const char *str;
>       int rval;
>  
> -     for_each_child_of_node(node, child) {
> +     fwnode_for_each_child_node(fwnode, child) {
>               u32 id = 0;
>  
> -             of_property_read_u32(child, "reg", &id);
> +             fwnode_property_read_u32(
> +                     child, is_of_node(child) ? "reg" : "led", &id);
>  
>               switch (id) {
>               case AS_LED_FLASH:
> -                     flash->flash_node = of_node_get(child);
> +                     flash->flash_node = child;
>                       break;
>               case AS_LED_INDICATOR:
> -                     flash->indicator_node = of_node_get(child);
> +                     flash->indicator_node = child;
>                       break;
>               default:
>                       dev_warn(&flash->client->dev,
>                                "unknown LED %u encountered, ignoring\n", id);
>                       break;
>               }
> +             fwnode_handle_get(child);
>       }
>  
>       if (!flash->flash_node) {
> @@ -523,14 +526,18 @@ static int as3645a_parse_node(struct as3645a *flash,
>               return -ENODEV;
>       }
>  
> -     rval = of_property_read_string(flash->flash_node, "label", &name);
> -     if (!rval)
> +     rval = fwnode_property_read_string(flash->flash_node, "label", &name);
> +     if (!rval) {
>               strlcpy(names->flash, name, sizeof(names->flash));
> -     else
> +     } else if (is_of_node(fwnode)) {
>               snprintf(names->flash, sizeof(names->flash),
> -                      "%s:flash", node->name);
> +                      "%s:flash", to_of_node(fwnode)->name);
> +     } else {
> +             dev_err(&flash->client->dev, "flash node has no label!\n");
> +             return -EINVAL;
> +     }
>  
> -     rval = of_property_read_u32(flash->flash_node, "flash-timeout-us",
> +     rval = fwnode_property_read_u32(flash->flash_node, "flash-timeout-us",
>                                   &cfg->flash_timeout_us);
>       if (rval < 0) {
>               dev_err(&flash->client->dev,
> @@ -538,7 +545,7 @@ static int as3645a_parse_node(struct as3645a *flash,
>               goto out_err;
>       }
>  
> -     rval = of_property_read_u32(flash->flash_node, "flash-max-microamp",
> +     rval = fwnode_property_read_u32(flash->flash_node, "flash-max-microamp",
>                                   &cfg->flash_max_ua);
>       if (rval < 0) {
>               dev_err(&flash->client->dev,
> @@ -546,7 +553,7 @@ static int as3645a_parse_node(struct as3645a *flash,
>               goto out_err;
>       }
>  
> -     rval = of_property_read_u32(flash->flash_node, "led-max-microamp",
> +     rval = fwnode_property_read_u32(flash->flash_node, "led-max-microamp",
>                                   &cfg->assist_max_ua);
>       if (rval < 0) {
>               dev_err(&flash->client->dev,
> @@ -554,10 +561,10 @@ static int as3645a_parse_node(struct as3645a *flash,
>               goto out_err;
>       }
>  
> -     of_property_read_u32(flash->flash_node, "voltage-reference",
> +     fwnode_property_read_u32(flash->flash_node, "voltage-reference",
>                            &cfg->voltage_reference);
>  
> -     of_property_read_u32(flash->flash_node, "ams,input-max-microamp",
> +     fwnode_property_read_u32(flash->flash_node, "ams,input-max-microamp",
>                            &cfg->peak);
>       cfg->peak = AS_PEAK_mA_TO_REG(cfg->peak);
>  
> @@ -567,14 +574,18 @@ static int as3645a_parse_node(struct as3645a *flash,
>               goto out_err;
>       }
>  
> -     rval = of_property_read_string(flash->indicator_node, "label", &name);
> -     if (!rval)
> +     rval = fwnode_property_read_string(flash->indicator_node, "label", 
> &name);
> +     if (!rval) {
>               strlcpy(names->indicator, name, sizeof(names->indicator));
> -     else
> +     } else if (is_of_node(fwnode)) {
>               snprintf(names->indicator, sizeof(names->indicator),
> -                      "%s:indicator", node->name);
> +                      "%s:indicator", to_of_node(fwnode)->name);
> +     } else {
> +             dev_err(&flash->client->dev, "flash node has no label!\n");
> +             return -EINVAL;
> +     }
>  
> -     rval = of_property_read_u32(flash->indicator_node, "led-max-microamp",
> +     rval = fwnode_property_read_u32(flash->indicator_node, 
> "led-max-microamp",
>                                   &cfg->indicator_max_ua);
>       if (rval < 0) {
>               dev_err(&flash->client->dev,
> @@ -585,8 +596,8 @@ static int as3645a_parse_node(struct as3645a *flash,
>       return 0;
>  
>  out_err:
> -     of_node_put(flash->flash_node);
> -     of_node_put(flash->indicator_node);
> +     fwnode_handle_put(flash->flash_node);
> +     fwnode_handle_put(flash->indicator_node);
>  
>       return rval;
>  }
> @@ -667,14 +678,14 @@ static int as3645a_v4l2_setup(struct as3645a *flash)
>       strlcpy(cfgind.dev_name, flash->iled_cdev.name, sizeof(cfg.dev_name));
>  
>       flash->vf = v4l2_flash_init(
> -             &flash->client->dev, of_fwnode_handle(flash->flash_node),
> -             &flash->fled, NULL, &cfg);
> +             &flash->client->dev, flash->flash_node, &flash->fled, NULL,
> +             &cfg);
>       if (IS_ERR(flash->vf))
>               return PTR_ERR(flash->vf);
>  
>       flash->vfind = v4l2_flash_indicator_init(
> -             &flash->client->dev, of_fwnode_handle(flash->indicator_node),
> -             &flash->iled_cdev, &cfgind);
> +             &flash->client->dev, flash->indicator_node, &flash->iled_cdev,
> +             &cfgind);
>       if (IS_ERR(flash->vfind)) {
>               v4l2_flash_release(flash->vf);
>               return PTR_ERR(flash->vfind);
> @@ -689,7 +700,7 @@ static int as3645a_probe(struct i2c_client *client)
>       struct as3645a *flash;
>       int rval;
>  
> -     if (client->dev.of_node == NULL)
> +     if (!dev_fwnode(&client->dev))
>               return -ENODEV;
>  
>       flash = devm_kzalloc(&client->dev, sizeof(*flash), GFP_KERNEL);
> @@ -698,7 +709,7 @@ static int as3645a_probe(struct i2c_client *client)
>  
>       flash->client = client;
>  
> -     rval = as3645a_parse_node(flash, &names, client->dev.of_node);
> +     rval = as3645a_parse_node(flash, &names, dev_fwnode(&client->dev));
>       if (rval < 0)
>               return rval;
>  
> @@ -730,8 +741,8 @@ static int as3645a_probe(struct i2c_client *client)
>       mutex_destroy(&flash->mutex);
>  
>  out_put_nodes:
> -     of_node_put(flash->flash_node);
> -     of_node_put(flash->indicator_node);
> +     fwnode_handle_put(flash->flash_node);
> +     fwnode_handle_put(flash->indicator_node);
>  
>       return rval;
>  }
> @@ -749,8 +760,8 @@ static int as3645a_remove(struct i2c_client *client)
>  
>       mutex_destroy(&flash->mutex);
>  
> -     of_node_put(flash->flash_node);
> -     of_node_put(flash->indicator_node);
> +     fwnode_handle_put(flash->flash_node);
> +     fwnode_handle_put(flash->indicator_node);
>  
>       return 0;
>  }
> 

Reply via email to