Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 1 | Kernel driver lp855x |
| 2 | ==================== |
| 3 | |
| 4 | Backlight driver for LP855x ICs |
| 5 | |
| 6 | Supported chips: |
Kim, Milo | 26e8ccc | 2013-02-21 16:44:06 -0800 | [diff] [blame] | 7 | Texas Instruments LP8550, LP8551, LP8552, LP8553, LP8556 and LP8557 |
Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 8 | |
| 9 | Author: Milo(Woogyom) Kim <milo.kim@ti.com> |
| 10 | |
| 11 | Description |
| 12 | ----------- |
| 13 | |
| 14 | * Brightness control |
| 15 | |
| 16 | Brightness can be controlled by the pwm input or the i2c command. |
| 17 | The lp855x driver supports both cases. |
| 18 | |
| 19 | * Device attributes |
| 20 | |
| 21 | 1) bl_ctl_mode |
| 22 | Backlight control mode. |
| 23 | Value : pwm based or register based |
| 24 | |
| 25 | 2) chip_id |
| 26 | The lp855x chip id. |
Kim, Milo | 26e8ccc | 2013-02-21 16:44:06 -0800 | [diff] [blame] | 27 | Value : lp8550/lp8551/lp8552/lp8553/lp8556/lp8557 |
Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 28 | |
| 29 | Platform data for lp855x |
| 30 | ------------------------ |
| 31 | |
| 32 | For supporting platform specific data, the lp855x platform data can be used. |
| 33 | |
| 34 | * name : Backlight driver name. If it is not defined, default name is set. |
Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 35 | * device_control : Value of DEVICE CONTROL register. |
| 36 | * initial_brightness : Initial value of backlight brightness. |
Kim, Milo | 8cc9764 | 2012-12-17 16:00:43 -0800 | [diff] [blame] | 37 | * period_ns : Platform specific PWM period value. unit is nano. |
Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 38 | Only valid when brightness is pwm input mode. |
Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 39 | * size_program : Total size of lp855x_rom_data. |
| 40 | * rom_data : List of new eeprom/eprom registers. |
| 41 | |
| 42 | example 1) lp8552 platform data : i2c register mode with new eeprom data |
| 43 | |
| 44 | #define EEPROM_A5_ADDR 0xA5 |
| 45 | #define EEPROM_A5_VAL 0x4f /* EN_VSYNC=0 */ |
| 46 | |
| 47 | static struct lp855x_rom_data lp8552_eeprom_arr[] = { |
| 48 | {EEPROM_A5_ADDR, EEPROM_A5_VAL}, |
| 49 | }; |
| 50 | |
| 51 | static struct lp855x_platform_data lp8552_pdata = { |
| 52 | .name = "lcd-bl", |
Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 53 | .device_control = I2C_CONFIG(LP8552), |
| 54 | .initial_brightness = INITIAL_BRT, |
Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 55 | .size_program = ARRAY_SIZE(lp8552_eeprom_arr), |
| 56 | .rom_data = lp8552_eeprom_arr, |
| 57 | }; |
| 58 | |
| 59 | example 2) lp8556 platform data : pwm input mode with default rom data |
| 60 | |
| 61 | static struct lp855x_platform_data lp8556_pdata = { |
Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 62 | .device_control = PWM_CONFIG(LP8556), |
| 63 | .initial_brightness = INITIAL_BRT, |
Kim, Milo | 8cc9764 | 2012-12-17 16:00:43 -0800 | [diff] [blame] | 64 | .period_ns = 1000000, |
Kim, Milo | 7be865a | 2012-03-23 15:02:01 -0700 | [diff] [blame] | 65 | }; |