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