[PATCH v2] pwm_backlight: Add device tree support for Low Threshold Brightness

From: Philip, Avinash
Date: Fri Sep 21 2012 - 01:11:03 EST


Some backlights perform poorly when driven by a PWM with a short
duty-cycle. For such devices, the low threshold can be used to specify a
lower bound for the duty-cycle and should be chosen to exclude the
problematic range.

This patch adds support for an optional low-threshold-brightness
property.

Signed-off-by: Philip, Avinash <avinashphilip@xxxxxx>
---
Changes since v1:
- Updated commit message.
- Changes to low-threshold-brightness.
- Merged example section to original.

:100644 100644 1e4fc72... 5baebff... M Documentation/devicetree/bindings/video/backlight/pwm-backlight.txt
:100644 100644 995f016... 29e6fe1... M drivers/video/backlight/pwm_bl.c
.../bindings/video/backlight/pwm-backlight.txt | 4 ++++
drivers/video/backlight/pwm_bl.c | 5 +++++
2 files changed, 9 insertions(+), 0 deletions(-)

diff --git a/Documentation/devicetree/bindings/video/backlight/pwm-backlight.txt b/Documentation/devicetree/bindings/video/backlight/pwm-backlight.txt
index 1e4fc72..5baebff 100644
--- a/Documentation/devicetree/bindings/video/backlight/pwm-backlight.txt
+++ b/Documentation/devicetree/bindings/video/backlight/pwm-backlight.txt
@@ -14,6 +14,9 @@ Required properties:
Optional properties:
- pwm-names: a list of names for the PWM devices specified in the
"pwms" property (see PWM binding[0])
+ - low-threshold-brightness: brightness threshold low level. Low threshold
+ brightness set to value so that backlight present on low end of
+ brightness.

[0]: Documentation/devicetree/bindings/pwm/pwm.txt

@@ -25,4 +28,5 @@ Example:

brightness-levels = <0 4 8 16 32 64 128 255>;
default-brightness-level = <6>;
+ low-threshold-brightness = <50>;
};
diff --git a/drivers/video/backlight/pwm_bl.c b/drivers/video/backlight/pwm_bl.c
index 995f016..29e6fe1 100644
--- a/drivers/video/backlight/pwm_bl.c
+++ b/drivers/video/backlight/pwm_bl.c
@@ -143,6 +143,11 @@ static int pwm_backlight_parse_dt(struct device *dev,

data->dft_brightness = value;
data->max_brightness--;
+
+ ret = of_property_read_u32(node, "low-threshold-brightness",
+ &value);
+ if (!ret)
+ data->lth_brightness = value;
}

/*
--
1.7.0.4

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/