162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* Copyright(c) 2009-2014 Realtek Corporation.*/ 362306a36Sopenharmony_ci 462306a36Sopenharmony_ci#include "../wifi.h" 562306a36Sopenharmony_ci#include "../pci.h" 662306a36Sopenharmony_ci#include "reg.h" 762306a36Sopenharmony_ci#include "led.h" 862306a36Sopenharmony_ci 962306a36Sopenharmony_civoid rtl92ee_sw_led_on(struct ieee80211_hw *hw, enum rtl_led_pin pin) 1062306a36Sopenharmony_ci{ 1162306a36Sopenharmony_ci u32 ledcfg; 1262306a36Sopenharmony_ci struct rtl_priv *rtlpriv = rtl_priv(hw); 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci rtl_dbg(rtlpriv, COMP_LED, DBG_LOUD, 1562306a36Sopenharmony_ci "LedAddr:%X ledpin=%d\n", REG_LEDCFG2, pin); 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci switch (pin) { 1862306a36Sopenharmony_ci case LED_PIN_GPIO0: 1962306a36Sopenharmony_ci break; 2062306a36Sopenharmony_ci case LED_PIN_LED0: 2162306a36Sopenharmony_ci ledcfg = rtl_read_dword(rtlpriv , REG_GPIO_PIN_CTRL); 2262306a36Sopenharmony_ci ledcfg &= ~BIT(13); 2362306a36Sopenharmony_ci ledcfg |= BIT(21); 2462306a36Sopenharmony_ci ledcfg &= ~BIT(29); 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci rtl_write_dword(rtlpriv, REG_GPIO_PIN_CTRL, ledcfg); 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci break; 2962306a36Sopenharmony_ci case LED_PIN_LED1: 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci break; 3262306a36Sopenharmony_ci default: 3362306a36Sopenharmony_ci rtl_dbg(rtlpriv, COMP_ERR, DBG_LOUD, 3462306a36Sopenharmony_ci "switch case %#x not processed\n", pin); 3562306a36Sopenharmony_ci break; 3662306a36Sopenharmony_ci } 3762306a36Sopenharmony_ci} 3862306a36Sopenharmony_ci 3962306a36Sopenharmony_civoid rtl92ee_sw_led_off(struct ieee80211_hw *hw, enum rtl_led_pin pin) 4062306a36Sopenharmony_ci{ 4162306a36Sopenharmony_ci struct rtl_priv *rtlpriv = rtl_priv(hw); 4262306a36Sopenharmony_ci u32 ledcfg; 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci rtl_dbg(rtlpriv, COMP_LED, DBG_LOUD, 4562306a36Sopenharmony_ci "LedAddr:%X ledpin=%d\n", REG_LEDCFG2, pin); 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_ci switch (pin) { 4862306a36Sopenharmony_ci case LED_PIN_GPIO0: 4962306a36Sopenharmony_ci break; 5062306a36Sopenharmony_ci case LED_PIN_LED0: 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci ledcfg = rtl_read_dword(rtlpriv , REG_GPIO_PIN_CTRL); 5362306a36Sopenharmony_ci ledcfg |= ~BIT(21); 5462306a36Sopenharmony_ci ledcfg &= ~BIT(29); 5562306a36Sopenharmony_ci rtl_write_dword(rtlpriv, REG_GPIO_PIN_CTRL, ledcfg); 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci break; 5862306a36Sopenharmony_ci case LED_PIN_LED1: 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_ci break; 6162306a36Sopenharmony_ci default: 6262306a36Sopenharmony_ci rtl_dbg(rtlpriv, COMP_ERR, DBG_LOUD, 6362306a36Sopenharmony_ci "switch case %#x not processed\n", pin); 6462306a36Sopenharmony_ci break; 6562306a36Sopenharmony_ci } 6662306a36Sopenharmony_ci} 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_cistatic void _rtl92ee_sw_led_control(struct ieee80211_hw *hw, 6962306a36Sopenharmony_ci enum led_ctl_mode ledaction) 7062306a36Sopenharmony_ci{ 7162306a36Sopenharmony_ci struct rtl_priv *rtlpriv = rtl_priv(hw); 7262306a36Sopenharmony_ci enum rtl_led_pin pin0 = rtlpriv->ledctl.sw_led0; 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci switch (ledaction) { 7562306a36Sopenharmony_ci case LED_CTL_POWER_ON: 7662306a36Sopenharmony_ci case LED_CTL_LINK: 7762306a36Sopenharmony_ci case LED_CTL_NO_LINK: 7862306a36Sopenharmony_ci rtl92ee_sw_led_on(hw, pin0); 7962306a36Sopenharmony_ci break; 8062306a36Sopenharmony_ci case LED_CTL_POWER_OFF: 8162306a36Sopenharmony_ci rtl92ee_sw_led_off(hw, pin0); 8262306a36Sopenharmony_ci break; 8362306a36Sopenharmony_ci default: 8462306a36Sopenharmony_ci break; 8562306a36Sopenharmony_ci } 8662306a36Sopenharmony_ci} 8762306a36Sopenharmony_ci 8862306a36Sopenharmony_civoid rtl92ee_led_control(struct ieee80211_hw *hw, enum led_ctl_mode ledaction) 8962306a36Sopenharmony_ci{ 9062306a36Sopenharmony_ci struct rtl_priv *rtlpriv = rtl_priv(hw); 9162306a36Sopenharmony_ci struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); 9262306a36Sopenharmony_ci 9362306a36Sopenharmony_ci if ((ppsc->rfoff_reason > RF_CHANGE_BY_PS) && 9462306a36Sopenharmony_ci (ledaction == LED_CTL_TX || 9562306a36Sopenharmony_ci ledaction == LED_CTL_RX || 9662306a36Sopenharmony_ci ledaction == LED_CTL_SITE_SURVEY || 9762306a36Sopenharmony_ci ledaction == LED_CTL_LINK || 9862306a36Sopenharmony_ci ledaction == LED_CTL_NO_LINK || 9962306a36Sopenharmony_ci ledaction == LED_CTL_START_TO_LINK || 10062306a36Sopenharmony_ci ledaction == LED_CTL_POWER_ON)) { 10162306a36Sopenharmony_ci return; 10262306a36Sopenharmony_ci } 10362306a36Sopenharmony_ci rtl_dbg(rtlpriv, COMP_LED, DBG_TRACE, "ledaction %d,\n", ledaction); 10462306a36Sopenharmony_ci _rtl92ee_sw_led_control(hw, ledaction); 10562306a36Sopenharmony_ci} 106