hal_led.c 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  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. #include <hal_data.h>
  17. #ifdef CONFIG_RTW_LED
  18. void dump_led_config(void *sel, _adapter *adapter)
  19. {
  20. struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
  21. struct led_priv *ledpriv = adapter_to_led(adapter);
  22. int i;
  23. RTW_PRINT_SEL(sel, "strategy:%u\n", ledpriv->LedStrategy);
  24. #ifdef CONFIG_RTW_SW_LED
  25. RTW_PRINT_SEL(sel, "bRegUseLed:%u\n", ledpriv->bRegUseLed);
  26. RTW_PRINT_SEL(sel, "iface_en_mask:0x%02X\n", ledpriv->iface_en_mask);
  27. for (i = 0; i < dvobj->iface_nums; i++)
  28. RTW_PRINT_SEL(sel, "ctl_en_mask[%d]:0x%08X\n", i, ledpriv->ctl_en_mask[i]);
  29. #endif
  30. }
  31. void rtw_led_set_strategy(_adapter *adapter, u8 strategy)
  32. {
  33. struct led_priv *ledpriv = adapter_to_led(adapter);
  34. _adapter *pri_adapter = GET_PRIMARY_ADAPTER(adapter);
  35. #ifndef CONFIG_RTW_SW_LED
  36. if (IS_SW_LED_STRATEGY(strategy)) {
  37. RTW_WARN("CONFIG_RTW_SW_LED is not defined\n");
  38. return;
  39. }
  40. #endif
  41. #ifdef CONFIG_RTW_SW_LED
  42. if (!ledpriv->bRegUseLed)
  43. return;
  44. #endif
  45. if (ledpriv->LedStrategy == strategy)
  46. return;
  47. if (IS_HW_LED_STRATEGY(strategy) || IS_HW_LED_STRATEGY(ledpriv->LedStrategy)) {
  48. RTW_WARN("switching on/off HW_LED strategy is not supported\n");
  49. return;
  50. }
  51. ledpriv->LedStrategy = strategy;
  52. #ifdef CONFIG_RTW_SW_LED
  53. rtw_hal_sw_led_deinit(pri_adapter);
  54. #endif
  55. rtw_led_control(pri_adapter, RTW_LED_OFF);
  56. }
  57. #ifdef CONFIG_RTW_SW_LED
  58. #if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
  59. void rtw_sw_led_blink_uc_trx_only(LED_DATA *led)
  60. {
  61. _adapter *adapter = led->padapter;
  62. BOOLEAN bStopBlinking = _FALSE;
  63. if (led->BlinkingLedState == RTW_LED_ON)
  64. SwLedOn(adapter, led);
  65. else
  66. SwLedOff(adapter, led);
  67. switch (led->CurrLedState) {
  68. case RTW_LED_ON:
  69. SwLedOn(adapter, led);
  70. break;
  71. case RTW_LED_OFF:
  72. SwLedOff(adapter, led);
  73. break;
  74. case LED_BLINK_TXRX:
  75. led->BlinkTimes--;
  76. if (led->BlinkTimes == 0)
  77. bStopBlinking = _TRUE;
  78. if (adapter_to_pwrctl(adapter)->rf_pwrstate != rf_on
  79. && adapter_to_pwrctl(adapter)->rfoff_reason > RF_CHANGE_BY_PS
  80. ) {
  81. SwLedOff(adapter, led);
  82. led->bLedBlinkInProgress = _FALSE;
  83. } else {
  84. if (led->bLedOn)
  85. led->BlinkingLedState = RTW_LED_OFF;
  86. else
  87. led->BlinkingLedState = RTW_LED_ON;
  88. if (bStopBlinking) {
  89. led->CurrLedState = RTW_LED_OFF;
  90. led->bLedBlinkInProgress = _FALSE;
  91. }
  92. _set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
  93. }
  94. break;
  95. default:
  96. break;
  97. }
  98. }
  99. void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl)
  100. {
  101. struct led_priv *ledpriv = adapter_to_led(adapter);
  102. LED_DATA *led = &(ledpriv->SwLed0);
  103. LED_DATA *led1 = &(ledpriv->SwLed1);
  104. LED_DATA *led2 = &(ledpriv->SwLed2);
  105. switch (ctl) {
  106. case LED_CTL_UC_TX:
  107. case LED_CTL_UC_RX:
  108. if (led->bLedBlinkInProgress == _FALSE) {
  109. led->bLedBlinkInProgress = _TRUE;
  110. led->CurrLedState = LED_BLINK_TXRX;
  111. led->BlinkTimes = 2;
  112. if (led->bLedOn)
  113. led->BlinkingLedState = RTW_LED_OFF;
  114. else
  115. led->BlinkingLedState = RTW_LED_ON;
  116. _set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
  117. }
  118. break;
  119. case LED_CTL_POWER_OFF:
  120. led->CurrLedState = RTW_LED_OFF;
  121. led->BlinkingLedState = RTW_LED_OFF;
  122. if (led->bLedBlinkInProgress) {
  123. _cancel_timer_ex(&(led->BlinkTimer));
  124. led->bLedBlinkInProgress = _FALSE;
  125. }
  126. SwLedOff(adapter, led);
  127. SwLedOff(adapter, led1);
  128. SwLedOff(adapter, led2);
  129. break;
  130. default:
  131. break;
  132. }
  133. }
  134. #endif /* CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY */
  135. void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl)
  136. {
  137. struct led_priv *ledpriv = adapter_to_led(adapter);
  138. if (ledpriv->LedControlHandler) {
  139. #if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
  140. if (ledpriv->LedStrategy != SW_LED_MODE_UC_TRX_ONLY) {
  141. if (ctl == LED_CTL_UC_TX || ctl == LED_CTL_BMC_TX) {
  142. if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_TX))
  143. ctl = LED_CTL_TX; /* transform specific TX ctl to general TX ctl */
  144. } else if (ctl == LED_CTL_UC_RX || ctl == LED_CTL_BMC_RX) {
  145. if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_RX))
  146. ctl = LED_CTL_RX; /* transform specific RX ctl to general RX ctl */
  147. }
  148. }
  149. #endif
  150. if ((ledpriv->iface_en_mask & BIT(adapter->iface_id))
  151. && (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(ctl)))
  152. ledpriv->LedControlHandler(adapter, ctl);
  153. }
  154. }
  155. void rtw_led_tx_control(_adapter *adapter, const u8 *da)
  156. {
  157. #if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
  158. if (IS_MCAST(da))
  159. rtw_led_control(adapter, LED_CTL_BMC_TX);
  160. else
  161. rtw_led_control(adapter, LED_CTL_UC_TX);
  162. #else
  163. rtw_led_control(adapter, LED_CTL_TX);
  164. #endif
  165. }
  166. void rtw_led_rx_control(_adapter *adapter, const u8 *da)
  167. {
  168. #if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
  169. if (IS_MCAST(da))
  170. rtw_led_control(adapter, LED_CTL_BMC_RX);
  171. else
  172. rtw_led_control(adapter, LED_CTL_UC_RX);
  173. #else
  174. rtw_led_control(adapter, LED_CTL_RX);
  175. #endif
  176. }
  177. void rtw_led_set_iface_en(_adapter *adapter, u8 en)
  178. {
  179. struct led_priv *ledpriv = adapter_to_led(adapter);
  180. if (en)
  181. ledpriv->iface_en_mask |= BIT(adapter->iface_id);
  182. else
  183. ledpriv->iface_en_mask &= ~BIT(adapter->iface_id);
  184. }
  185. void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask)
  186. {
  187. struct led_priv *ledpriv = adapter_to_led(adapter);
  188. ledpriv->iface_en_mask = mask;
  189. }
  190. void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask)
  191. {
  192. struct led_priv *ledpriv = adapter_to_led(adapter);
  193. #if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
  194. if (ctl_mask & BIT(LED_CTL_TX))
  195. ctl_mask |= BIT(LED_CTL_UC_TX) | BIT(LED_CTL_BMC_TX);
  196. if (ctl_mask & BIT(LED_CTL_RX))
  197. ctl_mask |= BIT(LED_CTL_UC_RX) | BIT(LED_CTL_BMC_RX);
  198. #endif
  199. ledpriv->ctl_en_mask[adapter->iface_id] = ctl_mask;
  200. }
  201. void rtw_led_set_ctl_en_mask_primary(_adapter *adapter)
  202. {
  203. rtw_led_set_ctl_en_mask(adapter, 0xFFFFFFFF);
  204. }
  205. void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter)
  206. {
  207. rtw_led_set_ctl_en_mask(adapter
  208. , BIT(LED_CTL_POWER_ON) | BIT(LED_CTL_POWER_OFF)
  209. | BIT(LED_CTL_TX) | BIT(LED_CTL_RX)
  210. );
  211. }
  212. #endif /* CONFIG_RTW_SW_LED */
  213. #endif /* CONFIG_RTW_LED */