linux/drivers/net/wireless/realtek/rtlwifi/rtl8192ee/pwrseq.h

/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright(c) 2009-2014  Realtek Corporation.*/

#ifndef __RTL92E_PWRSEQ_H__
#define __RTL92E_PWRSEQ_H__

#include "../pwrseqcmd.h"
/**
 *	Check document WM-20110607-Paul-RTL8192E_Power_Architecture-R02.vsd
 *	There are 6 HW Power States:
 *	0: POFF--Power Off
 *	1: PDN--Power Down
 *	2: CARDEMU--Card Emulation
 *	3: ACT--Active Mode
 *	4: LPS--Low Power State
 *	5: SUS--Suspend
 *
 *	The transision from different states are defined below
 *	TRANS_CARDEMU_TO_ACT
 *	TRANS_ACT_TO_CARDEMU
 *	TRANS_CARDEMU_TO_SUS
 *	TRANS_SUS_TO_CARDEMU
 *	TRANS_CARDEMU_TO_PDN
 *	TRANS_ACT_TO_LPS
 *	TRANS_LPS_TO_ACT
 *
 *	TRANS_END
 *	PWR SEQ Version: rtl8192E_PwrSeq_V09.h
 */

#define RTL8192E_TRANS_CARDEMU_TO_ACT_STEPS
#define RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS
#define RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS
#define RTL8192E_TRANS_SUS_TO_CARDEMU_STEPS
#define RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS
#define RTL8192E_TRANS_PDN_TO_CARDEMU_STEPS
#define RTL8192E_TRANS_ACT_TO_LPS_STEPS
#define RTL8192E_TRANS_LPS_TO_ACT_STEPS
#define RTL8192E_TRANS_END_STEPS

#define RTL8192E_TRANS_CARDEMU_TO_ACT

#define RTL8192E_TRANS_ACT_TO_CARDEMU

#define RTL8192E_TRANS_CARDEMU_TO_SUS

#define RTL8192E_TRANS_SUS_TO_CARDEMU

#define RTL8192E_TRANS_CARDEMU_TO_CARDDIS

#define RTL8192E_TRANS_CARDDIS_TO_CARDEMU

#define RTL8192E_TRANS_CARDEMU_TO_PDN

#define RTL8192E_TRANS_PDN_TO_CARDEMU

#define RTL8192E_TRANS_ACT_TO_LPS

#define RTL8192E_TRANS_LPS_TO_ACT

#define RTL8192E_TRANS_END

extern struct wlan_pwr_cfg rtl8192E_power_on_flow
					[RTL8192E_TRANS_CARDEMU_TO_ACT_STEPS +
					 RTL8192E_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8192E_radio_off_flow
					[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS +
					 RTL8192E_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8192E_card_disable_flow
					[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS +
					 RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS +
					 RTL8192E_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8192E_card_enable_flow
					[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS +
					 RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS +
					 RTL8192E_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8192E_suspend_flow
					[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS +
					 RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS +
					 RTL8192E_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8192E_resume_flow
					[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS +
					 RTL8192E_TRANS_CARDEMU_TO_SUS_STEPS +
					 RTL8192E_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8192E_hwpdn_flow
					[RTL8192E_TRANS_ACT_TO_CARDEMU_STEPS +
					 RTL8192E_TRANS_CARDEMU_TO_PDN_STEPS +
					 RTL8192E_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8192E_enter_lps_flow
					[RTL8192E_TRANS_ACT_TO_LPS_STEPS +
					 RTL8192E_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8192E_leave_lps_flow
					[RTL8192E_TRANS_LPS_TO_ACT_STEPS +
					 RTL8192E_TRANS_END_STEPS];

/* RTL8192EE Power Configuration CMDs for PCIe interface */
#define RTL8192E_NIC_PWR_ON_FLOW
#define RTL8192E_NIC_RF_OFF_FLOW
#define RTL8192E_NIC_DISABLE_FLOW
#define RTL8192E_NIC_ENABLE_FLOW
#define RTL8192E_NIC_SUSPEND_FLOW
#define RTL8192E_NIC_RESUME_FLOW
#define RTL8192E_NIC_PDN_FLOW
#define RTL8192E_NIC_LPS_ENTER_FLOW
#define RTL8192E_NIC_LPS_LEAVE_FLOW

#endif