162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* Copyright(c) 2009-2012 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 rtl92se_sw_led_on(struct ieee80211_hw *hw, enum rtl_led_pin pin) 1062306a36Sopenharmony_ci{ 1162306a36Sopenharmony_ci u8 ledcfg; 1262306a36Sopenharmony_ci struct rtl_priv *rtlpriv = rtl_priv(hw); 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci rtl_dbg(rtlpriv, COMP_LED, DBG_LOUD, "LedAddr:%X ledpin=%d\n", 1562306a36Sopenharmony_ci LEDCFG, pin); 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci ledcfg = rtl_read_byte(rtlpriv, LEDCFG); 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci switch (pin) { 2062306a36Sopenharmony_ci case LED_PIN_GPIO0: 2162306a36Sopenharmony_ci break; 2262306a36Sopenharmony_ci case LED_PIN_LED0: 2362306a36Sopenharmony_ci rtl_write_byte(rtlpriv, LEDCFG, ledcfg & 0xf0); 2462306a36Sopenharmony_ci break; 2562306a36Sopenharmony_ci case LED_PIN_LED1: 2662306a36Sopenharmony_ci rtl_write_byte(rtlpriv, LEDCFG, ledcfg & 0x0f); 2762306a36Sopenharmony_ci break; 2862306a36Sopenharmony_ci default: 2962306a36Sopenharmony_ci pr_err("switch case %#x not processed\n", pin); 3062306a36Sopenharmony_ci break; 3162306a36Sopenharmony_ci } 3262306a36Sopenharmony_ci} 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_civoid rtl92se_sw_led_off(struct ieee80211_hw *hw, enum rtl_led_pin pin) 3562306a36Sopenharmony_ci{ 3662306a36Sopenharmony_ci struct rtl_priv *rtlpriv; 3762306a36Sopenharmony_ci u8 ledcfg; 3862306a36Sopenharmony_ci 3962306a36Sopenharmony_ci rtlpriv = rtl_priv(hw); 4062306a36Sopenharmony_ci if (!rtlpriv || rtlpriv->max_fw_size) 4162306a36Sopenharmony_ci return; 4262306a36Sopenharmony_ci rtl_dbg(rtlpriv, COMP_LED, DBG_LOUD, "LedAddr:%X ledpin=%d\n", 4362306a36Sopenharmony_ci LEDCFG, pin); 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci ledcfg = rtl_read_byte(rtlpriv, LEDCFG); 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_ci switch (pin) { 4862306a36Sopenharmony_ci case LED_PIN_GPIO0: 4962306a36Sopenharmony_ci break; 5062306a36Sopenharmony_ci case LED_PIN_LED0: 5162306a36Sopenharmony_ci ledcfg &= 0xf0; 5262306a36Sopenharmony_ci if (rtlpriv->ledctl.led_opendrain) 5362306a36Sopenharmony_ci rtl_write_byte(rtlpriv, LEDCFG, (ledcfg | BIT(1))); 5462306a36Sopenharmony_ci else 5562306a36Sopenharmony_ci rtl_write_byte(rtlpriv, LEDCFG, (ledcfg | BIT(3))); 5662306a36Sopenharmony_ci break; 5762306a36Sopenharmony_ci case LED_PIN_LED1: 5862306a36Sopenharmony_ci ledcfg &= 0x0f; 5962306a36Sopenharmony_ci rtl_write_byte(rtlpriv, LEDCFG, (ledcfg | BIT(3))); 6062306a36Sopenharmony_ci break; 6162306a36Sopenharmony_ci default: 6262306a36Sopenharmony_ci pr_err("switch case %#x not processed\n", pin); 6362306a36Sopenharmony_ci break; 6462306a36Sopenharmony_ci } 6562306a36Sopenharmony_ci} 6662306a36Sopenharmony_ci 6762306a36Sopenharmony_cistatic void _rtl92se_sw_led_control(struct ieee80211_hw *hw, 6862306a36Sopenharmony_ci enum led_ctl_mode ledaction) 6962306a36Sopenharmony_ci{ 7062306a36Sopenharmony_ci struct rtl_priv *rtlpriv = rtl_priv(hw); 7162306a36Sopenharmony_ci enum rtl_led_pin pin0 = rtlpriv->ledctl.sw_led0; 7262306a36Sopenharmony_ci 7362306a36Sopenharmony_ci switch (ledaction) { 7462306a36Sopenharmony_ci case LED_CTL_POWER_ON: 7562306a36Sopenharmony_ci case LED_CTL_LINK: 7662306a36Sopenharmony_ci case LED_CTL_NO_LINK: 7762306a36Sopenharmony_ci rtl92se_sw_led_on(hw, pin0); 7862306a36Sopenharmony_ci break; 7962306a36Sopenharmony_ci case LED_CTL_POWER_OFF: 8062306a36Sopenharmony_ci rtl92se_sw_led_off(hw, pin0); 8162306a36Sopenharmony_ci break; 8262306a36Sopenharmony_ci default: 8362306a36Sopenharmony_ci break; 8462306a36Sopenharmony_ci } 8562306a36Sopenharmony_ci} 8662306a36Sopenharmony_ci 8762306a36Sopenharmony_civoid rtl92se_led_control(struct ieee80211_hw *hw, enum led_ctl_mode ledaction) 8862306a36Sopenharmony_ci{ 8962306a36Sopenharmony_ci struct rtl_priv *rtlpriv = rtl_priv(hw); 9062306a36Sopenharmony_ci struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); 9162306a36Sopenharmony_ci 9262306a36Sopenharmony_ci if ((ppsc->rfoff_reason > RF_CHANGE_BY_PS) && 9362306a36Sopenharmony_ci (ledaction == LED_CTL_TX || 9462306a36Sopenharmony_ci ledaction == LED_CTL_RX || 9562306a36Sopenharmony_ci ledaction == LED_CTL_SITE_SURVEY || 9662306a36Sopenharmony_ci ledaction == LED_CTL_LINK || 9762306a36Sopenharmony_ci ledaction == LED_CTL_NO_LINK || 9862306a36Sopenharmony_ci ledaction == LED_CTL_START_TO_LINK || 9962306a36Sopenharmony_ci ledaction == LED_CTL_POWER_ON)) { 10062306a36Sopenharmony_ci return; 10162306a36Sopenharmony_ci } 10262306a36Sopenharmony_ci rtl_dbg(rtlpriv, COMP_LED, DBG_LOUD, "ledaction %d\n", ledaction); 10362306a36Sopenharmony_ci 10462306a36Sopenharmony_ci _rtl92se_sw_led_control(hw, ledaction); 10562306a36Sopenharmony_ci} 10662306a36Sopenharmony_ci 107