hal_com_led.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
  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. * You should have received a copy of the GNU General Public License along with
  15. * this program; if not, write to the Free Software Foundation, Inc.,
  16. * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
  17. *
  18. *
  19. ******************************************************************************/
  20. #ifndef __HAL_COMMON_LED_H_
  21. #define __HAL_COMMON_LED_H_
  22. #define MSECS(t) (HZ * ((t) / 1000) + (HZ * ((t) % 1000)) / 1000)
  23. /* ********************************************************************************
  24. * LED Behavior Constant.
  25. * ********************************************************************************
  26. * Default LED behavior.
  27. * */
  28. #define LED_BLINK_NORMAL_INTERVAL 100
  29. #define LED_BLINK_SLOWLY_INTERVAL 200
  30. #define LED_BLINK_LONG_INTERVAL 400
  31. #define LED_INITIAL_INTERVAL 1800
  32. /* LED Customerization */
  33. /* NETTRONIX */
  34. #define LED_BLINK_NORMAL_INTERVAL_NETTRONIX 100
  35. #define LED_BLINK_SLOWLY_INTERVAL_NETTRONIX 2000
  36. /* PORNET */
  37. #define LED_BLINK_SLOWLY_INTERVAL_PORNET 1000
  38. #define LED_BLINK_NORMAL_INTERVAL_PORNET 100
  39. #define LED_BLINK_FAST_INTERVAL_BITLAND 30
  40. /* AzWave. */
  41. #define LED_CM2_BLINK_ON_INTERVAL 250
  42. #define LED_CM2_BLINK_OFF_INTERVAL 4750
  43. #define LED_CM8_BLINK_OFF_INTERVAL 3750 /* for QMI */
  44. /* RunTop */
  45. #define LED_RunTop_BLINK_INTERVAL 300
  46. /* ALPHA */
  47. #define LED_BLINK_NO_LINK_INTERVAL_ALPHA 1000
  48. #define LED_BLINK_NO_LINK_INTERVAL_ALPHA_500MS 500 /* add by ylb 20121012 for customer led for alpha */
  49. #define LED_BLINK_LINK_INTERVAL_ALPHA 500 /* 500 */
  50. #define LED_BLINK_SCAN_INTERVAL_ALPHA 180 /* 150 */
  51. #define LED_BLINK_FASTER_INTERVAL_ALPHA 50
  52. #define LED_BLINK_WPS_SUCESS_INTERVAL_ALPHA 5000
  53. /* 111122 by hpfan: Customized for Xavi */
  54. #define LED_CM11_BLINK_INTERVAL 300
  55. #define LED_CM11_LINK_ON_INTERVEL 3000
  56. /* Netgear */
  57. #define LED_BLINK_LINK_INTERVAL_NETGEAR 500
  58. #define LED_BLINK_LINK_SLOWLY_INTERVAL_NETGEAR 1000
  59. #define LED_WPS_BLINK_OFF_INTERVAL_NETGEAR 100
  60. #define LED_WPS_BLINK_ON_INTERVAL_NETGEAR 500
  61. /* Belkin AC950 */
  62. #define LED_BLINK_LINK_INTERVAL_ON_BELKIN 200
  63. #define LED_BLINK_LINK_INTERVAL_OFF_BELKIN 100
  64. #define LED_BLINK_ERROR_INTERVAL_BELKIN 100
  65. /* by chiyokolin for Azurewave */
  66. #define LED_CM12_BLINK_INTERVAL_5Mbps 160
  67. #define LED_CM12_BLINK_INTERVAL_10Mbps 80
  68. #define LED_CM12_BLINK_INTERVAL_20Mbps 50
  69. #define LED_CM12_BLINK_INTERVAL_40Mbps 40
  70. #define LED_CM12_BLINK_INTERVAL_80Mbps 30
  71. #define LED_CM12_BLINK_INTERVAL_MAXMbps 25
  72. /* Dlink */
  73. #define LED_BLINK_NO_LINK_INTERVAL 1000
  74. #define LED_BLINK_LINK_IDEL_INTERVAL 100
  75. #define LED_BLINK_SCAN_ON_INTERVAL 30
  76. #define LED_BLINK_SCAN_OFF_INTERVAL 300
  77. #define LED_WPS_BLINK_ON_INTERVAL_DLINK 30
  78. #define LED_WPS_BLINK_OFF_INTERVAL_DLINK 300
  79. #define LED_WPS_BLINK_LINKED_ON_INTERVAL_DLINK 5000
  80. /* ********************************************************************************
  81. * LED object.
  82. * ******************************************************************************** */
  83. typedef enum _LED_CTL_MODE {
  84. LED_CTL_POWER_ON = 1,
  85. LED_CTL_LINK = 2,
  86. LED_CTL_NO_LINK = 3,
  87. LED_CTL_TX = 4,
  88. LED_CTL_RX = 5,
  89. LED_CTL_SITE_SURVEY = 6,
  90. LED_CTL_POWER_OFF = 7,
  91. LED_CTL_START_TO_LINK = 8,
  92. LED_CTL_START_WPS = 9,
  93. LED_CTL_STOP_WPS = 10,
  94. LED_CTL_START_WPS_BOTTON = 11, /* added for runtop */
  95. LED_CTL_STOP_WPS_FAIL = 12, /* added for ALPHA */
  96. LED_CTL_STOP_WPS_FAIL_OVERLAP = 13, /* added for BELKIN */
  97. LED_CTL_CONNECTION_NO_TRANSFER = 14,
  98. } LED_CTL_MODE;
  99. typedef enum _LED_STATE {
  100. LED_UNKNOWN = 0,
  101. RTW_LED_ON = 1,
  102. RTW_LED_OFF = 2,
  103. LED_BLINK_NORMAL = 3,
  104. LED_BLINK_SLOWLY = 4,
  105. LED_BLINK_POWER_ON = 5,
  106. LED_BLINK_SCAN = 6, /* LED is blinking during scanning period, the # of times to blink is depend on time for scanning. */
  107. LED_BLINK_NO_LINK = 7, /* LED is blinking during no link state. */
  108. LED_BLINK_StartToBlink = 8, /* Customzied for Sercomm Printer Server case */
  109. LED_BLINK_TXRX = 9,
  110. LED_BLINK_WPS = 10, /* LED is blinkg during WPS communication */
  111. LED_BLINK_WPS_STOP = 11, /* for ALPHA */
  112. LED_BLINK_WPS_STOP_OVERLAP = 12, /* for BELKIN */
  113. LED_BLINK_RUNTOP = 13, /* Customized for RunTop */
  114. LED_BLINK_CAMEO = 14,
  115. LED_BLINK_XAVI = 15,
  116. LED_BLINK_ALWAYS_ON = 16,
  117. LED_BLINK_LINK_IN_PROCESS = 17, /* Customized for Belkin AC950 */
  118. LED_BLINK_AUTH_ERROR = 18, /* Customized for Belkin AC950 */
  119. LED_BLINK_Azurewave_5Mbps = 19,
  120. LED_BLINK_Azurewave_10Mbps = 20,
  121. LED_BLINK_Azurewave_20Mbps = 21,
  122. LED_BLINK_Azurewave_40Mbps = 22,
  123. LED_BLINK_Azurewave_80Mbps = 23,
  124. LED_BLINK_Azurewave_MAXMbps = 24,
  125. LED_BLINK_LINK_IDEL = 25,
  126. LED_BLINK_WPS_LINKED = 26,
  127. } LED_STATE;
  128. typedef enum _LED_PIN {
  129. LED_PIN_GPIO0,
  130. LED_PIN_LED0,
  131. LED_PIN_LED1,
  132. LED_PIN_LED2
  133. } LED_PIN;
  134. /* ********************************************************************************
  135. * PCIE LED Definition.
  136. * ******************************************************************************** */
  137. #ifdef CONFIG_PCI_HCI
  138. typedef enum _LED_STRATEGY_PCIE {
  139. SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
  140. SW_LED_MODE1, /* SW control for PCI Express */
  141. SW_LED_MODE2, /* SW control for Cameo. */
  142. SW_LED_MODE3, /* SW contorl for RunTop. */
  143. SW_LED_MODE4, /* SW control for Netcore */
  144. SW_LED_MODE5, /* added by vivi, for led new mode, DLINK */
  145. SW_LED_MODE6, /* added by vivi, for led new mode, PRONET */
  146. SW_LED_MODE7, /* added by chiyokolin, for Lenovo, PCI Express Minicard Spec Rev.1.2 spec */
  147. SW_LED_MODE8, /* added by chiyokolin, for QMI */
  148. SW_LED_MODE9, /* added by chiyokolin, for BITLAND-LENOVO, PCI Express Minicard Spec Rev.1.1 */
  149. SW_LED_MODE10, /* added by chiyokolin, for Edimax-ASUS */
  150. SW_LED_MODE11, /* added by hpfan, for Xavi */
  151. SW_LED_MODE12, /* added by chiyokolin, for Azurewave */
  152. HW_LED, /* HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes) */
  153. } LED_STRATEGY_PCIE, *PLED_STRATEGY_PCIE;
  154. typedef struct _LED_PCIE {
  155. PADAPTER padapter;
  156. LED_PIN LedPin; /* Identify how to implement this SW led. */
  157. LED_STATE CurrLedState; /* Current LED state. */
  158. BOOLEAN bLedOn; /* TRUE if LED is ON, FALSE if LED is OFF. */
  159. BOOLEAN bLedBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
  160. BOOLEAN bLedWPSBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
  161. BOOLEAN bLedSlowBlinkInProgress;/* added by vivi, for led new mode */
  162. u32 BlinkTimes; /* Number of times to toggle led state for blinking. */
  163. LED_STATE BlinkingLedState; /* Next state for blinking, either LED_ON or LED_OFF are. */
  164. _timer BlinkTimer; /* Timer object for led blinking. */
  165. } LED_PCIE, *PLED_PCIE;
  166. typedef struct _LED_PCIE LED_DATA, *PLED_DATA;
  167. typedef enum _LED_STRATEGY_PCIE LED_STRATEGY, *PLED_STRATEGY;
  168. VOID
  169. LedControlPCIE(
  170. IN PADAPTER Adapter,
  171. IN LED_CTL_MODE LedAction
  172. );
  173. VOID
  174. gen_RefreshLedState(
  175. IN PADAPTER Adapter);
  176. /* ********************************************************************************
  177. * USB LED Definition.
  178. * ******************************************************************************** */
  179. #elif defined(CONFIG_USB_HCI)
  180. #define IS_LED_WPS_BLINKING(_LED_USB) (((PLED_USB)_LED_USB)->CurrLedState == LED_BLINK_WPS \
  181. || ((PLED_USB)_LED_USB)->CurrLedState == LED_BLINK_WPS_STOP \
  182. || ((PLED_USB)_LED_USB)->bLedWPSBlinkInProgress)
  183. #define IS_LED_BLINKING(_LED_USB) (((PLED_USB)_LED_USB)->bLedWPSBlinkInProgress \
  184. || ((PLED_USB)_LED_USB)->bLedScanBlinkInProgress)
  185. typedef enum _LED_STRATEGY_USB {
  186. SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
  187. SW_LED_MODE1, /* 2 LEDs, through LED0 and LED1. For ALPHA. */
  188. SW_LED_MODE2, /* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. */
  189. SW_LED_MODE3, /* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. */
  190. SW_LED_MODE4, /* for Edimax / Belkin */
  191. SW_LED_MODE5, /* for Sercomm / Belkin */
  192. SW_LED_MODE6, /* for 88CU minicard, porting from ce SW_LED_MODE7 */
  193. SW_LED_MODE7, /* for Netgear special requirement */
  194. SW_LED_MODE8, /* for LC */
  195. SW_LED_MODE9, /* for Belkin AC950 */
  196. SW_LED_MODE10, /* for Netgear A6200V2 */
  197. SW_LED_MODE11, /* for Edimax / ASUS */
  198. SW_LED_MODE12, /* for WNC/NEC */
  199. SW_LED_MODE13, /* for Netgear A6100, 8811Au */
  200. SW_LED_MODE14, /* for Buffalo, DNI, 8811Au */
  201. SW_LED_MODE15, /* for DLINK, 8811Au/8812AU */
  202. HW_LED, /* HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes, see MAC.CONFIG1 for details.) */
  203. } LED_STRATEGY_USB, *PLED_STRATEGY_USB;
  204. typedef struct _LED_USB {
  205. PADAPTER padapter;
  206. LED_PIN LedPin; /* Identify how to implement this SW led. */
  207. LED_STATE CurrLedState; /* Current LED state. */
  208. BOOLEAN bLedOn; /* TRUE if LED is ON, FALSE if LED is OFF. */
  209. BOOLEAN bSWLedCtrl;
  210. BOOLEAN bLedBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
  211. /* ALPHA, added by chiyoko, 20090106 */
  212. BOOLEAN bLedNoLinkBlinkInProgress;
  213. BOOLEAN bLedLinkBlinkInProgress;
  214. BOOLEAN bLedStartToLinkBlinkInProgress;
  215. BOOLEAN bLedScanBlinkInProgress;
  216. BOOLEAN bLedWPSBlinkInProgress;
  217. u32 BlinkTimes; /* Number of times to toggle led state for blinking. */
  218. u8 BlinkCounter; /* Added for turn off overlap led after blinking a while, by page, 20120821 */
  219. LED_STATE BlinkingLedState; /* Next state for blinking, either LED_ON or LED_OFF are. */
  220. _timer BlinkTimer; /* Timer object for led blinking. */
  221. _workitem BlinkWorkItem; /* Workitem used by BlinkTimer to manipulate H/W to blink LED.' */
  222. } LED_USB, *PLED_USB;
  223. typedef struct _LED_USB LED_DATA, *PLED_DATA;
  224. typedef enum _LED_STRATEGY_USB LED_STRATEGY, *PLED_STRATEGY;
  225. VOID
  226. LedControlUSB(
  227. IN PADAPTER Adapter,
  228. IN LED_CTL_MODE LedAction
  229. );
  230. /* ********************************************************************************
  231. * SDIO LED Definition.
  232. * ******************************************************************************** */
  233. #elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
  234. #define IS_LED_WPS_BLINKING(_LED_SDIO) (((PLED_SDIO)_LED_SDIO)->CurrLedState == LED_BLINK_WPS \
  235. || ((PLED_SDIO)_LED_SDIO)->CurrLedState == LED_BLINK_WPS_STOP \
  236. || ((PLED_SDIO)_LED_SDIO)->bLedWPSBlinkInProgress)
  237. #define IS_LED_BLINKING(_LED_SDIO) (((PLED_SDIO)_LED_SDIO)->bLedWPSBlinkInProgress \
  238. || ((PLED_SDIO)_LED_SDIO)->bLedScanBlinkInProgress)
  239. typedef enum _LED_STRATEGY_SDIO {
  240. SW_LED_MODE0, /* SW control 1 LED via GPIO0. It is default option. */
  241. SW_LED_MODE1, /* 2 LEDs, through LED0 and LED1. For ALPHA. */
  242. SW_LED_MODE2, /* SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. */
  243. SW_LED_MODE3, /* SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. */
  244. SW_LED_MODE4, /* for Edimax / Belkin */
  245. SW_LED_MODE5, /* for Sercomm / Belkin */
  246. SW_LED_MODE6, /* for 88CU minicard, porting from ce SW_LED_MODE7 */
  247. HW_LED, /* HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes, see MAC.CONFIG1 for details.) */
  248. } LED_STRATEGY_SDIO, *PLED_STRATEGY_SDIO;
  249. typedef struct _LED_SDIO {
  250. PADAPTER padapter;
  251. LED_PIN LedPin; /* Identify how to implement this SW led. */
  252. LED_STATE CurrLedState; /* Current LED state. */
  253. BOOLEAN bLedOn; /* TRUE if LED is ON, FALSE if LED is OFF. */
  254. BOOLEAN bSWLedCtrl;
  255. BOOLEAN bLedBlinkInProgress; /* TRUE if it is blinking, FALSE o.w.. */
  256. /* ALPHA, added by chiyoko, 20090106 */
  257. BOOLEAN bLedNoLinkBlinkInProgress;
  258. BOOLEAN bLedLinkBlinkInProgress;
  259. BOOLEAN bLedStartToLinkBlinkInProgress;
  260. BOOLEAN bLedScanBlinkInProgress;
  261. BOOLEAN bLedWPSBlinkInProgress;
  262. u32 BlinkTimes; /* Number of times to toggle led state for blinking. */
  263. LED_STATE BlinkingLedState; /* Next state for blinking, either LED_ON or LED_OFF are. */
  264. _timer BlinkTimer; /* Timer object for led blinking. */
  265. _workitem BlinkWorkItem; /* Workitem used by BlinkTimer to manipulate H/W to blink LED. */
  266. } LED_SDIO, *PLED_SDIO;
  267. typedef struct _LED_SDIO LED_DATA, *PLED_DATA;
  268. typedef enum _LED_STRATEGY_SDIO LED_STRATEGY, *PLED_STRATEGY;
  269. VOID
  270. LedControlSDIO(
  271. IN PADAPTER Adapter,
  272. IN LED_CTL_MODE LedAction
  273. );
  274. #endif
  275. struct led_priv {
  276. /* add for led controll */
  277. LED_DATA SwLed0;
  278. LED_DATA SwLed1;
  279. LED_DATA SwLed2;
  280. LED_STRATEGY LedStrategy;
  281. u8 bRegUseLed;
  282. void (*LedControlHandler)(_adapter *padapter, LED_CTL_MODE LedAction);
  283. void (*SwLedOn)(_adapter *padapter, PLED_DATA pLed);
  284. void (*SwLedOff)(_adapter *padapter, PLED_DATA pLed);
  285. /* add for led controll */
  286. };
  287. #ifdef CONFIG_SW_LED
  288. #define rtw_led_control(adapter, LedAction) \
  289. do { \
  290. if ((adapter)->ledpriv.LedControlHandler) \
  291. (adapter)->ledpriv.LedControlHandler((adapter), (LedAction)); \
  292. } while (0)
  293. #else /* CONFIG_SW_LED */
  294. #define rtw_led_control(adapter, LedAction)
  295. #endif /* CONFIG_SW_LED */
  296. #define SwLedOn(adapter, pLed) \
  297. do { \
  298. if ((adapter)->ledpriv.SwLedOn) \
  299. (adapter)->ledpriv.SwLedOn((adapter), (pLed)); \
  300. } while (0)
  301. #define SwLedOff(adapter, pLed) \
  302. do { \
  303. if ((adapter)->ledpriv.SwLedOff) \
  304. (adapter)->ledpriv.SwLedOff((adapter), (pLed)); \
  305. } while (0)
  306. void BlinkTimerCallback(struct timer_list *t);
  307. void BlinkWorkItemCallback(_workitem *work);
  308. void ResetLedStatus(PLED_DATA pLed);
  309. void
  310. InitLed(
  311. _adapter *padapter,
  312. PLED_DATA pLed,
  313. LED_PIN LedPin
  314. );
  315. void
  316. DeInitLed(
  317. PLED_DATA pLed
  318. );
  319. /* hal... */
  320. extern void BlinkHandler(PLED_DATA pLed);
  321. #endif /* __RTW_LED_H_ */