custom_gpio_linux.c 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2007 - 2017 Realtek Corporation.
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of version 2 of the GNU General Public License as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it will be useful, but WITHOUT
  10. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  12. * more details.
  13. *
  14. *****************************************************************************/
  15. #include "drv_types.h"
  16. #ifdef CONFIG_PLATFORM_SPRD
  17. /* gspi func & GPIO define */
  18. #include <mach/gpio.h>/* 0915 */
  19. #include <mach/board.h>
  20. #if !(defined ANDROID_2X)
  21. #ifdef CONFIG_RTL8188E
  22. #include <mach/regulator.h>
  23. #include <linux/regulator/consumer.h>
  24. #endif /* CONFIG_RTL8188E */
  25. #ifndef GPIO_WIFI_POWER
  26. #define GPIO_WIFI_POWER -1
  27. #endif /* !GPIO_WIFI_POWER */
  28. #ifndef GPIO_WIFI_RESET
  29. #define GPIO_WIFI_RESET -1
  30. #endif /* !GPIO_WIFI_RESET */
  31. #ifndef GPIO_WIFI_PWDN
  32. #define GPIO_WIFI_PWDN -1
  33. #endif /* !GPIO_WIFI_RESET */
  34. #ifdef CONFIG_GSPI_HCI
  35. extern unsigned int oob_irq;
  36. #endif /* CONFIG_GSPI_HCI */
  37. #ifdef CONFIG_SDIO_HCI
  38. extern int rtw_mp_mode;
  39. #else /* !CONFIG_SDIO_HCI */
  40. #endif /* !CONFIG_SDIO_HCI */
  41. int rtw_wifi_gpio_init(void)
  42. {
  43. #ifdef CONFIG_GSPI_HCI
  44. if (GPIO_WIFI_IRQ > 0) {
  45. gpio_request(GPIO_WIFI_IRQ, "oob_irq");
  46. gpio_direction_input(GPIO_WIFI_IRQ);
  47. oob_irq = gpio_to_irq(GPIO_WIFI_IRQ);
  48. RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
  49. }
  50. #endif
  51. if (GPIO_WIFI_RESET > 0)
  52. gpio_request(GPIO_WIFI_RESET , "wifi_rst");
  53. if (GPIO_WIFI_POWER > 0)
  54. gpio_request(GPIO_WIFI_POWER, "wifi_power");
  55. #ifdef CONFIG_SDIO_HCI
  56. #if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1)
  57. if (rtw_mp_mode == 1) {
  58. RTW_INFO("%s GPIO_BT_RESET pin special for mp_test\n", __func__);
  59. if (GPIO_BT_RESET > 0)
  60. gpio_request(GPIO_BT_RESET , "bt_rst");
  61. }
  62. #endif
  63. #endif
  64. return 0;
  65. }
  66. int rtw_wifi_gpio_deinit(void)
  67. {
  68. #ifdef CONFIG_GSPI_HCI
  69. if (GPIO_WIFI_IRQ > 0)
  70. gpio_free(GPIO_WIFI_IRQ);
  71. #endif
  72. if (GPIO_WIFI_RESET > 0)
  73. gpio_free(GPIO_WIFI_RESET);
  74. if (GPIO_WIFI_POWER > 0)
  75. gpio_free(GPIO_WIFI_POWER);
  76. #ifdef CONFIG_SDIO_HCI
  77. #if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1)
  78. if (rtw_mp_mode == 1) {
  79. RTW_INFO("%s GPIO_BT_RESET pin special for mp_test\n", __func__);
  80. if (GPIO_BT_RESET > 0)
  81. gpio_free(GPIO_BT_RESET);
  82. }
  83. #endif
  84. #endif
  85. return 0;
  86. }
  87. /* Customer function to control hw specific wlan gpios */
  88. void rtw_wifi_gpio_wlan_ctrl(int onoff)
  89. {
  90. switch (onoff) {
  91. case WLAN_PWDN_OFF:
  92. RTW_INFO("%s: call customer specific GPIO(%d) to set wifi power down pin to 0\n",
  93. __FUNCTION__, GPIO_WIFI_RESET);
  94. #ifndef CONFIG_DONT_BUS_SCAN
  95. if (GPIO_WIFI_RESET > 0)
  96. gpio_direction_output(GPIO_WIFI_RESET , 0);
  97. #endif
  98. break;
  99. case WLAN_PWDN_ON:
  100. RTW_INFO("%s: callc customer specific GPIO(%d) to set wifi power down pin to 1\n",
  101. __FUNCTION__, GPIO_WIFI_RESET);
  102. if (GPIO_WIFI_RESET > 0)
  103. gpio_direction_output(GPIO_WIFI_RESET , 1);
  104. break;
  105. case WLAN_POWER_OFF:
  106. break;
  107. case WLAN_POWER_ON:
  108. break;
  109. #ifdef CONFIG_SDIO_HCI
  110. #if (defined(CONFIG_RTL8723B)) && (MP_DRIVER == 1)
  111. case WLAN_BT_PWDN_OFF:
  112. if (rtw_mp_mode == 1) {
  113. RTW_INFO("%s: call customer specific GPIO to set wifi power down pin to 0\n",
  114. __FUNCTION__);
  115. if (GPIO_BT_RESET > 0)
  116. gpio_direction_output(GPIO_BT_RESET , 0);
  117. }
  118. break;
  119. case WLAN_BT_PWDN_ON:
  120. if (rtw_mp_mode == 1) {
  121. RTW_INFO("%s: callc customer specific GPIO to set wifi power down pin to 1 %x\n",
  122. __FUNCTION__, GPIO_BT_RESET);
  123. if (GPIO_BT_RESET > 0)
  124. gpio_direction_output(GPIO_BT_RESET , 1);
  125. }
  126. break;
  127. #endif
  128. #endif
  129. }
  130. }
  131. #else /* ANDROID_2X */
  132. #include <mach/ldo.h>
  133. #ifdef CONFIG_RTL8188E
  134. extern int sprd_3rdparty_gpio_wifi_power;
  135. #endif
  136. extern int sprd_3rdparty_gpio_wifi_pwd;
  137. #if defined(CONFIG_RTL8723B)
  138. extern int sprd_3rdparty_gpio_bt_reset;
  139. #endif
  140. int rtw_wifi_gpio_init(void)
  141. {
  142. #if defined(CONFIG_RTL8723B)
  143. if (sprd_3rdparty_gpio_bt_reset > 0)
  144. gpio_direction_output(sprd_3rdparty_gpio_bt_reset, 1);
  145. #endif
  146. return 0;
  147. }
  148. int rtw_wifi_gpio_deinit(void)
  149. {
  150. return 0;
  151. }
  152. /* Customer function to control hw specific wlan gpios */
  153. void rtw_wifi_gpio_wlan_ctrl(int onoff)
  154. {
  155. switch (onoff) {
  156. case WLAN_PWDN_OFF:
  157. RTW_INFO("%s: call customer specific GPIO to set wifi power down pin to 0\n",
  158. __FUNCTION__);
  159. if (sprd_3rdparty_gpio_wifi_pwd > 0)
  160. gpio_set_value(sprd_3rdparty_gpio_wifi_pwd, 0);
  161. if (sprd_3rdparty_gpio_wifi_pwd == 60) {
  162. RTW_INFO("%s: turn off VSIM2 2.8V\n", __func__);
  163. LDO_TurnOffLDO(LDO_LDO_SIM2);
  164. }
  165. break;
  166. case WLAN_PWDN_ON:
  167. RTW_INFO("%s: callc customer specific GPIO to set wifi power down pin to 1\n",
  168. __FUNCTION__);
  169. if (sprd_3rdparty_gpio_wifi_pwd == 60) {
  170. RTW_INFO("%s: turn on VSIM2 2.8V\n", __func__);
  171. LDO_SetVoltLevel(LDO_LDO_SIM2, LDO_VOLT_LEVEL0);
  172. LDO_TurnOnLDO(LDO_LDO_SIM2);
  173. }
  174. if (sprd_3rdparty_gpio_wifi_pwd > 0)
  175. gpio_set_value(sprd_3rdparty_gpio_wifi_pwd, 1);
  176. break;
  177. case WLAN_POWER_OFF:
  178. #ifdef CONFIG_RTL8188E
  179. #ifdef CONFIG_WIF1_LDO
  180. RTW_INFO("%s: turn off VDD-WIFI0 1.2V\n", __FUNCTION__);
  181. LDO_TurnOffLDO(LDO_LDO_WIF1);
  182. #endif /* CONFIG_WIF1_LDO */
  183. RTW_INFO("%s: turn off VDD-WIFI0 3.3V\n", __FUNCTION__);
  184. LDO_TurnOffLDO(LDO_LDO_WIF0);
  185. RTW_INFO("%s: call customer specific GPIO(%d) to turn off wifi power\n",
  186. __FUNCTION__, sprd_3rdparty_gpio_wifi_power);
  187. if (sprd_3rdparty_gpio_wifi_power != 65535)
  188. gpio_set_value(sprd_3rdparty_gpio_wifi_power, 0);
  189. #endif
  190. break;
  191. case WLAN_POWER_ON:
  192. #ifdef CONFIG_RTL8188E
  193. RTW_INFO("%s: call customer specific GPIO(%d) to turn on wifi power\n",
  194. __FUNCTION__, sprd_3rdparty_gpio_wifi_power);
  195. if (sprd_3rdparty_gpio_wifi_power != 65535)
  196. gpio_set_value(sprd_3rdparty_gpio_wifi_power, 1);
  197. RTW_INFO("%s: turn on VDD-WIFI0 3.3V\n", __FUNCTION__);
  198. LDO_TurnOnLDO(LDO_LDO_WIF0);
  199. LDO_SetVoltLevel(LDO_LDO_WIF0, LDO_VOLT_LEVEL1);
  200. #ifdef CONFIG_WIF1_LDO
  201. RTW_INFO("%s: turn on VDD-WIFI1 1.2V\n", __func__);
  202. LDO_TurnOnLDO(LDO_LDO_WIF1);
  203. LDO_SetVoltLevel(LDO_LDO_WIF1, LDO_VOLT_LEVEL3);
  204. #endif /* CONFIG_WIF1_LDO */
  205. #endif
  206. break;
  207. case WLAN_BT_PWDN_OFF:
  208. RTW_INFO("%s: call customer specific GPIO to set bt power down pin to 0\n",
  209. __FUNCTION__);
  210. #if defined(CONFIG_RTL8723B)
  211. if (sprd_3rdparty_gpio_bt_reset > 0)
  212. gpio_set_value(sprd_3rdparty_gpio_bt_reset, 0);
  213. #endif
  214. break;
  215. case WLAN_BT_PWDN_ON:
  216. RTW_INFO("%s: callc customer specific GPIO to set bt power down pin to 1\n",
  217. __FUNCTION__);
  218. #if defined(CONFIG_RTL8723B)
  219. if (sprd_3rdparty_gpio_bt_reset > 0)
  220. gpio_set_value(sprd_3rdparty_gpio_bt_reset, 1);
  221. #endif
  222. break;
  223. }
  224. }
  225. #endif /* ANDROID_2X */
  226. #elif defined(CONFIG_PLATFORM_ARM_RK3066)
  227. #include <mach/iomux.h>
  228. #define GPIO_WIFI_IRQ RK30_PIN2_PC2
  229. extern unsigned int oob_irq;
  230. int rtw_wifi_gpio_init(void)
  231. {
  232. #ifdef CONFIG_GSPI_HCI
  233. if (GPIO_WIFI_IRQ > 0) {
  234. rk30_mux_api_set(GPIO2C2_LCDC1DATA18_SMCBLSN1_HSADCDATA5_NAME, GPIO2C_GPIO2C2);/* jacky_test */
  235. gpio_request(GPIO_WIFI_IRQ, "oob_irq");
  236. gpio_direction_input(GPIO_WIFI_IRQ);
  237. oob_irq = gpio_to_irq(GPIO_WIFI_IRQ);
  238. RTW_INFO("%s oob_irq:%d\n", __func__, oob_irq);
  239. }
  240. #endif
  241. return 0;
  242. }
  243. int rtw_wifi_gpio_deinit(void)
  244. {
  245. #ifdef CONFIG_GSPI_HCI
  246. if (GPIO_WIFI_IRQ > 0)
  247. gpio_free(GPIO_WIFI_IRQ);
  248. #endif
  249. return 0;
  250. }
  251. void rtw_wifi_gpio_wlan_ctrl(int onoff)
  252. {
  253. }
  254. #ifdef CONFIG_GPIO_API
  255. /* this is a demo for extending GPIO pin[7] as interrupt mode */
  256. struct net_device *rtl_net;
  257. extern int rtw_register_gpio_interrupt(struct net_device *netdev, int gpio_num, void(*callback)(u8 level));
  258. extern int rtw_disable_gpio_interrupt(struct net_device *netdev, int gpio_num);
  259. void gpio_int(u8 is_high)
  260. {
  261. RTW_INFO("%s level=%d\n", __func__, is_high);
  262. }
  263. int register_net_gpio_init(void)
  264. {
  265. rtl_net = dev_get_by_name(&init_net, "wlan0");
  266. if (!rtl_net) {
  267. RTW_PRINT("rtl_net init fail!\n");
  268. return -1;
  269. }
  270. return rtw_register_gpio_interrupt(rtl_net, 7, gpio_int);
  271. }
  272. int unregister_net_gpio_init(void)
  273. {
  274. rtl_net = dev_get_by_name(&init_net, "wlan0");
  275. if (!rtl_net) {
  276. RTW_PRINT("rtl_net init fail!\n");
  277. return -1;
  278. }
  279. return rtw_disable_gpio_interrupt(rtl_net, 7);
  280. }
  281. #endif
  282. #else
  283. int rtw_wifi_gpio_init(void)
  284. {
  285. return 0;
  286. }
  287. void rtw_wifi_gpio_wlan_ctrl(int onoff)
  288. {
  289. }
  290. #endif /* CONFIG_PLATFORM_SPRD */