TCL_Phone_pad:modify tp i2c err when device going to earlysuspend.
[firefly-linux-kernel-4.4.55.git] / arch / arm / mach-rk29 / include / mach / board.h
1 /* arch/arm/mach-rk29/include/mach/board.h
2  *
3  * Copyright (C) 2010 ROCKCHIP, Inc.
4  *
5  * This software is licensed under the terms of the GNU General Public
6  * License version 2, as published by the Free Software Foundation, and
7  * may be copied, distributed, and modified under those terms.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  */
15 #ifndef __ASM_ARCH_RK29_BOARD_H
16 #define __ASM_ARCH_RK29_BOARD_H
17
18 #include <linux/device.h>
19 #include <linux/platform_device.h>
20 #include <linux/i2c.h>
21 #include <linux/types.h>
22 #include <linux/timer.h>
23 #include <linux/notifier.h>
24
25 struct led_newton_pwm {
26         const char      *name;
27         unsigned int    pwm_id;
28         unsigned                pwm_gpio;
29         char*                   pwm_iomux_name;
30         unsigned int    pwm_iomux_pwm;
31         unsigned int    pwm_iomux_gpio;
32         unsigned int    freq;/**/
33         unsigned int    period;/*1-100*/
34 };
35
36 struct led_newton_pwm_platform_data {
37         int                     num_leds;
38         struct led_newton_pwm* leds;
39 };
40
41 struct hdmi_platform_data {
42         u32 hdmi_on_pin;
43         u32 hdmi_on_level;
44         int (*io_init)(void);
45         int (*io_deinit)(void);
46 };
47 struct irda_info{
48     u32 intr_pin;
49     int (*iomux_init)(void);
50     int (*iomux_deinit)(void);
51     int (*irda_pwr_ctl)(int en);
52 };
53
54 struct rk29_button_light_info{
55         u32 led_on_pin;
56         u32 led_on_level;
57         int (*io_init)(void);
58         int (*io_deinit)(void);
59 };
60
61 /*spi*/
62 struct spi_cs_gpio {
63         const char *name;
64         unsigned int cs_gpio;
65         char *cs_iomux_name;
66         unsigned int cs_iomux_mode;
67 };
68
69 struct rk29xx_spi_platform_data {
70         int (*io_init)(struct spi_cs_gpio*, int);
71         int (*io_deinit)(struct spi_cs_gpio*, int);
72         int (*io_fix_leakage_bug)(void);
73         int (*io_resume_leakage_bug)(void);
74         struct spi_cs_gpio *chipselect_gpios;   
75         u16 num_chipselect;
76 };
77
78 /*vmac*/
79 struct rk29_vmac_platform_data {
80         int (*vmac_register_set)(void);
81         int (*rmii_io_init)(void);
82         int (*rmii_io_deinit)(void);
83     int (*rmii_power_control)(int enable);
84 };
85
86 #define INVALID_GPIO        -1
87
88 struct rk29lcd_info{
89     u32 lcd_id;
90     u32 txd_pin;
91     u32 clk_pin;
92     u32 cs_pin;
93     int (*io_init)(void);
94     int (*io_deinit)(void);
95 };
96
97 struct rk29_fb_setting_info{
98     u8 data_num;
99     u8 vsync_en;
100     u8 den_en;
101     u8 mcu_fmk_en;
102     u8 disp_on_en;
103     u8 standby_en;
104 };
105
106 struct rk29fb_info{
107     u32 fb_id;
108     u32 mcu_fmk_pin;
109     struct rk29lcd_info *lcd_info;
110     int (*io_init)(struct rk29_fb_setting_info *fb_setting);
111     int (*io_deinit)(void);
112     int (*io_enable)(void);
113     int (*io_disable)(void);
114 };
115
116 struct rk29_bl_info{
117     u32 pwm_id;
118     u32 bl_ref;
119     int (*io_init)(void);
120     int (*io_deinit)(void);
121         int (*pwm_suspend)(void);
122         int (*pwm_resume)(void);
123         int min_brightness;     /* 0 ~ 255 */
124         unsigned int delay_ms;  /* in milliseconds */
125 };
126
127 struct wifi_platform_data {
128         int (*set_power)(int val);
129         int (*set_reset)(int val);
130         int (*set_carddetect)(int val);
131         void *(*mem_prealloc)(int section, unsigned long size);
132         int (*get_mac_addr)(unsigned char *buf);
133 };
134
135 struct rk29_sdmmc_platform_data {
136         unsigned int host_caps;
137         unsigned int host_ocr_avail;
138         unsigned int use_dma:1;
139         char dma_name[8];
140         int (*io_init)(void);
141         int (*io_deinit)(void);
142         int (*status)(struct device *);
143         int (*register_status_notify)(void (*callback)(int card_present, void *dev_id), void *dev_id);
144         int detect_irq;
145                 int enable_sd_wakeup;
146         int write_prt;
147 };
148 struct rk29_i2c_platform_data {
149         int     bus_num;        
150         unsigned int    flags;     
151         unsigned int    slave_addr; 
152         unsigned long   scl_rate;   
153 #define I2C_MODE_IRQ    0
154 #define I2C_MODE_POLL   1
155         unsigned int    mode:1;
156         int (*io_init)(void);
157         int (*io_deinit)(void);
158 };
159
160 struct bq27510_platform_data {  
161         int (*init_dc_check_pin)(void); 
162         unsigned int dc_check_pin;      
163         unsigned int bat_num;
164 };
165
166 struct bq27541_platform_data {  
167         int (*init_dc_check_pin)(void); 
168         unsigned int dc_check_pin;
169         unsigned int bat_check_pin;
170         unsigned int chgok_check_pin;
171         unsigned int bat_num;
172 };
173
174 /*i2s*/
175 struct rk29_i2s_platform_data {
176         int (*io_init)(void);
177         int (*io_deinit)(void);
178 };
179
180 /*p1003 touch */
181 struct p1003_platform_data {
182     u16     model;
183
184     int     (*get_pendown_state)(void);
185     int     (*init_platform_hw)(void);
186     int     (*p1003_platform_sleep)(void);
187     int     (*p1003_platform_wakeup)(void);
188     void    (*exit_platform_hw)(void);
189 };
190 struct eeti_egalax_platform_data{
191         u16     model;
192
193     int     (*get_pendown_state)(void);
194     int     (*init_platform_hw)(void);
195     int     (*eeti_egalax_platform_sleep)(void);
196     int     (*eeti_egalax_platform_wakeup)(void);
197     void    (*exit_platform_hw)(void);
198     int     standby_pin;
199     int     standby_value;
200     int     disp_on_pin;
201     int     disp_on_value;
202  
203 };
204 //added by zyw
205 struct atmel_1386_platform_data {
206         u8    numtouch; /* Number of touches to report  */
207         int  (*init_platform_hw)(struct device *dev);
208         void  (*exit_platform_hw)(struct device *dev);
209         int   max_x;    /* The default reported X range   */  
210         int   max_y;    /* The default reported Y range   */
211         u8    (*valid_interrupt) (void);
212         u8    (*read_chg) (void);
213 };
214
215 /*sintex touch*/
216 struct sintek_platform_data {
217         u16     model;
218
219         int     (*get_pendown_state)(void);
220         int     (*init_platform_hw)(void);
221         int     (*sintek_platform_sleep)(void);
222         int     (*sintek_platform_wakeup)(void);
223         void    (*exit_platform_hw)(void);
224 };
225
226 /*synaptics  touch*/
227 struct synaptics_platform_data {
228         u16     model;
229         
230         int     (*get_pendown_state)(void);
231         int     (*init_platform_hw)(void);
232         int     (*sintek_platform_sleep)(void);
233         int     (*sintek_platform_wakeup)(void);
234         void    (*exit_platform_hw)(void);
235 };
236
237 struct mma8452_platform_data {
238     u16     model;
239         u16     swap_xy;
240         u16             swap_xyz;
241         signed char orientation[9];
242     int     (*get_pendown_state)(void);
243     int     (*init_platform_hw)(void);
244     int     (*mma8452_platform_sleep)(void);
245     int     (*mma8452_platform_wakeup)(void);
246     void    (*exit_platform_hw)(void);
247 };
248
249 struct cm3202_platform_data {
250         int CM3202_SD_IOPIN;
251         int DATA_ADC_CHN;
252         int     (*init_platform_hw)(void);
253         void    (*exit_platform_hw)(void);
254 };
255
256 /*it7260 touch */
257 struct it7260_platform_data {
258     int     (*get_pendown_state)(void);
259     int     (*init_platform_hw)(void);
260     int     (*it7260_platform_sleep)(void);
261     int     (*it7260_platform_wakeup)(void);
262     void    (*exit_platform_hw)(void);
263 };
264
265 struct ft5406_platform_data {
266     int     (*get_pendown_state)(void);
267     int     (*init_platform_hw)(void);
268     int     (*platform_sleep)(void);
269     int     (*platform_wakeup)(void);
270     void    (*exit_platform_hw)(void);
271 };
272
273 struct goodix_platform_data {
274     int     (*get_pendown_state)(void);
275     int     (*init_platform_hw)(void);
276     int     (*platform_sleep)(void);
277     int     (*platform_wakeup)(void);
278     void    (*exit_platform_hw)(void);
279 };
280
281 struct cs42l52_platform_data {
282     int     (*get_pendown_state)(void);
283     int     (*init_platform_hw)(void);
284     int     (*platform_sleep)(void);
285     int     (*platform_wakeup)(void);
286     void    (*exit_platform_hw)(void);
287 };
288
289 //tcl miaozh add
290 /*nas touch */
291 struct nas_platform_data {
292     u16     model;
293
294     int     (*get_pendown_state)(void);
295     int     (*init_platform_hw)(void);
296     int     (*nas_platform_sleep)(void);
297     int     (*nas_platform_wakeup)(void);
298     void    (*exit_platform_hw)(void);
299 };
300
301
302 struct laibao_platform_data {
303     u16     model;
304
305     int     (*get_pendown_state)(void);
306     int     (*init_platform_hw)(void);
307     int     (*laibao_platform_sleep)(void);
308     int     (*laibao_platform_wakeup)(void);
309     void    (*exit_platform_hw)(void);
310     int     lcd_disp_on_pin;
311     int     disp_on_value;
312     int     lcd_cs_pin;
313     int     lcd_cs_value;
314 };
315
316 struct akm8975_platform_data {
317         char layouts[3][3];
318         char project_name[64];
319         int gpio_DRDY;
320 };
321
322 struct rk29_gpio_expander_info {
323         unsigned int gpio_num;
324         unsigned int pin_type;//GPIO_IN or GPIO_OUT
325         unsigned int pin_value;//GPIO_HIGH or GPIO_LOW
326 };
327 struct rk29_newton_data {
328 };
329
330 struct tca6424_platform_data {
331         /*  the first extern gpio number in all of gpio groups */
332         unsigned int gpio_base;
333         unsigned int gpio_pin_num;
334         /*  the first gpio irq  number in all of irq source */
335
336         unsigned int gpio_irq_start;
337         unsigned int irq_pin_num;        //number of interrupt
338         unsigned int tca6424_irq_pin;     //rk29 gpio
339         unsigned int expand_port_group;
340         unsigned int expand_port_pinnum;
341         unsigned int rk_irq_mode;
342         unsigned int rk_irq_gpio_pull_up_down;
343         
344         /* initial polarity inversion setting */
345         uint16_t        invert;
346         struct rk29_gpio_expander_info  *settinginfo;
347         int  settinginfolen;
348         void    *context;       /* param to setup/teardown */
349
350         int             (*setup)(struct i2c_client *client,unsigned gpio, unsigned ngpio,void *context);
351         int             (*teardown)(struct i2c_client *client,unsigned gpio, unsigned ngpio,void *context);
352         char    **names;
353         void    (*reseti2cpin)(void);
354 };
355
356 void __init rk29_setup_early_printk(void);
357 void __init rk29_map_common_io(void);
358 void __init board_power_init(void);
359
360 #define BOOT_MODE_NORMAL                0
361 #define BOOT_MODE_FACTORY2              1
362 #define BOOT_MODE_RECOVERY              2
363 #define BOOT_MODE_CHARGE                3
364 #define BOOT_MODE_POWER_TEST            4
365 #define BOOT_MODE_OFFMODE_CHARGING      5
366 #define BOOT_MODE_REBOOT                6
367 #define BOOT_MODE_PANIC                 7
368 int board_boot_mode(void);
369
370 enum periph_pll {
371         periph_pll_96mhz = 96000000, /* save more power */
372         periph_pll_144mhz = 144000000,
373         periph_pll_288mhz = 288000000, /* for USB 1.1 */
374         periph_pll_300mhz = 300000000, /* for Ethernet */
375 #if defined(CONFIG_RK29_VMAC) && defined(CONFIG_USB20_HOST_EN)
376         periph_pll_default = periph_pll_300mhz,
377 #else
378         periph_pll_default = periph_pll_288mhz,
379 #endif
380 };
381
382 enum codec_pll {
383         codec_pll_297mhz = 297000000, /* for HDMI */
384         codec_pll_300mhz = 300000000,
385         codec_pll_504mhz = 504000000,
386         codec_pll_552mhz = 552000000,
387         codec_pll_594mhz = 594000000, /* for HDMI */
388         codec_pll_600mhz = 600000000,
389 };
390
391 void __init rk29_clock_init(enum periph_pll ppll_rate); /* codec pll is 297MHz, has xin27m */
392 void __init rk29_clock_init2(enum periph_pll ppll_rate, enum codec_pll cpll_rate, bool has_xin27m);
393
394 /* for USB detection */
395 #ifdef CONFIG_USB_GADGET
396 int board_usb_detect_init(unsigned gpio);
397 #else
398 static int inline board_usb_detect_init(unsigned gpio) { return 0; }
399 #endif
400
401 /* for wakeup Android */
402 void rk28_send_wakeup_key(void);
403
404 #endif