From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jacek Anaszewski Subject: Re: [PATCH 08/24] leds: lt3593: Use led_compose_name() Date: Wed, 7 Nov 2018 20:49:39 +0100 Message-ID: <6666ef06-c19d-b0d8-a32b-44cecb8bc4b3@gmail.com> References: <1541542052-10081-1-git-send-email-jacek.anaszewski@gmail.com> <1541542052-10081-9-git-send-email-jacek.anaszewski@gmail.com> <42d68eae-6905-e787-3797-f0f16b0dfb84@zonque.org> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Return-path: In-Reply-To: <42d68eae-6905-e787-3797-f0f16b0dfb84@zonque.org> Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org To: Daniel Mack , linux-leds@vger.kernel.org Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, pavel@ucw.cz, robh@kernel.org List-Id: linux-leds@vger.kernel.org On 11/07/2018 08:37 PM, Daniel Mack wrote: > On 6/11/2018 11:07 PM, Jacek Anaszewski wrote: >> Switch to using generic LED support for composing LED class >> device name. > > Thanks for the rework! > >> Signed-off-by: Jacek Anaszewski >> --- >>   drivers/leds/leds-lt3593.c | 19 ++++++++----------- >>   1 file changed, 8 insertions(+), 11 deletions(-) >> >> diff --git a/drivers/leds/leds-lt3593.c b/drivers/leds/leds-lt3593.c >> index de3623e..d005abc 100644 >> --- a/drivers/leds/leds-lt3593.c >> +++ b/drivers/leds/leds-lt3593.c >> @@ -10,10 +10,10 @@ >>   #include >>   #include >>   #include >> -#include >> + >> +#define LED_LT3593_NAME "lt3593" >>     struct lt3593_led_data { >> -    char name[LED_MAX_NAME_SIZE]; >>       struct led_classdev cdev; >>       struct gpio_desc *gpiod; >>   }; >> @@ -111,6 +111,7 @@ static int lt3593_led_probe(struct platform_device >> *pdev) >>       struct fwnode_handle *child; >>       int ret, state = LEDS_GPIO_DEFSTATE_OFF; >>       enum gpiod_flags flags = GPIOD_OUT_LOW; >> +    struct led_init_data init_data; >>       const char *tmp; >>         if (dev_get_platdata(dev)) { >> @@ -138,14 +139,11 @@ static int lt3593_led_probe(struct >> platform_device *pdev) >>           return PTR_ERR(led_data->gpiod); >>         child = device_get_next_child_node(dev, NULL); >> +    init_data.fwnode = child; > > Not quite following. `fwnode' is the only member of that struct that is > initialized? > >>   -    ret = fwnode_property_read_string(child, "label", &tmp); >> -    if (ret < 0) >> -        snprintf(led_data->name, sizeof(led_data->name), >> -             "lt3593::"); >> -    else >> -        snprintf(led_data->name, sizeof(led_data->name), >> -             "lt3593:%s", tmp); >> +    ret = led_compose_name(child, LED_LT3593_NAME, ":", init_data.name); > > ... and here, a member that wasn't written before is used? What am I > missing? init_data.name pointer is passed to led_compose_name(), which fills this array with the composed name. -- Best regards, Jacek Anaszewski