[PATCH 01/02] backlight: control WLED output current in da9034
Haojian Zhuang
haojian.zhuang at gmail.com
Tue Nov 17 02:27:50 EST 2009
On Thu, Nov 5, 2009 at 3:20 AM, Haojian Zhuang <haojian.zhuang at gmail.com> wrote:
> On Thu, Nov 5, 2009 at 2:57 AM, Haojian Zhuang <haojian.zhuang at gmail.com> wrote:
>> From ff0d136a181ce431a0db9582f18733425a51411d Mon Sep 17 00:00:00 2001
>> From: Haojian Zhuang <haojian.zhuang at marvell.com>
>> Date: Thu, 5 Nov 2009 10:27:13 -0500
>> Subject: [PATCH] backlight: control WLED output current in da9034
>>
>> Update WLED output current source before changing brightness.
>>
>> Signed-off-by: Haojian Zhuang <haojian.zhuang at marvell.com>
>> ---
>> drivers/video/backlight/da903x_bl.c | 15 ++++++++++++++-
>> include/linux/mfd/da903x.h | 7 +++++++
>> 2 files changed, 21 insertions(+), 1 deletions(-)
>>
>> diff --git a/drivers/video/backlight/da903x_bl.c
>> b/drivers/video/backlight/da903x_bl.c
>> index 701a108..9aba516 100644
>> --- a/drivers/video/backlight/da903x_bl.c
>> +++ b/drivers/video/backlight/da903x_bl.c
>> @@ -35,6 +35,7 @@ struct da903x_backlight_data {
>> struct device *da903x_dev;
>> int id;
>> int current_brightness;
>> + int out_current; /* output current */
>> };
>>
>> static int da903x_backlight_set(struct backlight_device *bl, int brightness)
>> @@ -56,10 +57,17 @@ static int da903x_backlight_set(struct
>> backlight_device *bl, int brightness)
>> DA9034_WLED_CONTROL2,
>> DA9034_WLED_BOOST_EN);
>>
>> - if (data->current_brightness == 0 && brightness)
>> + if (data->current_brightness == 0 && brightness) {
>> + if (data->out_current) {
>> + ret = da903x_write(dev, DA9034_WLED_CONTROL2,
>> + data->out_current);
>> + if (ret)
>> + return ret;
>> + }
>> ret = da903x_set_bits(dev,
>> DA9034_WLED_CONTROL2,
>> DA9034_WLED_BOOST_EN);
>> + }
>> break;
>> case DA9030_ID_WLED:
>> val = DA9030_WLED_TRIM(brightness);
>> @@ -101,6 +109,7 @@ static struct backlight_ops da903x_backlight_ops = {
>>
>> static int da903x_backlight_probe(struct platform_device *pdev)
>> {
>> + struct da9034_backlight_pdata *pdata = pdev->dev.platform_data;
>> struct da903x_backlight_data *data;
>> struct backlight_device *bl;
>> int max_brightness;
>> @@ -127,6 +136,10 @@ static int da903x_backlight_probe(struct
>> platform_device *pdev)
>> data->da903x_dev = pdev->dev.parent;
>> data->current_brightness = 0;
>>
>> + /* set output current */
>> + if (pdata)
>> + data->out_current = pdata->out_current;
>> +
>> bl = backlight_device_register(pdev->name, data->da903x_dev,
>> data, &da903x_backlight_ops);
>> if (IS_ERR(bl)) {
>> diff --git a/include/linux/mfd/da903x.h b/include/linux/mfd/da903x.h
>> index c63b65c..240a893 100644
>> --- a/include/linux/mfd/da903x.h
>> +++ b/include/linux/mfd/da903x.h
>> @@ -96,6 +96,13 @@ struct da9034_touch_pdata {
>> int y_inverted;
>> };
>>
>> +#define DA9034_WLED_OUT_MASK ((1 << 5) - 1)
>> +#define DA9034_WLED_CURRENT(x) (x & DA9034_WLED_OUT_MASK)
>> +
>> +struct da9034_backlight_pdata {
>> + int out_current; /* output current of WLED, unit is mA */
>> +};
>> +
>> /* DA9030 battery charger data */
>> struct power_supply_info;
>>
>> --
>> 1.5.6.5
>>
>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0001-backlight-control-WLED-output-current-in-da9034.patch
Type: text/x-patch
Size: 2704 bytes
Desc: not available
URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20091117/38ae295b/attachment-0001.bin>
More information about the linux-arm-kernel
mailing list