From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jacek Anaszewski Subject: Re: [PATCH 4/4] leds: trigger: Add pattern initialization from Device Tree Date: Sat, 8 Dec 2018 19:44:35 +0100 Message-ID: <8222f85b-4e61-69c4-6d31-ba559de02829@gmail.com> References: <1544185974-5932-1-git-send-email-krzk@kernel.org> <1544185974-5932-4-git-send-email-krzk@kernel.org> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <1544185974-5932-4-git-send-email-krzk@kernel.org> Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org To: Krzysztof Kozlowski , Pavel Machek , Rob Herring , Mark Rutland , Baolin Wang , Raphael Teysseyre , linux-leds@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org List-Id: devicetree@vger.kernel.org Hi Krzysztof, Thank you for the patch set. Applied 1/4 and 2/4. I'll hold on merging 3/4 until we sort out the issues I have with this one. Please refer to my comment below. On 12/7/18 1:32 PM, Krzysztof Kozlowski wrote: > Allow initialization of pattern used in pattern trigger from Device Tree > property. > > This is especially useful for embedded systems where the pattern trigger > would be used to indicate the process of boot status in a nice, > user-friendly blinking way. This initialization pattern will be used > till user-space is brought up and sets its own pattern, indicating the > boot status is for example finished. > > Signed-off-by: Krzysztof Kozlowski > --- > drivers/leds/trigger/ledtrig-pattern.c | 18 ++++++++++++++++++ > 1 file changed, 18 insertions(+) > > diff --git a/drivers/leds/trigger/ledtrig-pattern.c b/drivers/leds/trigger/ledtrig-pattern.c > index 1870cf87afe1..96309d3bc43c 100644 > --- a/drivers/leds/trigger/ledtrig-pattern.c > +++ b/drivers/leds/trigger/ledtrig-pattern.c > @@ -11,6 +11,7 @@ > #include > #include > #include > +#include > #include > #include > > @@ -331,6 +332,21 @@ static const struct attribute_group *pattern_trig_groups[] = { > NULL, > }; > > +static void pattern_init(struct led_classdev *led_cdev) > +{ > + struct device_node *np = dev_of_node(led_cdev->dev); > + const char *pattern; > + > + if (!np) > + return; > + > + if (!of_property_read_string(np, "linux,trigger-pattern", &pattern)) { > + if (strlen(pattern)) > + pattern_trig_store_patterns(led_cdev, pattern, > + strlen(pattern), false); > + } > +} > + > static int pattern_trig_activate(struct led_classdev *led_cdev) > { > struct pattern_trig_data *data; > @@ -354,6 +370,8 @@ static int pattern_trig_activate(struct led_classdev *led_cdev) > timer_setup(&data->timer, pattern_trig_timer_function, 0); > led_cdev->activated = true; > > + pattern_init(led_cdev); It means that the pattern defined in DT would be applied whenever the pattern trigger is set for a LED class device, whereas it should happen only on LED class device initialization, if linux,default-trigger is set to "pattern". What we would need for making that work is a generic support for parsing trigger specific initialization data in the of_led_classdev_register(). > + > return 0; > } > > -- Best regards, Jacek Anaszewski