e44300abd7ec7ef63aa4906fc07f7edde53fc41d
[firefly-linux-kernel-4.4.55.git] / arch / arm / mach-rk30 / board-rk3168-tb-sdmmc-conifg.c
1 /*****************************************************************************************
2  * arch/arm/mach-rkxx/baord-xxx-sdmmc-config.c
3  *
4  * Copyright (C) 2013 ROCKCHIP, Inc.
5  *
6  * Description: 
7  *     define the gpio for SD-MMC-SDIO-Wifi functions  according to your own projects.
8  *
9  * Author: Michael Xie
10  *         15 Jan,2013
11  * E-mail: xbw@rock-chips.com
12  *
13  ******************************************************************************************/
14
15 /*
16 ** If you select the macro of CONFIG_SDMMC0_RK29_WRITE_PROTECT, You must define the following values.
17 ** Otherwise, there is no need to define the following values¡£
18 */
19 //#define SDMMC0_WRITE_PROTECT_PIN                  RK30_PIN3_PB2       //According to your own project to set the value of write-protect-pin.
20 //#define SDMMC0_WRITE_PROTECT_ENABLE_VALUE     GPIO_HIGH
21
22 /*
23 ** If you select the macro of CONFIG_SDMMC1_RK29_WRITE_PROTECT, You must define the following values.
24 ** Otherwise, there is no need to define the following values¡£
25 */
26 //#define SDMMC1_WRITE_PROTECT_PIN                  RK30_PIN3_PB3       //According to your own project to set the value of write-protect-pin.
27 //#define SDMMC1_WRITE_PROTECT_ENABLE_VALUE     GPIO_HIGH
28     
29 /*
30 ** If you select the macro of CONFIG_RK29_SDIO_IRQ_FROM_GPIO, You must define the following values.
31 ** Otherwise, there is no need to define the following values¡£
32 */
33 //#define RK29SDK_WIFI_SDIO_CARD_INT         RK30_PIN3_PD2
34
35
36 /*
37 * define sdcard PowerEn-pin
38 */
39 #define RK29SDK_SD_CARD_PWR_EN                  RK30_PIN3_PA1
40 #define RK29SDK_SD_CARD_PWR_EN_LEVEL            GPIO_LOW 
41 int rk31sdk_get_sdmmc0_pin_io_voltage(void)
42 {
43     int voltage;
44 #define RK31SDK_SET_SDMMC0_PIN_VOLTAGE
45
46     /**************************************************************************************
47     **  Please tell me how much voltage of your SDMMC0-pin in your project. 
48     **
49     **     ÀýÈç: ÓеÄÏîÄ¿£¬ËüµÄSDMMC0ËùÔÚµÄRKÖ÷¿ØµÄIO×飬ÏëÓÃ1.8V, ¶ø¿¨±¾ÉíÓÃ3.3V, 
50     **  ¶øÖмäͨ¹ý¸öµçƽת»».ÄÇô£¬Äú´Ëʱ£¬Ó¦¸ÃÉèÖÃÏÂÃæµÄvoltageֵΪ 1.8V(¼´1800mv)
51     ***************************************************************************************/
52     voltage = 3300;  //default the voltage 3300mv. 
53
54     return voltage;
55 }
56
57 /*
58 * define the card-detect-pin.
59 */
60 #define RK29SDK_SD_CARD_DETECT_N                RK30_PIN3_PB0  //According to your own project to set the value of card-detect-pin.
61 #define RK29SDK_SD_CARD_INSERT_LEVEL            GPIO_LOW       // set the voltage of insert-card. Please pay attention to the default setting.
62
63 /*
64 * Define wifi module's power and reset gpio, and gpio sensitive level.
65 * Please set the value according to your own project.
66 *
67 * Well, you just own engineering module to set the value in the corresponding module branch.
68 * Otherwise, you do not define this macro, eliminate it.
69 *
70 */          
71 #if defined(CONFIG_RTL8192CU) || defined(CONFIG_RTL8188EU) 
72     #define RK30SDK_WIFI_GPIO_POWER_N               RK30_PIN3_PD0            
73     #define RK30SDK_WIFI_GPIO_POWER_ENABLE_VALUE    GPIO_LOW//GPIO_HIGH        
74     
75 #elif defined(CONFIG_BCM4329) || defined(CONFIG_BCM4319) || defined(CONFIG_RK903) || defined(CONFIG_RK901)
76     #define RK30SDK_WIFI_GPIO_POWER_N               RK30_PIN3_PD0                 
77     #define RK30SDK_WIFI_GPIO_POWER_ENABLE_VALUE    GPIO_HIGH
78
79     #define RK30SDK_WIFI_GPIO_RESET_N               RK30_PIN2_PA7
80     #define RK30SDK_WIFI_GPIO_RESET_ENABLE_VALUE    GPIO_HIGH 
81
82 #elif defined(CONFIG_MT5931_MT6622) || defined(CONFIG_MT5931)
83
84         #ifdef  CONFIG_MACH_RK3168_LR097 
85         #define RK30SDK_WIFI_GPIO_POWER_N               RK30_PIN3_PD0 
86         #define RK30SDK_WIFI_GPIO_POWER_ENABLE_VALUE    GPIO_HIGH
87
88         //#define RK30SDK_WIFI_GPIO_RESET_N                 RK30_PIN3_PD1
89         //#define RK30SDK_WIFI_GPIO_RESET_ENABLE_VALUE    GPIO_HIGH
90
91         #else
92         #define RK30SDK_WIFI_GPIO_POWER_N               RK30_PIN0_PA5
93         #define RK30SDK_WIFI_GPIO_POWER_ENABLE_VALUE    GPIO_HIGH
94
95         #define RK30SDK_WIFI_GPIO_RESET_N               RK30_PIN3_PD1
96         #define RK30SDK_WIFI_GPIO_RESET_ENABLE_VALUE    GPIO_HIGH       
97         #endif
98
99 #elif defined(CONFIG_MT6620)
100     #define COMBO_MODULE_MT6620_CDT    1  // to control antsel2,antsel3 and gps_lan foot when using AcSip or Cdtech chip. 
101                                               //- 1--use Cdtech chip; 0--unuse CDT chip
102
103     //power, PMU_EN
104     #define RK30SDK_WIFI_GPIO_POWER_N                   RK30_PIN3_PC7            
105     #define RK30SDK_WIFI_GPIO_POWER_ENABLE_VALUE        GPIO_HIGH        
106     //reset, DAIRST,SYSRST_B
107     #define RK30SDK_WIFI_GPIO_RESET_N                   RK30_PIN3_PD1
108     #define RK30SDK_WIFI_GPIO_RESET_ENABLE_VALUE        GPIO_HIGH 
109     //VDDIO
110     //#define RK30SDK_WIFI_GPIO_VCCIO_WL                  RK30_PIN0_PD2 //You do not get control of the foot, and you do not need to define the macro 
111     //#define RK30SDK_WIFI_GPIO_VCCIO_WL_ENABLE_VALUE     GPIO_HIGH
112     //WIFI_INT_B
113     #define RK30SDK_WIFI_GPIO_WIFI_INT_B                RK30_PIN3_PD2
114     #define RK30SDK_WIFI_GPIO_WIFI_INT_B_ENABLE_VALUE   GPIO_HIGH 
115     //BGF_INT_B
116     #define RK30SDK_WIFI_GPIO_BGF_INT_B                 RK30_PIN6_PA7
117     #define RK30SDK_WIFI_GPIO_BGF_INT_B_ENABLE_VALUE    GPIO_HIGH 
118     //GPS_SYNC
119     #define RK30SDK_WIFI_GPIO_GPS_SYNC                  RK30_PIN3_PD0
120     #define RK30SDK_WIFI_GPIO_GPS_SYNC_ENABLE_VALUE     GPIO_HIGH 
121
122     #if COMBO_MODULE_MT6620_CDT
123     //ANTSEL2
124     #define RK30SDK_WIFI_GPIO_ANTSEL2                   RK30_PIN4_PD4
125     #define RK30SDK_WIFI_GPIO_ANTSEL2_ENABLE_VALUE      GPIO_LOW    //use 6620 in CDT chip, LOW--work; High--no work.
126     //ANTSEL3
127     #define RK30SDK_WIFI_GPIO_ANTSEL3                   RK30_PIN4_PD3
128     #define RK30SDK_WIFI_GPIO_ANTSEL3_ENABLE_VALUE      GPIO_HIGH    //use 6620 in CDT chip, High--work; Low--no work..
129     //GPS_LAN
130     #define RK30SDK_WIFI_GPIO_GPS_LAN                   RK30_PIN4_PD6
131     #define RK30SDK_WIFI_GPIO_GPS_LAN_ENABLE_VALUE      GPIO_HIGH    //use 6620 in CDT chip, High--work; Low--no work..
132     #endif // #if COMBO_MODULE_MT6620_CDT--#endif
133 #endif 
134
135 #ifndef RK30SDK_WIFI_GPIO_WIFI_INT_B
136 #define RK30SDK_WIFI_GPIO_WIFI_INT_B              INVALID_GPIO
137 #define RK30SDK_WIFI_GPIO_WIFI_INT_B_ENABLE_VALUE   GPIO_HIGH 
138 #endif
139
140 int rk31sdk_get_sdio_wifi_voltage(void)
141 {
142     int voltage;
143     
144     /******************************************************************************
145     **  Please tell me how much wifi-module uses voltage in your project.  
146     ******************************************************************************/
147 #if defined(CONFIG_BCM4329) || defined(CONFIG_BCM4319) || defined(CONFIG_RK903) || defined(CONFIG_RK901)
148     voltage = 1800 ; //power 1800mV
149     
150 #elif defined(CONFIG_MT5931_MT6622)||defined(CONFIG_MT5931)
151     voltage = 1800 ; //power 1800V
152 #elif defined(CONFIG_MT6620) 
153     voltage = 2800 ; //power 2800V
154 #elif defined(CONFIG_RDA5990)||defined(CONFIG_RTL8723AS)  
155     voltage = 3300 ; //power 3300V
156 #else
157     //default, sdio use 3.0V
158     voltage = 3000 ; //power 3000V
159 #endif
160
161     return voltage;
162 }
163
164
165