* [PATCH v2 0/2] leds: lp5860: add enable-gpio
@ 2026-03-10 14:14 Steffen Trumtrar
2026-03-10 14:14 ` [PATCH v2 1/2] dt-bindings: " Steffen Trumtrar
2026-03-10 14:14 ` [PATCH v2 2/2] leds: rgb: " Steffen Trumtrar
0 siblings, 2 replies; 4+ messages in thread
From: Steffen Trumtrar @ 2026-03-10 14:14 UTC (permalink / raw)
To: Lee Jones, Pavel Machek, Rob Herring, Krzysztof Kozlowski,
Conor Dooley, Steffen Trumtrar
Cc: linux-leds, devicetree, linux-kernel, Steffen Trumtrar,
Conor Dooley
The LP5860 can have the VIO_EN pin either be connected to VIO power
supply or a GPIO.
Add support for the pin to the devicetree binding and the driver.
Signed-off-by: Steffen Trumtrar <s.trumtrar@pengutronix.de>
---
Changes in v2:
- add acked-by
- updated deps to newer lp5860 series
- rebased to v7.0-rc1
- Link to v1: https://lore.kernel.org/r/20260217-v6-19-topic-ti-lp5860-enable-gpio-v1-0-f5e8edeb5d74@pengutronix.de
---
Steffen Trumtrar (2):
dt-bindings: leds: lp5860: add enable-gpio
leds: rgb: lp5860: add enable-gpio
Documentation/devicetree/bindings/leds/leds-lp5860.yaml | 7 +++++++
drivers/leds/rgb/leds-lp5860-core.c | 10 ++++++++++
include/linux/platform_data/leds-lp5860.h | 1 +
3 files changed, 18 insertions(+)
---
base-commit: 559f264e403e4d58d56a17595c60a1de011c5e20
change-id: 20260217-v6-19-topic-ti-lp5860-enable-gpio-83c0652d34ad
prerequisite-message-id: <20260309-v6-14-topic-ti-lp5860-v7-1-b1ed6c6a47ce@pengutronix.de>
prerequisite-patch-id: 45e295aab0d3ea7d92bf71596f8b0e18e8621ac0
Best regards,
--
Steffen Trumtrar <s.trumtrar@pengutronix.de>
^ permalink raw reply [flat|nested] 4+ messages in thread* [PATCH v2 1/2] dt-bindings: leds: lp5860: add enable-gpio 2026-03-10 14:14 [PATCH v2 0/2] leds: lp5860: add enable-gpio Steffen Trumtrar @ 2026-03-10 14:14 ` Steffen Trumtrar 2026-03-10 14:14 ` [PATCH v2 2/2] leds: rgb: " Steffen Trumtrar 1 sibling, 0 replies; 4+ messages in thread From: Steffen Trumtrar @ 2026-03-10 14:14 UTC (permalink / raw) To: Lee Jones, Pavel Machek, Rob Herring, Krzysztof Kozlowski, Conor Dooley, Steffen Trumtrar Cc: linux-leds, devicetree, linux-kernel, Steffen Trumtrar, Conor Dooley The VIO_EN pin on the lp5860 can either be connected to VIO power supply or GPIO. Add the enable-gpios pin to the binding documentation. Signed-off-by: Steffen Trumtrar <s.trumtrar@pengutronix.de> Acked-by: Conor Dooley <conor.dooley@microchip.com> --- Documentation/devicetree/bindings/leds/leds-lp5860.yaml | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/Documentation/devicetree/bindings/leds/leds-lp5860.yaml b/Documentation/devicetree/bindings/leds/leds-lp5860.yaml index 1ccba48541595..0e88c71c2d398 100644 --- a/Documentation/devicetree/bindings/leds/leds-lp5860.yaml +++ b/Documentation/devicetree/bindings/leds/leds-lp5860.yaml @@ -33,6 +33,11 @@ properties: '#size-cells': const: 0 + enable-gpios: + maxItems: 1 + description: | + GPIO attached to the chip's enable pin (VIO_EN). + patternProperties: '^multi-led@[0-9a-f]+$': type: object @@ -74,6 +79,7 @@ unevaluatedProperties: false examples: - | + #include <dt-bindings/gpio/gpio.h> #include <dt-bindings/leds/common.h> spi { @@ -83,6 +89,7 @@ examples: led-controller@0 { compatible = "ti,lp5860"; reg = <0x0>; + enable-gpios = <&gpio1 1 GPIO_ACTIVE_HIGH>; #address-cells = <1>; #size-cells = <0>; -- 2.51.0 ^ permalink raw reply related [flat|nested] 4+ messages in thread
* [PATCH v2 2/2] leds: rgb: lp5860: add enable-gpio 2026-03-10 14:14 [PATCH v2 0/2] leds: lp5860: add enable-gpio Steffen Trumtrar 2026-03-10 14:14 ` [PATCH v2 1/2] dt-bindings: " Steffen Trumtrar @ 2026-03-10 14:14 ` Steffen Trumtrar 2026-03-19 15:02 ` Lee Jones 1 sibling, 1 reply; 4+ messages in thread From: Steffen Trumtrar @ 2026-03-10 14:14 UTC (permalink / raw) To: Lee Jones, Pavel Machek, Rob Herring, Krzysztof Kozlowski, Conor Dooley, Steffen Trumtrar Cc: linux-leds, devicetree, linux-kernel, Steffen Trumtrar The VIO_EN pin can either be connected with VIO power supply or GPIO. Get the GPIO from DT if provided and set it on chip enable and disable. Signed-off-by: Steffen Trumtrar <s.trumtrar@pengutronix.de> --- drivers/leds/rgb/leds-lp5860-core.c | 10 ++++++++++ include/linux/platform_data/leds-lp5860.h | 1 + 2 files changed, 11 insertions(+) diff --git a/drivers/leds/rgb/leds-lp5860-core.c b/drivers/leds/rgb/leds-lp5860-core.c index 28b4d86e11f1a..1f349aa53f7a9 100644 --- a/drivers/leds/rgb/leds-lp5860-core.c +++ b/drivers/leds/rgb/leds-lp5860-core.c @@ -61,6 +61,9 @@ static int lp5860_set_mc_brightness(struct led_classdev *cdev, static int lp5860_chip_enable_toggle(struct lp5860 *led, int enable) { + if (led->enable_gpiod) + gpiod_direction_output(led->enable_gpiod, enable); + return regmap_write(led->regmap, LP5860_REG_CHIP_EN, enable); } @@ -170,6 +173,13 @@ int lp5860_device_init(struct device *dev) struct lp5860 *lp = dev_get_drvdata(dev); int ret; + lp->enable_gpiod = devm_gpiod_get_optional(lp->dev, "enable", GPIOD_ASIS); + if (IS_ERR(lp->enable_gpiod)) + return PTR_ERR(lp->enable_gpiod); + + if (lp->enable_gpiod) + gpiod_set_consumer_name(lp->enable_gpiod, "LP5860 VIO enable"); + ret = lp5860_chip_enable_toggle(lp, LP5860_CHIP_ENABLE); if (ret) return ret; diff --git a/include/linux/platform_data/leds-lp5860.h b/include/linux/platform_data/leds-lp5860.h index 7bc69a7a550dd..7258d0674ce59 100644 --- a/include/linux/platform_data/leds-lp5860.h +++ b/include/linux/platform_data/leds-lp5860.h @@ -257,6 +257,7 @@ struct lp5860_led { struct lp5860 { struct device *dev; struct regmap *regmap; + struct gpio_desc *enable_gpiod; unsigned int leds_count; DECLARE_FLEX_ARRAY(struct lp5860_led, leds); -- 2.51.0 ^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH v2 2/2] leds: rgb: lp5860: add enable-gpio 2026-03-10 14:14 ` [PATCH v2 2/2] leds: rgb: " Steffen Trumtrar @ 2026-03-19 15:02 ` Lee Jones 0 siblings, 0 replies; 4+ messages in thread From: Lee Jones @ 2026-03-19 15:02 UTC (permalink / raw) To: Steffen Trumtrar Cc: Pavel Machek, Rob Herring, Krzysztof Kozlowski, Conor Dooley, Steffen Trumtrar, linux-leds, devicetree, linux-kernel On Tue, 10 Mar 2026, Steffen Trumtrar wrote: > The VIO_EN pin can either be connected with VIO power supply or GPIO. > Get the GPIO from DT if provided and set it on chip enable and disable. > > Signed-off-by: Steffen Trumtrar <s.trumtrar@pengutronix.de> > --- > drivers/leds/rgb/leds-lp5860-core.c | 10 ++++++++++ > include/linux/platform_data/leds-lp5860.h | 1 + > 2 files changed, 11 insertions(+) > > diff --git a/drivers/leds/rgb/leds-lp5860-core.c b/drivers/leds/rgb/leds-lp5860-core.c > index 28b4d86e11f1a..1f349aa53f7a9 100644 > --- a/drivers/leds/rgb/leds-lp5860-core.c > +++ b/drivers/leds/rgb/leds-lp5860-core.c > @@ -61,6 +61,9 @@ static int lp5860_set_mc_brightness(struct led_classdev *cdev, > > static int lp5860_chip_enable_toggle(struct lp5860 *led, int enable) > { > + if (led->enable_gpiod) gpiod_direction_output() validates this for you. > + gpiod_direction_output(led->enable_gpiod, enable); > + > return regmap_write(led->regmap, LP5860_REG_CHIP_EN, enable); > } > > @@ -170,6 +173,13 @@ int lp5860_device_init(struct device *dev) > struct lp5860 *lp = dev_get_drvdata(dev); > int ret; > > + lp->enable_gpiod = devm_gpiod_get_optional(lp->dev, "enable", GPIOD_ASIS); > + if (IS_ERR(lp->enable_gpiod)) > + return PTR_ERR(lp->enable_gpiod); > + > + if (lp->enable_gpiod) gpiod_set_consumer_name() validates this for you. > + gpiod_set_consumer_name(lp->enable_gpiod, "LP5860 VIO enable"); > + > ret = lp5860_chip_enable_toggle(lp, LP5860_CHIP_ENABLE); > if (ret) > return ret; > diff --git a/include/linux/platform_data/leds-lp5860.h b/include/linux/platform_data/leds-lp5860.h > index 7bc69a7a550dd..7258d0674ce59 100644 > --- a/include/linux/platform_data/leds-lp5860.h > +++ b/include/linux/platform_data/leds-lp5860.h > @@ -257,6 +257,7 @@ struct lp5860_led { > struct lp5860 { > struct device *dev; > struct regmap *regmap; > + struct gpio_desc *enable_gpiod; > unsigned int leds_count; > > DECLARE_FLEX_ARRAY(struct lp5860_led, leds); > > -- > 2.51.0 > > -- Lee Jones [李琼斯] ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2026-03-19 15:02 UTC | newest] Thread overview: 4+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2026-03-10 14:14 [PATCH v2 0/2] leds: lp5860: add enable-gpio Steffen Trumtrar 2026-03-10 14:14 ` [PATCH v2 1/2] dt-bindings: " Steffen Trumtrar 2026-03-10 14:14 ` [PATCH v2 2/2] leds: rgb: " Steffen Trumtrar 2026-03-19 15:02 ` Lee Jones
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox