* [PATCH v2 1/2] dt-bindings: backlight: document new property default-brightness-level
@ 2023-06-21 21:54 Alexandru Ardelean
2023-06-21 21:54 ` [PATCH v2 2/2] backlight: gpio_backlight: add " Alexandru Ardelean
2023-06-22 2:13 ` [PATCH v2 1/2] dt-bindings: backlight: document " Rob Herring
0 siblings, 2 replies; 5+ messages in thread
From: Alexandru Ardelean @ 2023-06-21 21:54 UTC (permalink / raw)
To: dri-devel, linux-leds, devicetree, linux-kernel, linux-fbdev
Cc: lee, daniel.thompson, jingoohan1, pavel, robh+dt,
krzysztof.kozlowski+dt, conor+dt, deller, Yannick Fertre,
Alexandru Ardelean
From: Yannick Fertre <yannick.fertre@foss.st.com>
Add documentation for new default-brightness-level property.
Signed-off-by: Yannick Fertre <yannick.fertre@foss.st.com>
Signed-off-by: Alexandru Ardelean <alex@shruggie.ro>
---
Link to original patch:
https://github.com/STMicroelectronics/linux/commit/c4067d7bd883c6fa14ffd49892c4ce663cdafe98
Changelog v1 -> v2:
* https://lore.kernel.org/dri-devel/20230519200520.10657-2-alex@shruggie.ro/
* removed 'brightness-levels' reference
* updated doc-text for 'default-brightness-level'
* updated doc-text for 'default-on'
* added 'minimum' & 'maximum' to 'default-brightness-level' property
* removed 'Reviewed-by: Philippe CORNU <philippe.cornu@foss.st.com>' as
requested
* patch is first in series of 2 patches (was second patch)
.../bindings/leds/backlight/gpio-backlight.yaml | 14 +++++++++++++-
1 file changed, 13 insertions(+), 1 deletion(-)
diff --git a/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml b/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
index 584030b6b0b9..2da6552a207c 100644
--- a/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
+++ b/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
@@ -20,9 +20,21 @@ properties:
maxItems: 1
default-on:
- description: enable the backlight at boot.
+ description:
+ The default power state of the backlight at boot.
type: boolean
+ default-brightness-level:
+ description:
+ The default brightness level on device init. The value can be 0 or 1.
+ If omitted, the value is 1. In the context of the "gpio-backlight" driver
+ the effect of this setting will be that the backlight is on/off.
+ The difference between this setting and "default-on" is that this handles
+ brightness, while "default-on" handles the power setting of the device.
+ $ref: /schemas/types.yaml#/definitions/uint32
+ minimum: 0
+ maximum: 1
+
required:
- compatible
- gpios
--
2.40.1
^ permalink raw reply related [flat|nested] 5+ messages in thread
* [PATCH v2 2/2] backlight: gpio_backlight: add new property default-brightness-level
2023-06-21 21:54 [PATCH v2 1/2] dt-bindings: backlight: document new property default-brightness-level Alexandru Ardelean
@ 2023-06-21 21:54 ` Alexandru Ardelean
2023-06-22 2:13 ` [PATCH v2 1/2] dt-bindings: backlight: document " Rob Herring
1 sibling, 0 replies; 5+ messages in thread
From: Alexandru Ardelean @ 2023-06-21 21:54 UTC (permalink / raw)
To: dri-devel, linux-leds, devicetree, linux-kernel, linux-fbdev
Cc: lee, daniel.thompson, jingoohan1, pavel, robh+dt,
krzysztof.kozlowski+dt, conor+dt, deller, Yannick Fertre,
Alexandru Ardelean
From: Yannick Fertre <yannick.fertre@foss.st.com>
Add new property to set a brightness by default at probe.
Reviewed-by: Daniel Thompson <daniel.thompson@linaro.org>
Signed-off-by: Yannick Fertre <yannick.fertre@foss.st.com>
Signed-off-by: Alexandru Ardelean <alex@shruggie.ro>
---
Link to original patch:
https://github.com/STMicroelectronics/linux/commit/c4067d7bd883c6fa14ffd49892c4ce663cdafe98
Changelog v1 -> v2:
* https://lore.kernel.org/dri-devel/20230519200520.10657-1-alex@shruggie.ro/
* removed 'Reviewed-by: Philippe CORNU <philippe.cornu@foss.st.com>' as
requested
* patch is now second patch of 2 (was first in series)
* added 'Reviewed-by: Daniel Thompson <daniel.thompson@linaro.org>'
drivers/video/backlight/gpio_backlight.c | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/drivers/video/backlight/gpio_backlight.c b/drivers/video/backlight/gpio_backlight.c
index 6f78d928f054..d3fa3a8bef4d 100644
--- a/drivers/video/backlight/gpio_backlight.c
+++ b/drivers/video/backlight/gpio_backlight.c
@@ -53,6 +53,7 @@ static int gpio_backlight_probe(struct platform_device *pdev)
struct backlight_device *bl;
struct gpio_backlight *gbl;
int ret, init_brightness, def_value;
+ u32 value;
gbl = devm_kzalloc(dev, sizeof(*gbl), GFP_KERNEL);
if (gbl == NULL)
@@ -93,7 +94,11 @@ static int gpio_backlight_probe(struct platform_device *pdev)
else
bl->props.power = FB_BLANK_UNBLANK;
- bl->props.brightness = 1;
+ ret = device_property_read_u32(dev, "default-brightness-level", &value);
+ if (!ret && value <= props.max_brightness)
+ bl->props.brightness = value;
+ else
+ bl->props.brightness = 1;
init_brightness = backlight_get_brightness(bl);
ret = gpiod_direction_output(gbl->gpiod, init_brightness);
--
2.40.1
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH v2 1/2] dt-bindings: backlight: document new property default-brightness-level
2023-06-21 21:54 [PATCH v2 1/2] dt-bindings: backlight: document new property default-brightness-level Alexandru Ardelean
2023-06-21 21:54 ` [PATCH v2 2/2] backlight: gpio_backlight: add " Alexandru Ardelean
@ 2023-06-22 2:13 ` Rob Herring
2023-06-23 7:19 ` Alexandru Ardelean
1 sibling, 1 reply; 5+ messages in thread
From: Rob Herring @ 2023-06-22 2:13 UTC (permalink / raw)
To: Alexandru Ardelean
Cc: dri-devel, linux-leds, devicetree, linux-kernel, linux-fbdev, lee,
daniel.thompson, jingoohan1, pavel, krzysztof.kozlowski+dt,
conor+dt, deller, Yannick Fertre
On Thu, Jun 22, 2023 at 12:54:56AM +0300, Alexandru Ardelean wrote:
> From: Yannick Fertre <yannick.fertre@foss.st.com>
>
> Add documentation for new default-brightness-level property.
Why?
>
> Signed-off-by: Yannick Fertre <yannick.fertre@foss.st.com>
> Signed-off-by: Alexandru Ardelean <alex@shruggie.ro>
> ---
>
> Link to original patch:
> https://github.com/STMicroelectronics/linux/commit/c4067d7bd883c6fa14ffd49892c4ce663cdafe98
>
> Changelog v1 -> v2:
> * https://lore.kernel.org/dri-devel/20230519200520.10657-2-alex@shruggie.ro/
> * removed 'brightness-levels' reference
> * updated doc-text for 'default-brightness-level'
> * updated doc-text for 'default-on'
> * added 'minimum' & 'maximum' to 'default-brightness-level' property
> * removed 'Reviewed-by: Philippe CORNU <philippe.cornu@foss.st.com>' as
> requested
> * patch is first in series of 2 patches (was second patch)
>
> .../bindings/leds/backlight/gpio-backlight.yaml | 14 +++++++++++++-
> 1 file changed, 13 insertions(+), 1 deletion(-)
>
> diff --git a/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml b/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
> index 584030b6b0b9..2da6552a207c 100644
> --- a/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
> +++ b/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
> @@ -20,9 +20,21 @@ properties:
> maxItems: 1
>
> default-on:
> - description: enable the backlight at boot.
> + description:
> + The default power state of the backlight at boot.
> type: boolean
>
> + default-brightness-level:
> + description:
> + The default brightness level on device init. The value can be 0 or 1.
> + If omitted, the value is 1. In the context of the "gpio-backlight" driver
> + the effect of this setting will be that the backlight is on/off.
> + The difference between this setting and "default-on" is that this handles
> + brightness, while "default-on" handles the power setting of the device.
What power setting? You only have 1 GPIO to control here which is 2
states. I fail to see why you need 6 possible states with all the
combinations of 2 properties.
> + $ref: /schemas/types.yaml#/definitions/uint32
> + minimum: 0
> + maximum: 1
> +
> required:
> - compatible
> - gpios
> --
> 2.40.1
>
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH v2 1/2] dt-bindings: backlight: document new property default-brightness-level
2023-06-22 2:13 ` [PATCH v2 1/2] dt-bindings: backlight: document " Rob Herring
@ 2023-06-23 7:19 ` Alexandru Ardelean
2023-06-23 11:32 ` Daniel Thompson
0 siblings, 1 reply; 5+ messages in thread
From: Alexandru Ardelean @ 2023-06-23 7:19 UTC (permalink / raw)
To: Rob Herring
Cc: dri-devel, linux-leds, devicetree, linux-kernel, linux-fbdev, lee,
daniel.thompson, jingoohan1, pavel, krzysztof.kozlowski+dt,
conor+dt, deller, Yannick Fertre
On Thu, Jun 22, 2023 at 5:13 AM Rob Herring <robh@kernel.org> wrote:
>
> On Thu, Jun 22, 2023 at 12:54:56AM +0300, Alexandru Ardelean wrote:
> > From: Yannick Fertre <yannick.fertre@foss.st.com>
> >
> > Add documentation for new default-brightness-level property.
>
> Why?
I'll admit, I liked the fact that the "default-brightness-level" is
more uniform in the space of backlights.
The "default-on" property is more specific to the gpio-backlight driver.
And then there's gpio hogging that could also work.
>
> >
> > Signed-off-by: Yannick Fertre <yannick.fertre@foss.st.com>
> > Signed-off-by: Alexandru Ardelean <alex@shruggie.ro>
> > ---
> >
> > Link to original patch:
> > https://github.com/STMicroelectronics/linux/commit/c4067d7bd883c6fa14ffd49892c4ce663cdafe98
> >
> > Changelog v1 -> v2:
> > * https://lore.kernel.org/dri-devel/20230519200520.10657-2-alex@shruggie.ro/
> > * removed 'brightness-levels' reference
> > * updated doc-text for 'default-brightness-level'
> > * updated doc-text for 'default-on'
> > * added 'minimum' & 'maximum' to 'default-brightness-level' property
> > * removed 'Reviewed-by: Philippe CORNU <philippe.cornu@foss.st.com>' as
> > requested
> > * patch is first in series of 2 patches (was second patch)
> >
> > .../bindings/leds/backlight/gpio-backlight.yaml | 14 +++++++++++++-
> > 1 file changed, 13 insertions(+), 1 deletion(-)
> >
> > diff --git a/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml b/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
> > index 584030b6b0b9..2da6552a207c 100644
> > --- a/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
> > +++ b/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
> > @@ -20,9 +20,21 @@ properties:
> > maxItems: 1
> >
> > default-on:
> > - description: enable the backlight at boot.
> > + description:
> > + The default power state of the backlight at boot.
> > type: boolean
> >
> > + default-brightness-level:
> > + description:
> > + The default brightness level on device init. The value can be 0 or 1.
> > + If omitted, the value is 1. In the context of the "gpio-backlight" driver
> > + the effect of this setting will be that the backlight is on/off.
> > + The difference between this setting and "default-on" is that this handles
> > + brightness, while "default-on" handles the power setting of the device.
>
> What power setting? You only have 1 GPIO to control here which is 2
> states. I fail to see why you need 6 possible states with all the
> combinations of 2 properties.
So, the "default-on" bool gets converted to backlight power settings,
which eventually gets converted back to GPIO values (at some point).
Which sounds quirky (when saying/writing it).
But, yeah.
That's one thing that also made me a bit undecided to send this.
On the one hand I like the uniformity it brings.
On the other hand, because there is the legacy behavior (the
"default-on" property, and the fact that we can use the GPIO DT
settings to control this) just explodes complexity/quirks.
We can probably just drop this.
I'll also admit that my doc-writing skills aren't too great.
Thanks
Alex
>
> > + $ref: /schemas/types.yaml#/definitions/uint32
> > + minimum: 0
> > + maximum: 1
> > +
> > required:
> > - compatible
> > - gpios
> > --
> > 2.40.1
> >
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH v2 1/2] dt-bindings: backlight: document new property default-brightness-level
2023-06-23 7:19 ` Alexandru Ardelean
@ 2023-06-23 11:32 ` Daniel Thompson
0 siblings, 0 replies; 5+ messages in thread
From: Daniel Thompson @ 2023-06-23 11:32 UTC (permalink / raw)
To: Alexandru Ardelean
Cc: Rob Herring, dri-devel, linux-leds, devicetree, linux-kernel,
linux-fbdev, lee, jingoohan1, pavel, krzysztof.kozlowski+dt,
conor+dt, deller, Yannick Fertre
On Fri, Jun 23, 2023 at 10:19:57AM +0300, Alexandru Ardelean wrote:
> On Thu, Jun 22, 2023 at 5:13 AM Rob Herring <robh@kernel.org> wrote:
> > > +++ b/Documentation/devicetree/bindings/leds/backlight/gpio-backlight.yaml
> > > default-on:
> > > - description: enable the backlight at boot.
> > > + description:
> > > + The default power state of the backlight at boot.
> > > type: boolean
> > >
> > > + default-brightness-level:
> > > + description:
> > > + The default brightness level on device init. The value can be 0 or 1.
> > > + If omitted, the value is 1. In the context of the "gpio-backlight" driver
> > > + the effect of this setting will be that the backlight is on/off.
> > > + The difference between this setting and "default-on" is that this handles
> > > + brightness, while "default-on" handles the power setting of the device.
> >
> > What power setting? You only have 1 GPIO to control here which is 2
> > states.
There are at least three states: On/Off/HiZ .
Currently the DT description isn't acually rich enough to allow drivers
to safely use the HiZ state so that is not why this change is potentially
useful today (but does illustrate why it is not "wrong" to put it on the
h/ware description).
> > I fail to see why you need 6 possible states with all the
> > combinations of 2 properties.
>
> So, the "default-on" bool gets converted to backlight power settings,
> which eventually gets converted back to GPIO values (at some point).
> Which sounds quirky (when saying/writing it).
Modern DT practice is to for the display to link to backlight. This
gives display control over power state (so backlight automatically
follows the display power state). On such systems the backlight will
be turned "on" when the display hardware comes up (regardless of whether
or not default-on is set).
Thus this control covers the case where we have a display that is
readable when the GPIO is off (e.g. transflexive LCD or epaper).
A display that is readable with the GPIO off means the default
brightness brightness at boot can meaningfully be zero. In this
case the backlight is nominally on but the GPIO is off.
In short, this becomes part of the hardware description, rather than
merely being a driver feature, due to the effect of linking display
to backlight in the DT.
Note also that most backlights do expose on/off via DT for the same
reasons (when the off and zero states both result in the backlight
output pin doing physically the same thing).
> But, yeah.
> That's one thing that also made me a bit undecided to send this.
> On the one hand I like the uniformity it brings.
> On the other hand, because there is the legacy behavior (the
> "default-on" property, and the fact that we can use the GPIO DT
> settings to control this) just explodes complexity/quirks.
>
> We can probably just drop this.
> I'll also admit that my doc-writing skills aren't too great.
It may be potentially useful for people building kit with sunlight
readable displays and trivial backlights as a backup in the dark.
Of course if the pin the backlight is connected to is PWM capable
then the PWM backlight is probably a better bet ;-) .
Daniel.
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2023-06-23 11:32 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-06-21 21:54 [PATCH v2 1/2] dt-bindings: backlight: document new property default-brightness-level Alexandru Ardelean
2023-06-21 21:54 ` [PATCH v2 2/2] backlight: gpio_backlight: add " Alexandru Ardelean
2023-06-22 2:13 ` [PATCH v2 1/2] dt-bindings: backlight: document " Rob Herring
2023-06-23 7:19 ` Alexandru Ardelean
2023-06-23 11:32 ` Daniel Thompson
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).