* [PATCH 0/2] leds: trigger: gpio: Add update point / use threaded IRQ @ 2017-05-26 13:17 Jan Kiszka 2017-05-26 13:17 ` [PATCH 1/2] leds: trigger: gpio: Refresh LED state after GPIO change Jan Kiszka ` (3 more replies) 0 siblings, 4 replies; 5+ messages in thread From: Jan Kiszka @ 2017-05-26 13:17 UTC (permalink / raw) To: Richard Purdie, Jacek Anaszewski, Pavel Machek Cc: Linux Kernel Mailing List, linux-leds See patches for details. Jan Kiszka (2): leds: trigger: gpio: Refresh LED state after GPIO change leds: trigger: gpio: Use threaded IRQ drivers/leds/trigger/ledtrig-gpio.c | 29 +++++++---------------------- 1 file changed, 7 insertions(+), 22 deletions(-) -- 2.12.0 ^ permalink raw reply [flat|nested] 5+ messages in thread
* [PATCH 1/2] leds: trigger: gpio: Refresh LED state after GPIO change 2017-05-26 13:17 [PATCH 0/2] leds: trigger: gpio: Add update point / use threaded IRQ Jan Kiszka @ 2017-05-26 13:17 ` Jan Kiszka 2017-05-26 13:17 ` [PATCH 2/2] leds: trigger: gpio: Use threaded IRQ Jan Kiszka ` (2 subsequent siblings) 3 siblings, 0 replies; 5+ messages in thread From: Jan Kiszka @ 2017-05-26 13:17 UTC (permalink / raw) To: Richard Purdie, Jacek Anaszewski, Pavel Machek Cc: Linux Kernel Mailing List, linux-leds The new GPIO may have a different state than the old one. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> --- drivers/leds/trigger/ledtrig-gpio.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/leds/trigger/ledtrig-gpio.c b/drivers/leds/trigger/ledtrig-gpio.c index 51288a45fbcb..93d6b82e6437 100644 --- a/drivers/leds/trigger/ledtrig-gpio.c +++ b/drivers/leds/trigger/ledtrig-gpio.c @@ -170,6 +170,8 @@ static ssize_t gpio_trig_gpio_store(struct device *dev, if (gpio_data->gpio != 0) free_irq(gpio_to_irq(gpio_data->gpio), led); gpio_data->gpio = gpio; + /* After changing the GPIO, we need to update the LED. */ + schedule_work(&gpio_data->work); } return ret ? ret : n; -- 2.12.0 ^ permalink raw reply related [flat|nested] 5+ messages in thread
* [PATCH 2/2] leds: trigger: gpio: Use threaded IRQ 2017-05-26 13:17 [PATCH 0/2] leds: trigger: gpio: Add update point / use threaded IRQ Jan Kiszka 2017-05-26 13:17 ` [PATCH 1/2] leds: trigger: gpio: Refresh LED state after GPIO change Jan Kiszka @ 2017-05-26 13:17 ` Jan Kiszka 2017-05-27 15:02 ` [PATCH 0/2] leds: trigger: gpio: Add update point / use " Andy Shevchenko 2017-05-29 20:08 ` Jacek Anaszewski 3 siblings, 0 replies; 5+ messages in thread From: Jan Kiszka @ 2017-05-26 13:17 UTC (permalink / raw) To: Richard Purdie, Jacek Anaszewski, Pavel Machek Cc: Linux Kernel Mailing List, linux-leds This both simplifies the code because we can drop the workqueue indirection, and it enables using the trigger for GPIOs that work with threaded IRQs themselves. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> --- drivers/leds/trigger/ledtrig-gpio.c | 29 ++++++----------------------- 1 file changed, 6 insertions(+), 23 deletions(-) diff --git a/drivers/leds/trigger/ledtrig-gpio.c b/drivers/leds/trigger/ledtrig-gpio.c index 93d6b82e6437..8891e88d54dd 100644 --- a/drivers/leds/trigger/ledtrig-gpio.c +++ b/drivers/leds/trigger/ledtrig-gpio.c @@ -14,14 +14,12 @@ #include <linux/init.h> #include <linux/gpio.h> #include <linux/interrupt.h> -#include <linux/workqueue.h> #include <linux/leds.h> #include <linux/slab.h> #include "../leds.h" struct gpio_trig_data { struct led_classdev *led; - struct work_struct work; unsigned desired_brightness; /* desired brightness when led is on */ unsigned inverted; /* true when gpio is inverted */ @@ -32,22 +30,8 @@ static irqreturn_t gpio_trig_irq(int irq, void *_led) { struct led_classdev *led = _led; struct gpio_trig_data *gpio_data = led->trigger_data; - - /* just schedule_work since gpio_get_value can sleep */ - schedule_work(&gpio_data->work); - - return IRQ_HANDLED; -}; - -static void gpio_trig_work(struct work_struct *work) -{ - struct gpio_trig_data *gpio_data = container_of(work, - struct gpio_trig_data, work); int tmp; - if (!gpio_data->gpio) - return; - tmp = gpio_get_value_cansleep(gpio_data->gpio); if (gpio_data->inverted) tmp = !tmp; @@ -61,6 +45,8 @@ static void gpio_trig_work(struct work_struct *work) } else { led_set_brightness_nosleep(gpio_data->led, LED_OFF); } + + return IRQ_HANDLED; } static ssize_t gpio_trig_brightness_show(struct device *dev, @@ -120,7 +106,7 @@ static ssize_t gpio_trig_inverted_store(struct device *dev, gpio_data->inverted = inverted; /* After inverting, we need to update the LED. */ - schedule_work(&gpio_data->work); + gpio_trig_irq(0, led); return n; } @@ -147,7 +133,6 @@ static ssize_t gpio_trig_gpio_store(struct device *dev, ret = sscanf(buf, "%u", &gpio); if (ret < 1) { dev_err(dev, "couldn't read gpio number\n"); - flush_work(&gpio_data->work); return -EINVAL; } @@ -161,8 +146,8 @@ static ssize_t gpio_trig_gpio_store(struct device *dev, return n; } - ret = request_irq(gpio_to_irq(gpio), gpio_trig_irq, - IRQF_SHARED | IRQF_TRIGGER_RISING + ret = request_threaded_irq(gpio_to_irq(gpio), NULL, gpio_trig_irq, + IRQF_ONESHOT | IRQF_SHARED | IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING, "ledtrig-gpio", led); if (ret) { dev_err(dev, "request_irq failed with error %d\n", ret); @@ -171,7 +156,7 @@ static ssize_t gpio_trig_gpio_store(struct device *dev, free_irq(gpio_to_irq(gpio_data->gpio), led); gpio_data->gpio = gpio; /* After changing the GPIO, we need to update the LED. */ - schedule_work(&gpio_data->work); + gpio_trig_irq(0, led); } return ret ? ret : n; @@ -201,7 +186,6 @@ static void gpio_trig_activate(struct led_classdev *led) gpio_data->led = led; led->trigger_data = gpio_data; - INIT_WORK(&gpio_data->work, gpio_trig_work); led->activated = true; return; @@ -224,7 +208,6 @@ static void gpio_trig_deactivate(struct led_classdev *led) device_remove_file(led->dev, &dev_attr_gpio); device_remove_file(led->dev, &dev_attr_inverted); device_remove_file(led->dev, &dev_attr_desired_brightness); - flush_work(&gpio_data->work); if (gpio_data->gpio != 0) free_irq(gpio_to_irq(gpio_data->gpio), led); kfree(gpio_data); -- 2.12.0 ^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH 0/2] leds: trigger: gpio: Add update point / use threaded IRQ 2017-05-26 13:17 [PATCH 0/2] leds: trigger: gpio: Add update point / use threaded IRQ Jan Kiszka 2017-05-26 13:17 ` [PATCH 1/2] leds: trigger: gpio: Refresh LED state after GPIO change Jan Kiszka 2017-05-26 13:17 ` [PATCH 2/2] leds: trigger: gpio: Use threaded IRQ Jan Kiszka @ 2017-05-27 15:02 ` Andy Shevchenko 2017-05-29 20:08 ` Jacek Anaszewski 3 siblings, 0 replies; 5+ messages in thread From: Andy Shevchenko @ 2017-05-27 15:02 UTC (permalink / raw) To: Jan Kiszka Cc: Richard Purdie, Jacek Anaszewski, Pavel Machek, Linux Kernel Mailing List, Linux LED Subsystem On Fri, May 26, 2017 at 4:17 PM, Jan Kiszka <jan.kiszka@siemens.com> wrote: > See patches for details. > FWIW: Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com> P.S. Of course it would be also nice to convert to GPIO descriptors, though it's not related to this series. > Jan Kiszka (2): > leds: trigger: gpio: Refresh LED state after GPIO change > leds: trigger: gpio: Use threaded IRQ > > drivers/leds/trigger/ledtrig-gpio.c | 29 +++++++---------------------- > 1 file changed, 7 insertions(+), 22 deletions(-) > > -- > 2.12.0 > -- With Best Regards, Andy Shevchenko ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH 0/2] leds: trigger: gpio: Add update point / use threaded IRQ 2017-05-26 13:17 [PATCH 0/2] leds: trigger: gpio: Add update point / use threaded IRQ Jan Kiszka ` (2 preceding siblings ...) 2017-05-27 15:02 ` [PATCH 0/2] leds: trigger: gpio: Add update point / use " Andy Shevchenko @ 2017-05-29 20:08 ` Jacek Anaszewski 3 siblings, 0 replies; 5+ messages in thread From: Jacek Anaszewski @ 2017-05-29 20:08 UTC (permalink / raw) To: Jan Kiszka, Richard Purdie, Pavel Machek Cc: Linux Kernel Mailing List, linux-leds, Andy Shevchenko Hi Jan, Thanks for the patch set. On 05/26/2017 03:17 PM, Jan Kiszka wrote: > See patches for details. > > Jan Kiszka (2): > leds: trigger: gpio: Refresh LED state after GPIO change > leds: trigger: gpio: Use threaded IRQ > > drivers/leds/trigger/ledtrig-gpio.c | 29 +++++++---------------------- > 1 file changed, 7 insertions(+), 22 deletions(-) Both patches applied to the for-next branch of linux-leds.git, along with Andy's acks. -- Best regards, Jacek Anaszewski ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2017-05-29 20:09 UTC | newest] Thread overview: 5+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2017-05-26 13:17 [PATCH 0/2] leds: trigger: gpio: Add update point / use threaded IRQ Jan Kiszka 2017-05-26 13:17 ` [PATCH 1/2] leds: trigger: gpio: Refresh LED state after GPIO change Jan Kiszka 2017-05-26 13:17 ` [PATCH 2/2] leds: trigger: gpio: Use threaded IRQ Jan Kiszka 2017-05-27 15:02 ` [PATCH 0/2] leds: trigger: gpio: Add update point / use " Andy Shevchenko 2017-05-29 20:08 ` Jacek Anaszewski
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).