Path: blob/master/ALFA-W1F1/RTL8814AU/hal/led/hal_led.c
1307 views
/******************************************************************************1*2* Copyright(c) 2007 - 2017 Realtek Corporation.3*4* This program is free software; you can redistribute it and/or modify it5* under the terms of version 2 of the GNU General Public License as6* published by the Free Software Foundation.7*8* This program is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for11* more details.12*13*****************************************************************************/1415#include <drv_types.h>16#include <hal_data.h>1718#ifdef CONFIG_RTW_LED19void dump_led_config(void *sel, _adapter *adapter)20{21struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);22struct led_priv *ledpriv = adapter_to_led(adapter);23int i;2425RTW_PRINT_SEL(sel, "strategy:%u\n", ledpriv->LedStrategy);26#ifdef CONFIG_RTW_SW_LED27RTW_PRINT_SEL(sel, "bRegUseLed:%u\n", ledpriv->bRegUseLed);28RTW_PRINT_SEL(sel, "iface_en_mask:0x%02X\n", ledpriv->iface_en_mask);29for (i = 0; i < dvobj->iface_nums; i++)30RTW_PRINT_SEL(sel, "ctl_en_mask[%d]:0x%08X\n", i, ledpriv->ctl_en_mask[i]);31#endif32}3334void rtw_led_set_strategy(_adapter *adapter, u8 strategy)35{36struct led_priv *ledpriv = adapter_to_led(adapter);37_adapter *pri_adapter = GET_PRIMARY_ADAPTER(adapter);3839#ifndef CONFIG_RTW_SW_LED40if (IS_SW_LED_STRATEGY(strategy)) {41RTW_WARN("CONFIG_RTW_SW_LED is not defined\n");42return;43}44#endif4546#ifdef CONFIG_RTW_SW_LED47if (!ledpriv->bRegUseLed)48return;49#endif5051if (ledpriv->LedStrategy == strategy)52return;5354if (IS_HW_LED_STRATEGY(strategy) || IS_HW_LED_STRATEGY(ledpriv->LedStrategy)) {55RTW_WARN("switching on/off HW_LED strategy is not supported\n");56return;57}5859ledpriv->LedStrategy = strategy;6061#ifdef CONFIG_RTW_SW_LED62rtw_hal_sw_led_deinit(pri_adapter);63#endif6465rtw_led_control(pri_adapter, RTW_LED_OFF);66}6768#ifdef CONFIG_RTW_SW_LED69#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY70void rtw_sw_led_blink_uc_trx_only(LED_DATA *led)71{72_adapter *adapter = led->padapter;73BOOLEAN bStopBlinking = _FALSE;7475if (led->BlinkingLedState == RTW_LED_ON)76SwLedOn(adapter, led);77else78SwLedOff(adapter, led);7980switch (led->CurrLedState) {81case RTW_LED_ON:82SwLedOn(adapter, led);83break;8485case RTW_LED_OFF:86SwLedOff(adapter, led);87break;8889case LED_BLINK_TXRX:90led->BlinkTimes--;91if (led->BlinkTimes == 0)92bStopBlinking = _TRUE;9394if (adapter_to_pwrctl(adapter)->rf_pwrstate != rf_on95&& adapter_to_pwrctl(adapter)->rfoff_reason > RF_CHANGE_BY_PS96) {97SwLedOff(adapter, led);98led->bLedBlinkInProgress = _FALSE;99} else {100if (led->bLedOn)101led->BlinkingLedState = RTW_LED_OFF;102else103led->BlinkingLedState = RTW_LED_ON;104105if (bStopBlinking) {106led->CurrLedState = RTW_LED_OFF;107led->bLedBlinkInProgress = _FALSE;108}109_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);110}111break;112113default:114break;115}116}117118void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl)119{120struct led_priv *ledpriv = adapter_to_led(adapter);121LED_DATA *led = &(ledpriv->SwLed0);122LED_DATA *led1 = &(ledpriv->SwLed1);123LED_DATA *led2 = &(ledpriv->SwLed2);124125switch (ctl) {126case LED_CTL_UC_TX:127case LED_CTL_UC_RX:128if (led->bLedBlinkInProgress == _FALSE) {129led->bLedBlinkInProgress = _TRUE;130led->CurrLedState = LED_BLINK_TXRX;131led->BlinkTimes = 2;132if (led->bLedOn)133led->BlinkingLedState = RTW_LED_OFF;134else135led->BlinkingLedState = RTW_LED_ON;136_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);137}138break;139140case LED_CTL_POWER_OFF:141led->CurrLedState = RTW_LED_OFF;142led->BlinkingLedState = RTW_LED_OFF;143144if (led->bLedBlinkInProgress) {145_cancel_timer_ex(&(led->BlinkTimer));146led->bLedBlinkInProgress = _FALSE;147}148149SwLedOff(adapter, led);150SwLedOff(adapter, led1);151SwLedOff(adapter, led2);152break;153154default:155break;156}157}158#endif /* CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY */159160void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl)161{162struct led_priv *ledpriv = adapter_to_led(adapter);163164if (ledpriv->LedControlHandler) {165#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY166if (ledpriv->LedStrategy != SW_LED_MODE_UC_TRX_ONLY) {167if (ctl == LED_CTL_UC_TX || ctl == LED_CTL_BMC_TX) {168if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_TX))169ctl = LED_CTL_TX; /* transform specific TX ctl to general TX ctl */170} else if (ctl == LED_CTL_UC_RX || ctl == LED_CTL_BMC_RX) {171if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_RX))172ctl = LED_CTL_RX; /* transform specific RX ctl to general RX ctl */173}174}175#endif176177if ((ledpriv->iface_en_mask & BIT(adapter->iface_id))178&& (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(ctl)))179ledpriv->LedControlHandler(adapter, ctl);180}181}182183void rtw_led_tx_control(_adapter *adapter, const u8 *da)184{185#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY186if (IS_MCAST(da))187rtw_led_control(adapter, LED_CTL_BMC_TX);188else189rtw_led_control(adapter, LED_CTL_UC_TX);190#else191rtw_led_control(adapter, LED_CTL_TX);192#endif193}194195void rtw_led_rx_control(_adapter *adapter, const u8 *da)196{197#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY198if (IS_MCAST(da))199rtw_led_control(adapter, LED_CTL_BMC_RX);200else201rtw_led_control(adapter, LED_CTL_UC_RX);202#else203rtw_led_control(adapter, LED_CTL_RX);204#endif205}206207void rtw_led_set_iface_en(_adapter *adapter, u8 en)208{209struct led_priv *ledpriv = adapter_to_led(adapter);210211if (en)212ledpriv->iface_en_mask |= BIT(adapter->iface_id);213else214ledpriv->iface_en_mask &= ~BIT(adapter->iface_id);215}216217void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask)218{219struct led_priv *ledpriv = adapter_to_led(adapter);220221ledpriv->iface_en_mask = mask;222}223224void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask)225{226struct led_priv *ledpriv = adapter_to_led(adapter);227228#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY229if (ctl_mask & BIT(LED_CTL_TX))230ctl_mask |= BIT(LED_CTL_UC_TX) | BIT(LED_CTL_BMC_TX);231if (ctl_mask & BIT(LED_CTL_RX))232ctl_mask |= BIT(LED_CTL_UC_RX) | BIT(LED_CTL_BMC_RX);233#endif234235ledpriv->ctl_en_mask[adapter->iface_id] = ctl_mask;236}237238void rtw_led_set_ctl_en_mask_primary(_adapter *adapter)239{240rtw_led_set_ctl_en_mask(adapter, 0xFFFFFFFF);241}242243void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter)244{245rtw_led_set_ctl_en_mask(adapter246, BIT(LED_CTL_POWER_ON) | BIT(LED_CTL_POWER_OFF)247| BIT(LED_CTL_TX) | BIT(LED_CTL_RX)248);249}250#endif /* CONFIG_RTW_SW_LED */251252#endif /* CONFIG_RTW_LED */253254255256