2 * Backlight driver for Dialog Semiconductor DA9030/DA9034
4 * Copyright (C) 2008 Compulab, Ltd.
5 * Mike Rapoport <mike@compulab.co.il>
7 * Copyright (C) 2006-2008 Marvell International Ltd.
8 * Eric Miao <eric.miao@marvell.com>
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License version 2 as
12 * published by the Free Software Foundation.
15 #include <linux/kernel.h>
16 #include <linux/init.h>
17 #include <linux/platform_device.h>
19 #include <linux/backlight.h>
20 #include <linux/mfd/da903x.h>
21 #include <linux/slab.h>
22 #include <linux/module.h>
24 #define DA9030_WLED_CONTROL 0x25
25 #define DA9030_WLED_CP_EN (1 << 6)
26 #define DA9030_WLED_TRIM(x) ((x) & 0x7)
28 #define DA9034_WLED_CONTROL1 0x3C
29 #define DA9034_WLED_CONTROL2 0x3D
30 #define DA9034_WLED_ISET(x) ((x) & 0x1f)
32 #define DA9034_WLED_BOOST_EN (1 << 5)
34 #define DA9030_MAX_BRIGHTNESS 7
35 #define DA9034_MAX_BRIGHTNESS 0x7f
37 struct da903x_backlight_data
{
38 struct device
*da903x_dev
;
40 int current_brightness
;
43 static int da903x_backlight_set(struct backlight_device
*bl
, int brightness
)
45 struct da903x_backlight_data
*data
= bl_get_data(bl
);
46 struct device
*dev
= data
->da903x_dev
;
52 ret
= da903x_update(dev
, DA9034_WLED_CONTROL1
,
57 if (data
->current_brightness
&& brightness
== 0)
58 ret
= da903x_clr_bits(dev
,
60 DA9034_WLED_BOOST_EN
);
62 if (data
->current_brightness
== 0 && brightness
)
63 ret
= da903x_set_bits(dev
,
65 DA9034_WLED_BOOST_EN
);
68 val
= DA9030_WLED_TRIM(brightness
);
69 val
|= brightness
? DA9030_WLED_CP_EN
: 0;
70 ret
= da903x_write(dev
, DA9030_WLED_CONTROL
, val
);
77 data
->current_brightness
= brightness
;
81 static int da903x_backlight_update_status(struct backlight_device
*bl
)
83 int brightness
= bl
->props
.brightness
;
85 if (bl
->props
.power
!= FB_BLANK_UNBLANK
)
88 if (bl
->props
.fb_blank
!= FB_BLANK_UNBLANK
)
91 return da903x_backlight_set(bl
, brightness
);
94 static int da903x_backlight_get_brightness(struct backlight_device
*bl
)
96 struct da903x_backlight_data
*data
= bl_get_data(bl
);
97 return data
->current_brightness
;
100 static const struct backlight_ops da903x_backlight_ops
= {
101 .update_status
= da903x_backlight_update_status
,
102 .get_brightness
= da903x_backlight_get_brightness
,
105 static int da903x_backlight_probe(struct platform_device
*pdev
)
107 struct da9034_backlight_pdata
*pdata
= pdev
->dev
.platform_data
;
108 struct da903x_backlight_data
*data
;
109 struct backlight_device
*bl
;
110 struct backlight_properties props
;
113 data
= kzalloc(sizeof(*data
), GFP_KERNEL
);
119 max_brightness
= DA9030_MAX_BRIGHTNESS
;
122 max_brightness
= DA9034_MAX_BRIGHTNESS
;
125 dev_err(&pdev
->dev
, "invalid backlight device ID(%d)\n",
132 data
->da903x_dev
= pdev
->dev
.parent
;
133 data
->current_brightness
= 0;
135 /* adjust the WLED output current */
137 da903x_write(data
->da903x_dev
, DA9034_WLED_CONTROL2
,
138 DA9034_WLED_ISET(pdata
->output_current
));
140 props
.type
= BACKLIGHT_RAW
;
141 props
.max_brightness
= max_brightness
;
142 bl
= backlight_device_register(pdev
->name
, data
->da903x_dev
, data
,
143 &da903x_backlight_ops
, &props
);
145 dev_err(&pdev
->dev
, "failed to register backlight\n");
150 bl
->props
.brightness
= max_brightness
;
152 platform_set_drvdata(pdev
, bl
);
153 backlight_update_status(bl
);
157 static int da903x_backlight_remove(struct platform_device
*pdev
)
159 struct backlight_device
*bl
= platform_get_drvdata(pdev
);
160 struct da903x_backlight_data
*data
= bl_get_data(bl
);
162 backlight_device_unregister(bl
);
168 static int da903x_backlight_suspend(struct device
*dev
)
170 struct platform_device
*pdev
= to_platform_device(dev
);
171 struct backlight_device
*bl
= platform_get_drvdata(pdev
);
172 return da903x_backlight_set(bl
, 0);
175 static int da903x_backlight_resume(struct device
*dev
)
177 struct platform_device
*pdev
= to_platform_device(dev
);
178 struct backlight_device
*bl
= platform_get_drvdata(pdev
);
180 backlight_update_status(bl
);
184 static const struct dev_pm_ops da903x_backlight_pm_ops
= {
185 .suspend
= da903x_backlight_suspend
,
186 .resume
= da903x_backlight_resume
,
190 static struct platform_driver da903x_backlight_driver
= {
192 .name
= "da903x-backlight",
193 .owner
= THIS_MODULE
,
195 .pm
= &da903x_backlight_pm_ops
,
198 .probe
= da903x_backlight_probe
,
199 .remove
= da903x_backlight_remove
,
202 static int __init
da903x_backlight_init(void)
204 return platform_driver_register(&da903x_backlight_driver
);
206 module_init(da903x_backlight_init
);
208 static void __exit
da903x_backlight_exit(void)
210 platform_driver_unregister(&da903x_backlight_driver
);
212 module_exit(da903x_backlight_exit
);
214 MODULE_DESCRIPTION("Backlight Driver for Dialog Semiconductor DA9030/DA9034");
215 MODULE_AUTHOR("Eric Miao <eric.miao@marvell.com>"
216 "Mike Rapoport <mike@compulab.co.il>");
217 MODULE_LICENSE("GPL");
218 MODULE_ALIAS("platform:da903x-backlight");