Merge branch 'develop' of 10.10.10.29:/home/rockchip/kernel into develop
[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 };
147 struct rk29_i2c_platform_data {
148         int     bus_num;        
149         unsigned int    flags;     
150         unsigned int    slave_addr; 
151         unsigned long   scl_rate;   
152 #define I2C_MODE_IRQ    0
153 #define I2C_MODE_POLL   1
154         unsigned int    mode:1;
155         int (*io_init)(void);
156         int (*io_deinit)(void);
157 };
158
159 struct bq27510_platform_data {  
160         int (*init_dc_check_pin)(void); 
161         unsigned int dc_check_pin;      
162         unsigned int bat_num;
163 };
164
165 struct bq27541_platform_data {  
166         int (*init_dc_check_pin)(void); 
167         unsigned int dc_check_pin;
168         unsigned int bat_check_pin;
169         unsigned int chgok_check_pin;
170         unsigned int bat_num;
171 };
172
173 /*i2s*/
174 struct rk29_i2s_platform_data {
175         int (*io_init)(void);
176         int (*io_deinit)(void);
177 };
178
179 /*p1003 touch */
180 struct p1003_platform_data {
181     u16     model;
182
183     int     (*get_pendown_state)(void);
184     int     (*init_platform_hw)(void);
185     int     (*p1003_platform_sleep)(void);
186     int     (*p1003_platform_wakeup)(void);
187     void    (*exit_platform_hw)(void);
188 };
189 struct eeti_egalax_platform_data{
190         u16     model;
191
192     int     (*get_pendown_state)(void);
193     int     (*init_platform_hw)(void);
194     int     (*eeti_egalax_platform_sleep)(void);
195     int     (*eeti_egalax_platform_wakeup)(void);
196     void    (*exit_platform_hw)(void);
197     int     standby_pin;
198     int     standby_value;
199     int     disp_on_pin;
200     int     disp_on_value;
201  
202 };
203 //added by zyw
204 struct atmel_1386_platform_data {
205         u8    numtouch; /* Number of touches to report  */
206         int  (*init_platform_hw)(struct device *dev);
207         void  (*exit_platform_hw)(struct device *dev);
208         int   max_x;    /* The default reported X range   */  
209         int   max_y;    /* The default reported Y range   */
210         u8    (*valid_interrupt) (void);
211         u8    (*read_chg) (void);
212 };
213
214 /*sintex touch*/
215 struct sintek_platform_data {
216         u16     model;
217
218         int     (*get_pendown_state)(void);
219         int     (*init_platform_hw)(void);
220         int     (*sintek_platform_sleep)(void);
221         int     (*sintek_platform_wakeup)(void);
222         void    (*exit_platform_hw)(void);
223 };
224
225 /*synaptics  touch*/
226 struct synaptics_platform_data {
227         u16     model;
228         
229         int     (*get_pendown_state)(void);
230         int     (*init_platform_hw)(void);
231         int     (*sintek_platform_sleep)(void);
232         int     (*sintek_platform_wakeup)(void);
233         void    (*exit_platform_hw)(void);
234 };
235
236 struct mma8452_platform_data {
237     u16     model;
238         u16     swap_xy;
239         u16             swap_xyz;
240         signed char orientation[9];
241     int     (*get_pendown_state)(void);
242     int     (*init_platform_hw)(void);
243     int     (*mma8452_platform_sleep)(void);
244     int     (*mma8452_platform_wakeup)(void);
245     void    (*exit_platform_hw)(void);
246 };
247
248 struct cm3202_platform_data {
249         int CM3202_SD_IOPIN;
250         int DATA_ADC_CHN;
251         int     (*init_platform_hw)(void);
252         void    (*exit_platform_hw)(void);
253 };
254
255 /*it7260 touch */
256 struct it7260_platform_data {
257     int     (*get_pendown_state)(void);
258     int     (*init_platform_hw)(void);
259     int     (*it7260_platform_sleep)(void);
260     int     (*it7260_platform_wakeup)(void);
261     void    (*exit_platform_hw)(void);
262 };
263
264 struct ft5406_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 goodix_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 struct cs42l52_platform_data {
281     int     (*get_pendown_state)(void);
282     int     (*init_platform_hw)(void);
283     int     (*platform_sleep)(void);
284     int     (*platform_wakeup)(void);
285     void    (*exit_platform_hw)(void);
286 };
287
288 //tcl miaozh add
289 /*nas touch */
290 struct nas_platform_data {
291     u16     model;
292
293     int     (*get_pendown_state)(void);
294     int     (*init_platform_hw)(void);
295     int     (*nas_platform_sleep)(void);
296     int     (*nas_platform_wakeup)(void);
297     void    (*exit_platform_hw)(void);
298 };
299
300
301 struct laibao_platform_data {
302     u16     model;
303
304     int     (*get_pendown_state)(void);
305     int     (*init_platform_hw)(void);
306     int     (*laibao_platform_sleep)(void);
307     int     (*laibao_platform_wakeup)(void);
308     void    (*exit_platform_hw)(void);
309 };
310
311 struct akm8975_platform_data {
312         char layouts[3][3];
313         char project_name[64];
314         int gpio_DRDY;
315 };
316
317 struct rk29_gpio_expander_info {
318         unsigned int gpio_num;
319         unsigned int pin_type;//GPIO_IN or GPIO_OUT
320         unsigned int pin_value;//GPIO_HIGH or GPIO_LOW
321 };
322 struct rk29_newton_data {
323 };
324
325 struct tca6424_platform_data {
326         /*  the first extern gpio number in all of gpio groups */
327         unsigned int gpio_base;
328         unsigned int gpio_pin_num;
329         /*  the first gpio irq  number in all of irq source */
330
331         unsigned int gpio_irq_start;
332         unsigned int irq_pin_num;        //number of interrupt
333         unsigned int tca6424_irq_pin;     //rk29 gpio
334         unsigned int expand_port_group;
335         unsigned int expand_port_pinnum;
336         unsigned int rk_irq_mode;
337         unsigned int rk_irq_gpio_pull_up_down;
338         
339         /* initial polarity inversion setting */
340         uint16_t        invert;
341         struct rk29_gpio_expander_info  *settinginfo;
342         int  settinginfolen;
343         void    *context;       /* param to setup/teardown */
344
345         int             (*setup)(struct i2c_client *client,unsigned gpio, unsigned ngpio,void *context);
346         int             (*teardown)(struct i2c_client *client,unsigned gpio, unsigned ngpio,void *context);
347         char    **names;
348         void    (*reseti2cpin)(void);
349 };
350
351 void __init rk29_setup_early_printk(void);
352 void __init rk29_map_common_io(void);
353 void __init board_power_init(void);
354
355 #define BOOT_MODE_NORMAL                0
356 #define BOOT_MODE_FACTORY2              1
357 #define BOOT_MODE_RECOVERY              2
358 #define BOOT_MODE_CHARGE                3
359 #define BOOT_MODE_POWER_TEST            4
360 #define BOOT_MODE_OFFMODE_CHARGING      5
361 #define BOOT_MODE_REBOOT                6
362 #define BOOT_MODE_PANIC                 7
363 int board_boot_mode(void);
364
365 enum periph_pll {
366         periph_pll_96mhz = 96000000, /* save more power */
367         periph_pll_144mhz = 144000000,
368         periph_pll_288mhz = 288000000, /* for USB 1.1 */
369         periph_pll_300mhz = 300000000, /* for Ethernet */
370 #if defined(CONFIG_RK29_VMAC) && defined(CONFIG_USB20_HOST_EN)
371         periph_pll_default = periph_pll_300mhz,
372 #else
373         periph_pll_default = periph_pll_288mhz,
374 #endif
375 };
376
377 enum codec_pll {
378         codec_pll_297mhz = 297000000, /* for HDMI */
379         codec_pll_300mhz = 300000000,
380         codec_pll_504mhz = 504000000,
381         codec_pll_552mhz = 552000000,
382         codec_pll_594mhz = 594000000, /* for HDMI */
383         codec_pll_600mhz = 600000000,
384 };
385
386 void __init rk29_clock_init(enum periph_pll ppll_rate); /* codec pll is 297MHz, has xin27m */
387 void __init rk29_clock_init2(enum periph_pll ppll_rate, enum codec_pll cpll_rate, bool has_xin27m);
388
389 /* for USB detection */
390 #ifdef CONFIG_USB_GADGET
391 int board_usb_detect_init(unsigned gpio);
392 #else
393 static int inline board_usb_detect_init(unsigned gpio) { return 0; }
394 #endif
395
396 /* for wakeup Android */
397 void rk28_send_wakeup_key(void);
398
399 #endif