]> www.pilppa.org Git - linux-2.6-omap-h63xx.git/blob - include/linux/i2c/twl4030.h
b80e8b640aa5ff428f728e4906e1982a0da9e5dc
[linux-2.6-omap-h63xx.git] / include / linux / i2c / twl4030.h
1 /*
2  * twl4030.h - header for TWL4030 PM and audio CODEC device
3  *
4  * Copyright (C) 2005-2006 Texas Instruments, Inc.
5  *
6  * Based on tlv320aic23.c:
7  * Copyright (c) by Kai Svahn <kai.svahn@nokia.com>
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software
21  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
22  *
23  */
24
25 #ifndef __TWL4030_H_
26 #define __TWL4030_H_
27
28 /* USB ID */
29 #define TWL4030_MODULE_USB              0x00
30 /* AUD ID */
31 #define TWL4030_MODULE_AUDIO_VOICE      0x01
32 #define TWL4030_MODULE_GPIO             0x02
33 #define TWL4030_MODULE_INTBR            0x03
34 #define TWL4030_MODULE_PIH              0x04
35 #define TWL4030_MODULE_TEST             0x05
36 /* AUX ID */
37 #define TWL4030_MODULE_KEYPAD           0x06
38 #define TWL4030_MODULE_MADC             0x07
39 #define TWL4030_MODULE_INTERRUPTS       0x08
40 #define TWL4030_MODULE_LED              0x09
41 #define TWL4030_MODULE_MAIN_CHARGE      0x0A
42 #define TWL4030_MODULE_PRECHARGE        0x0B
43 #define TWL4030_MODULE_PWM0             0x0C
44 #define TWL4030_MODULE_PWM1             0x0D
45 #define TWL4030_MODULE_PWMA             0x0E
46 #define TWL4030_MODULE_PWMB             0x0F
47 /* POWER ID */
48 #define TWL4030_MODULE_BACKUP           0x10
49 #define TWL4030_MODULE_INT              0x11
50 #define TWL4030_MODULE_PM_MASTER        0x12
51 #define TWL4030_MODULE_PM_RECEIVER      0x13
52 #define TWL4030_MODULE_RTC              0x14
53 #define TWL4030_MODULE_SECURED_REG      0x15
54
55
56 /* TWL4030_GPIO_MAX (18) GPIOs, with interrupts */
57 struct twl4030_gpio_platform_data {
58         int             gpio_base;
59         unsigned        irq_base, irq_end;
60
61         /* for gpio-N, bit (1 << N) is set if pullup should be used */
62         u32             pullups;
63
64         int             (*setup)(struct device *dev,
65                                 unsigned gpio, unsigned ngpio);
66         int             (*teardown)(struct device *dev,
67                                 unsigned gpio, unsigned ngpio);
68 };
69
70 struct twl4030_keypad_data {
71         int rows;
72         int cols;
73         int *keymap;
74         int irq;
75         unsigned int keymapsize;
76         unsigned int rep:1;
77 };
78
79 enum twl4030_usb_mode {
80         T2_USB_MODE_ULPI = 1,
81         T2_USB_MODE_CEA2011_3PIN = 2,
82 };
83
84 struct twl4030_usb_data {
85         enum twl4030_usb_mode   usb_mode;
86 };
87
88 struct twl4030_platform_data {
89         unsigned                                irq_base, irq_end;
90         struct twl4030_gpio_platform_data       *gpio;
91         struct twl4030_keypad_data              *keypad;
92         struct twl4030_usb_data                 *usb;
93
94         /* REVISIT more to come ... _nothing_ should be hard-wired */
95 };
96
97 /*
98  * FIXME completely stop using TWL4030_IRQ_BASE ... instead, pass the
99  * IRQ data to subsidiary devices using platform device resources.
100  */
101
102 /* IRQ information-need base */
103 #include <mach/irqs.h>
104 /* TWL4030 interrupts */
105
106 #define TWL4030_MODIRQ_GPIO             (TWL4030_IRQ_BASE + 0)
107 #define TWL4030_MODIRQ_KEYPAD           (TWL4030_IRQ_BASE + 1)
108 #define TWL4030_MODIRQ_BCI              (TWL4030_IRQ_BASE + 2)
109 #define TWL4030_MODIRQ_MADC             (TWL4030_IRQ_BASE + 3)
110 #define TWL4030_MODIRQ_USB              (TWL4030_IRQ_BASE + 4)
111 #define TWL4030_MODIRQ_PWR              (TWL4030_IRQ_BASE + 5)
112
113 #define TWL4030_PWRIRQ_PWRBTN           (TWL4030_PWR_IRQ_BASE + 0)
114 #define TWL4030_PWRIRQ_CHG_PRES         (TWL4030_PWR_IRQ_BASE + 1)
115 #define TWL4030_PWRIRQ_USB_PRES         (TWL4030_PWR_IRQ_BASE + 2)
116 #define TWL4030_PWRIRQ_RTC              (TWL4030_PWR_IRQ_BASE + 3)
117 #define TWL4030_PWRIRQ_HOT_DIE          (TWL4030_PWR_IRQ_BASE + 4)
118 #define TWL4030_PWRIRQ_PWROK_TIMEOUT    (TWL4030_PWR_IRQ_BASE + 5)
119 #define TWL4030_PWRIRQ_MBCHG            (TWL4030_PWR_IRQ_BASE + 6)
120 #define TWL4030_PWRIRQ_SC_DETECT        (TWL4030_PWR_IRQ_BASE + 7)
121
122 /* Rest are unsued currently*/
123
124 /* Offsets to Power Registers */
125 #define TWL4030_VDAC_DEV_GRP            0x3B
126 #define TWL4030_VDAC_DEDICATED          0x3E
127 #define TWL4030_VAUX1_DEV_GRP           0x17
128 #define TWL4030_VAUX1_DEDICATED         0x1A
129 #define TWL4030_VAUX2_DEV_GRP           0x1B
130 #define TWL4030_VAUX2_DEDICATED         0x1E
131 #define TWL4030_VAUX3_DEV_GRP           0x1F
132 #define TWL4030_VAUX3_DEDICATED         0x22
133
134 /* TWL4030 GPIO interrupt definitions */
135
136 #define TWL4030_GPIO_MIN                0
137 #define TWL4030_GPIO_MAX                18
138 #define TWL4030_GPIO_MAX_CD             2
139 #define TWL4030_GPIO_IRQ_NO(n)          (TWL4030_GPIO_IRQ_BASE + (n))
140 #define TWL4030_GPIO_IS_INPUT           1
141 #define TWL4030_GPIO_IS_OUTPUT          0
142 #define TWL4030_GPIO_IS_ENABLE          1
143 #define TWL4030_GPIO_IS_DISABLE         0
144 #define TWL4030_GPIO_PULL_UP            0
145 #define TWL4030_GPIO_PULL_DOWN          1
146 #define TWL4030_GPIO_PULL_NONE          2
147 #define TWL4030_GPIO_EDGE_NONE          0
148 #define TWL4030_GPIO_EDGE_RISING        1
149 #define TWL4030_GPIO_EDGE_FALLING       2
150
151 /* Functions to read and write from TWL4030 */
152
153 /*
154  * IMP NOTE:
155  * The base address of the module will be added by the triton driver
156  * It is the caller's responsibility to ensure sane values
157  */
158 int twl4030_i2c_write_u8(u8 mod_no, u8 val, u8 reg);
159 int twl4030_i2c_read_u8(u8 mod_no, u8 *val, u8 reg);
160
161  /*
162   * i2c_write: IMPORTANT - Allocate value num_bytes+1 and valid data starts at
163   *             Offset 1.
164   */
165 int twl4030_i2c_write(u8 mod_no, u8 *value, u8 reg, u8 num_bytes);
166 int twl4030_i2c_read(u8 mod_no, u8 *value, u8 reg, u8 num_bytes);
167
168 /*
169  * Exported TWL4030 GPIO APIs
170  *
171  * WARNING -- use standard GPIO and IRQ calls instead; these will vanish.
172  */
173 int twl4030_get_gpio_datain(int gpio);
174 int twl4030_request_gpio(int gpio);
175 int twl4030_set_gpio_edge_ctrl(int gpio, int edge);
176 int twl4030_set_gpio_debounce(int gpio, int enable);
177 int twl4030_free_gpio(int gpio);
178
179 #if defined(CONFIG_TWL4030_BCI_BATTERY) || \
180         defined(CONFIG_TWL4030_BCI_BATTERY_MODULE)
181         extern int twl4030charger_usb_en(int enable);
182 #else
183         static inline int twl4030charger_usb_en(int enable) { return 0; }
184 #endif
185
186 #endif /* End of __TWL4030_H */