/****************************************************************************** * * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms of version 2 of the GNU General Public License as * published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along with * this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA * * ******************************************************************************/ #ifndef __RTW_LED_H_ #define __RTW_LED_H_ #include #include #include #define MSECS(t) (HZ * ((t) / 1000) + (HZ * ((t) % 1000)) / 1000) typedef enum _LED_CTL_MODE{ LED_CTL_POWER_ON = 1, LED_CTL_LINK = 2, LED_CTL_NO_LINK = 3, LED_CTL_TX = 4, LED_CTL_RX = 5, LED_CTL_SITE_SURVEY = 6, LED_CTL_POWER_OFF = 7, LED_CTL_START_TO_LINK = 8, LED_CTL_START_WPS = 9, LED_CTL_STOP_WPS = 10, LED_CTL_START_WPS_BOTTON = 11, //added for runtop LED_CTL_STOP_WPS_FAIL = 12, //added for ALPHA LED_CTL_STOP_WPS_FAIL_OVERLAP = 13, //added for BELKIN }LED_CTL_MODE; #if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) //================================================================================ // LED object. //================================================================================ typedef enum _LED_STATE_871x{ LED_UNKNOWN = 0, RTW_LED_ON = 1, RTW_LED_OFF = 2, LED_BLINK_NORMAL = 3, LED_BLINK_SLOWLY = 4, LED_POWER_ON_BLINK = 5, LED_SCAN_BLINK = 6, // LED is blinking during scanning period, the # of times to blink is depend on time for scanning. LED_NO_LINK_BLINK = 7, // LED is blinking during no link state. LED_BLINK_StartToBlink = 8,// Customzied for Sercomm Printer Server case LED_BLINK_WPS = 9, // LED is blinkg during WPS communication LED_TXRX_BLINK = 10, LED_BLINK_WPS_STOP = 11, //for ALPHA LED_BLINK_WPS_STOP_OVERLAP = 12, //for BELKIN }LED_STATE_871x; #define IS_LED_WPS_BLINKING(_LED_871x) (((PLED_871x)_LED_871x)->CurrLedState==LED_BLINK_WPS \ || ((PLED_871x)_LED_871x)->CurrLedState==LED_BLINK_WPS_STOP \ || ((PLED_871x)_LED_871x)->bLedWPSBlinkInProgress) #define IS_LED_BLINKING(_LED_871x) (((PLED_871x)_LED_871x)->bLedWPSBlinkInProgress \ ||((PLED_871x)_LED_871x)->bLedScanBlinkInProgress) typedef enum _LED_PIN_871x{ LED_PIN_GPIO0, LED_PIN_LED0, LED_PIN_LED1 }LED_PIN_871x; typedef struct _LED_871x{ _adapter *padapter; LED_PIN_871x LedPin; // Identify how to implement this SW led. LED_STATE_871x CurrLedState; // Current LED state. u8 bLedOn; // true if LED is ON, false if LED is OFF. u8 bSWLedCtrl; u8 bLedBlinkInProgress; // true if it is blinking, false o.w.. // ALPHA, added by chiyoko, 20090106 u8 bLedNoLinkBlinkInProgress; u8 bLedLinkBlinkInProgress; u8 bLedStartToLinkBlinkInProgress; u8 bLedScanBlinkInProgress; u8 bLedWPSBlinkInProgress; u32 BlinkTimes; // Number of times to toggle led state for blinking. LED_STATE_871x BlinkingLedState; // Next state for blinking, either RTW_LED_ON or RTW_LED_OFF are. _timer BlinkTimer; // Timer object for led blinking. #if LINUX_VERSION_CODE > KERNEL_VERSION(2,5,0)|| defined PLATFORM_FREEBSD _workitem BlinkWorkItem; // Workitem used by BlinkTimer to manipulate H/W to blink LED. #endif } LED_871x, *PLED_871x; //================================================================================ // LED customization. //================================================================================ typedef enum _LED_STRATEGY_871x{ SW_LED_MODE0, // SW control 1 LED via GPIO0. It is default option. SW_LED_MODE1, // 2 LEDs, through LED0 and LED1. For ALPHA. SW_LED_MODE2, // SW control 1 LED via GPIO0, customized for AzWave 8187 minicard. SW_LED_MODE3, // SW control 1 LED via GPIO0, customized for Sercomm Printer Server case. SW_LED_MODE4, //for Edimax / Belkin SW_LED_MODE5, //for Sercomm / Belkin SW_LED_MODE6, //for 88CU minicard, porting from ce SW_LED_MODE7 HW_LED, // HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes, see MAC.CONFIG1 for details.) }LED_STRATEGY_871x, *PLED_STRATEGY_871x; #endif //CONFIG_USB_HCI #ifdef CONFIG_PCI_HCI //================================================================================ // LED object. //================================================================================ typedef enum _LED_STATE_871x{ LED_UNKNOWN = 0, RTW_LED_ON = 1, RTW_LED_OFF = 2, LED_BLINK_NORMAL = 3, LED_BLINK_SLOWLY = 4, LED_POWER_ON_BLINK = 5, LED_SCAN_BLINK = 6, // LED is blinking during scanning period, the # of times to blink is depend on time for scanning. LED_NO_LINK_BLINK = 7, // LED is blinking during no link state. LED_BLINK_StartToBlink = 8, LED_BLINK_TXRX = 9, LED_BLINK_RUNTOP = 10, // Customized for RunTop LED_BLINK_CAMEO = 11, }LED_STATE_871x; typedef enum _LED_PIN_871x{ LED_PIN_GPIO0, LED_PIN_LED0, LED_PIN_LED1, LED_PIN_LED2 }LED_PIN_871x; typedef struct _LED_871x{ _adapter *padapter; LED_PIN_871x LedPin; // Identify how to implement this SW led. LED_STATE_871x CurrLedState; // Current LED state. u8 bLedOn; // TRUE if LED is ON, FALSE if LED is OFF. u8 bLedBlinkInProgress; // TRUE if it is blinking, FALSE o.w.. u8 bLedWPSBlinkInProgress; // TRUE if it is blinking, FALSE o.w.. u8 bLedSlowBlinkInProgress;//added by vivi, for led new mode u32 BlinkTimes; // Number of times to toggle led state for blinking. LED_STATE_871x BlinkingLedState; // Next state for blinking, either RTW_LED_ON or RTW_LED_OFF are. _timer BlinkTimer; // Timer object for led blinking. } LED_871x, *PLED_871x; //================================================================================ // LED customization. //================================================================================ typedef enum _LED_STRATEGY_871x{ SW_LED_MODE0, // SW control 1 LED via GPIO0. It is default option. SW_LED_MODE1, // SW control for PCI Express SW_LED_MODE2, // SW control for Cameo. SW_LED_MODE3, // SW contorl for RunTop. SW_LED_MODE4, // SW control for Netcore SW_LED_MODE5, //added by vivi, for led new mode, DLINK SW_LED_MODE6, //added by vivi, for led new mode, PRONET SW_LED_MODE7, //added by chiyokolin, for Lenovo, PCI Express Minicard Spec Rev.1.2 spec SW_LED_MODE8, //added by chiyokolin, for QMI SW_LED_MODE9, //added by chiyokolin, for BITLAND, PCI Express Minicard Spec Rev.1.1 SW_LED_MODE10, //added by chiyokolin, for Edimax-ASUS HW_LED, // HW control 2 LEDs, LED0 and LED1 (there are 4 different control modes) }LED_STRATEGY_871x, *PLED_STRATEGY_871x; #define LED_CM8_BLINK_INTERVAL 500 //for QMI #endif //CONFIG_PCI_HCI struct led_priv{ /* add for led controll */ LED_871x SwLed0; LED_871x SwLed1; LED_STRATEGY_871x LedStrategy; u8 bRegUseLed; void (*LedControlHandler)(_adapter *padapter, LED_CTL_MODE LedAction); /* add for led controll */ }; #ifdef CONFIG_SW_LED #define rtw_led_control(adapter, LedAction) \ do { \ if((adapter)->ledpriv.LedControlHandler) \ (adapter)->ledpriv.LedControlHandler((adapter), (LedAction)); \ } while(0) #else //CONFIG_SW_LED #define rtw_led_control(adapter, LedAction) #endif //CONFIG_SW_LED extern void BlinkHandler(PLED_871x pLed); #endif //__RTW_LED_H_