|
@@ -134,6 +134,8 @@ static int create_gpio_led(const struct gpio_led *template,
|
|
|
led_dat->cdev.flags |= LED_CORE_SUSPENDRESUME;
|
|
|
if (template->panic_indicator)
|
|
|
led_dat->cdev.flags |= LED_PANIC_INDICATOR;
|
|
|
+ if (template->retain_state_shutdown)
|
|
|
+ led_dat->cdev.flags |= LED_RETAIN_AT_SHUTDOWN;
|
|
|
|
|
|
ret = gpiod_direction_output(led_dat->gpiod, state);
|
|
|
if (ret < 0)
|
|
@@ -205,6 +207,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, "retain-state-shutdown"))
|
|
|
+ led.retain_state_shutdown = 1;
|
|
|
if (fwnode_property_present(child, "panic-indicator"))
|
|
|
led.panic_indicator = 1;
|
|
|
|
|
@@ -267,7 +271,8 @@ static void gpio_led_shutdown(struct platform_device *pdev)
|
|
|
for (i = 0; i < priv->num_leds; i++) {
|
|
|
struct gpio_led_data *led = &priv->leds[i];
|
|
|
|
|
|
- gpio_led_set(&led->cdev, LED_OFF);
|
|
|
+ if (!(led->cdev.flags & LED_RETAIN_AT_SHUTDOWN))
|
|
|
+ gpio_led_set(&led->cdev, LED_OFF);
|
|
|
}
|
|
|
}
|
|
|
|