Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754790AbcDNI5Y (ORCPT ); Thu, 14 Apr 2016 04:57:24 -0400 Received: from mailout3.w1.samsung.com ([210.118.77.13]:33525 "EHLO mailout3.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751178AbcDNI5U (ORCPT ); Thu, 14 Apr 2016 04:57:20 -0400 X-AuditID: cbfec7f4-f796c6d000001486-2e-570f5b6c7498 Message-id: <570F5B6B.3000702@samsung.com> Date: Thu, 14 Apr 2016 10:57:15 +0200 From: Jacek Anaszewski User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:17.0) Gecko/20130804 Thunderbird/17.0.8 MIME-version: 1.0 To: Ezequiel Garcia Cc: linux-leds@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, Richard Purdie , Kumar Gala , Ian Campbell , Mark Rutland , Pawel Moll , Rob Herring Subject: Re: [PATCH v2 3/3] leds: gpio: Support the "panic-indicator" firmware property References: <1460570899-24642-1-git-send-email-ezequiel@vanguardiasur.com.ar> <1460570899-24642-4-git-send-email-ezequiel@vanguardiasur.com.ar> In-reply-to: <1460570899-24642-4-git-send-email-ezequiel@vanguardiasur.com.ar> Content-type: text/plain; charset=ISO-8859-1; format=flowed Content-transfer-encoding: 7bit X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFvrPLMWRmVeSWpSXmKPExsVy+t/xa7o50fzhBq0rjS3mHznHarHxxWcW i/43C1ktzr1ayWix6fE1VovLu+awWWx9s47RYun1i0wWE6avZbFo3XuE3WL3rqesDtwea+at YfS43NfL5LFy+Rc2j02rOtk8Ni+p99gz/werR9eR62wenzfJBXBEcdmkpOZklqUW6dslcGWs PP2fpeCzQMXNLfvYGhgf8XYxcnJICJhIPLl3nQnCFpO4cG89G4gtJLCUUeJ9b2kXIxeQ/YxR 4tasvcwgCV4BLYnm6cfBilgEVCWaf1wAi7MJGEr8fPEabJCoQITEn9P7WCHqBSV+TL7HAmKL CBhLrHl9gwlkKLPAUyaJVf2fwRqEBSIl+qdfZ4LYNpFRYsWkJ+wgCU4BP4n313rBNjALWEus nLSNEcKWl9i85i3zBEaBWUiWzEJSNgtJ2QJG5lWMoqmlyQXFSem5hnrFibnFpXnpesn5uZsY IdHyZQfj4mNWhxgFOBiVeHgvrOENF2JNLCuuzD3EKMHBrCTCmxzCHy7Em5JYWZValB9fVJqT WnyIUZqDRUmcd+6u9yFCAumJJanZqakFqUUwWSYOTqkGRos3l/f+mb/Na+L05WcfbP3v0u3p dEWXda6tzbLjG/hPTn2zTnWTZWmDFq/jPNF7Lrt8WxY8ecV7S2Llk/XyAasv7i3vLnyv3fFi XoTRrFc6IVYu1y2UUjfHF2bObU34u/1C/lSzfDObvdVrVcTDl5W84a259USoXL5vLuP7/ayz E+cb2c/7JanEUpyRaKjFXFScCABeBgRIkgIAAA== Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2105 Lines: 58 Hi Ezequiel, It would be good to update also leds-gpio bindings, of course in a separate patch: Documentation/devicetree/bindings/leds/leds-gpio.txt Thanks, Jacek Anaszewski On 04/13/2016 08:08 PM, Ezequiel Garcia wrote: > Calling a GPIO LEDs is quite likely to work even if the kernel > has paniced, so they are ideal to blink in this situation. > This commit adds support for the new "panic-indicator" > firmware property, allowing to mark a given LED to blink on > a kernel panic. > > Signed-off-by: Ezequiel Garcia > --- > drivers/leds/leds-gpio.c | 4 ++++ > include/linux/leds.h | 1 + > 2 files changed, 5 insertions(+) > > diff --git a/drivers/leds/leds-gpio.c b/drivers/leds/leds-gpio.c > index 61143f55597e..8229f063b483 100644 > --- a/drivers/leds/leds-gpio.c > +++ b/drivers/leds/leds-gpio.c > @@ -127,6 +127,8 @@ static int create_gpio_led(const struct gpio_led *template, > led_dat->cdev.brightness = state ? LED_FULL : LED_OFF; > if (!template->retain_state_suspended) > led_dat->cdev.flags |= LED_CORE_SUSPENDRESUME; > + if (template->panic_indicator) > + led_dat->cdev.flags |= LED_PANIC_INDICATOR; > > ret = gpiod_direction_output(led_dat->gpiod, state); > if (ret < 0) > @@ -200,6 +202,8 @@ static struct gpio_leds_priv *gpio_leds_create(struct platform_device *pdev) > > if (fwnode_property_present(child, "retain-state-suspended")) > led.retain_state_suspended = 1; > + if (fwnode_property_present(child, "panic-indicator")) > + led.panic_indicator = 1; > > ret = create_gpio_led(&led, &priv->leds[priv->num_leds], > dev, NULL); > diff --git a/include/linux/leds.h b/include/linux/leds.h > index 49adf9c6e326..1067fb5f9296 100644 > --- a/include/linux/leds.h > +++ b/include/linux/leds.h > @@ -359,6 +359,7 @@ struct gpio_led { > unsigned gpio; > unsigned active_low : 1; > unsigned retain_state_suspended : 1; > + unsigned panic_indicator : 1; > unsigned default_state : 2; > /* default_state should be one of LEDS_GPIO_DEFSTATE_(ON|OFF|KEEP) */ > struct gpio_desc *gpiod; >