blob: 18e6398d70689a3d49cfe991e34a66d27aca66b6 [file] [log] [blame]
Mohan Pallaka53fe1a12011-12-15 16:56:37 +05301/* Copyright (c) 2010-2012, Code Aurora Forum. All rights reserved.
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07002 *
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License version 2 and
5 * only version 2 as published by the Free Software Foundation.
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 */
12
13#ifndef __LEDS_PM8XXX_H__
14#define __LEDS_PM8XXX_H__
15
Jay Chokshi8994e392011-09-14 18:20:39 -070016#include <linux/kernel.h>
Jay Chokshi868312e2011-09-16 13:57:13 -070017#include <linux/mfd/pm8xxx/pwm.h>
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070018
19#define PM8XXX_LEDS_DEV_NAME "pm8xxx-led"
20
21/**
22 * enum pm8xxx_leds - PMIC8XXX supported led ids
23 * @PM8XXX_ID_LED_KB_LIGHT - keyboard backlight led
24 * @PM8XXX_ID_LED_0 - First low current led
25 * @PM8XXX_ID_LED_1 - Second low current led
26 * @PM8XXX_ID_LED_2 - Third low current led
27 * @PM8XXX_ID_FLASH_LED_0 - First flash led
28 * @PM8XXX_ID_FLASH_LED_0 - Second flash led
29 */
30enum pm8xxx_leds {
31 PM8XXX_ID_LED_KB_LIGHT = 1,
32 PM8XXX_ID_LED_0,
33 PM8XXX_ID_LED_1,
34 PM8XXX_ID_LED_2,
35 PM8XXX_ID_FLASH_LED_0,
36 PM8XXX_ID_FLASH_LED_1,
Mohan Pallaka53fe1a12011-12-15 16:56:37 +053037 PM8XXX_ID_WLED,
38 PM8XXX_ID_MAX,
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070039};
40
Jay Chokshi12e49bf2011-07-22 16:24:39 -070041/**
42 * pm8xxx_led_modes - Operating modes of LEDs
43 */
44enum pm8xxx_led_modes {
45 PM8XXX_LED_MODE_MANUAL,
46 PM8XXX_LED_MODE_PWM1,
47 PM8XXX_LED_MODE_PWM2,
48 PM8XXX_LED_MODE_PWM3,
49 PM8XXX_LED_MODE_DTEST1,
50 PM8XXX_LED_MODE_DTEST2,
51 PM8XXX_LED_MODE_DTEST3,
52 PM8XXX_LED_MODE_DTEST4
53};
54
Mohan Pallaka53fe1a12011-12-15 16:56:37 +053055/* current boost limit */
56enum wled_current_bost_limit {
57 WLED_CURR_LIMIT_105mA,
58 WLED_CURR_LIMIT_385mA,
59 WLED_CURR_LIMIT_525mA,
60 WLED_CURR_LIMIT_805mA,
61 WLED_CURR_LIMIT_980mA,
62 WLED_CURR_LIMIT_1260mA,
63 WLED_CURR_LIMIT_1400mA,
64 WLED_CURR_LIMIT_1680mA,
65};
66
67/* over voltage protection threshold */
68enum wled_ovp_threshold {
69 WLED_OVP_35V,
70 WLED_OVP_32V,
71 WLED_OVP_29V,
72 WLED_OVP_37V,
73};
74
75/**
76 * wled_config_data - wled configuration data
77 * @num_strings - number of wled strings supported
78 * @ovp_val - over voltage protection threshold
79 * @boost_curr_lim - boot current limit
80 * @cp_select - high pole capacitance
81 * @ctrl_delay_us - delay in activation of led
82 * @dig_mod_gen_en - digital module generator
83 * @cs_out_en - current sink output enable
84 * @op_fdbck - selection of output as feedback for the boost
85 */
86struct wled_config_data {
87 u8 num_strings;
88 u8 ovp_val;
89 u8 boost_curr_lim;
90 u8 cp_select;
91 u8 ctrl_delay_us;
92 bool dig_mod_gen_en;
93 bool cs_out_en;
94 bool op_fdbck;
95};
96
Jay Chokshi8994e392011-09-14 18:20:39 -070097/**
98 * pm8xxx_led_config - led configuration parameters
Jay Chokshi868312e2011-09-16 13:57:13 -070099 * @id - LED id
100 * @mode - LED mode
101 * @max_current - maximum current that LED can sustain
102 * @pwm_channel - PWM channel ID the LED is driven to
103 * @pwm_period_us - PWM period value in micro seconds
Mohan Pallaka53fe1a12011-12-15 16:56:37 +0530104 * @default_state - default state of the led
Jay Chokshi868312e2011-09-16 13:57:13 -0700105 * @pwm_duty_cycles - PWM duty cycle information
Jay Chokshi8994e392011-09-14 18:20:39 -0700106 */
107struct pm8xxx_led_config {
108 u8 id;
109 u8 mode;
110 u16 max_current;
Jay Chokshi868312e2011-09-16 13:57:13 -0700111 int pwm_channel;
112 u32 pwm_period_us;
Mohan Pallaka53fe1a12011-12-15 16:56:37 +0530113 bool default_state;
Jay Chokshi868312e2011-09-16 13:57:13 -0700114 struct pm8xxx_pwm_duty_cycles *pwm_duty_cycles;
Mohan Pallaka53fe1a12011-12-15 16:56:37 +0530115 struct wled_config_data *wled_cfg;
Jay Chokshi8994e392011-09-14 18:20:39 -0700116};
117
118/**
119 * pm8xxx_led_platform_data - platform data for LED
Jay Chokshi868312e2011-09-16 13:57:13 -0700120 * @led_core - array of LEDs. Each datum in array contains
Jay Chokshi8994e392011-09-14 18:20:39 -0700121 * core data for the LED
Jay Chokshi868312e2011-09-16 13:57:13 -0700122 * @configs - array of platform configuration parameters
Jay Chokshi8994e392011-09-14 18:20:39 -0700123 * for each LED. It maps one-to-one with
124 * array of LEDs
Jay Chokshi868312e2011-09-16 13:57:13 -0700125 * @num_configs - count of members of configs array
Jay Chokshi8994e392011-09-14 18:20:39 -0700126 */
127struct pm8xxx_led_platform_data {
128 struct led_platform_data *led_core;
129 struct pm8xxx_led_config *configs;
130 u32 num_configs;
131};
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700132#endif /* __LEDS_PM8XXX_H__ */