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

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

#ifndef __RTL8723E_PWRSEQ_H__
#define __RTL8723E_PWRSEQ_H__

#include "../pwrseqcmd.h"
/* Check document WM-20110607-Paul-RTL8188EE_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: rtl8188ee_PwrSeq_V09.h
 */

#define RTL8188EE_TRANS_CARDEMU_TO_ACT_STEPS
#define RTL8188EE_TRANS_ACT_TO_CARDEMU_STEPS
#define RTL8188EE_TRANS_CARDEMU_TO_SUS_STEPS
#define RTL8188EE_TRANS_SUS_TO_CARDEMU_STEPS
#define RTL8188EE_TRANS_CARDEMU_TO_PDN_STEPS
#define RTL8188EE_TRANS_PDN_TO_CARDEMU_STEPS
#define RTL8188EE_TRANS_ACT_TO_LPS_STEPS
#define RTL8188EE_TRANS_LPS_TO_ACT_STEPS
#define RTL8188EE_TRANS_END_STEPS

/* The following macros have the following format:
 * { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value
 *   comments },
 */
#define RTL8188EE_TRANS_CARDEMU_TO_ACT

#define RTL8188EE_TRANS_ACT_TO_CARDEMU

#define RTL8188EE_TRANS_CARDEMU_TO_SUS

#define RTL8188EE_TRANS_SUS_TO_CARDEMU

#define RTL8188EE_TRANS_CARDEMU_TO_CARDDIS

#define RTL8188EE_TRANS_CARDDIS_TO_CARDEMU

#define RTL8188EE_TRANS_CARDEMU_TO_PDN

#define RTL8188EE_TRANS_PDN_TO_CARDEMU

#define RTL8188EE_TRANS_ACT_TO_LPS


#define RTL8188EE_TRANS_LPS_TO_ACT

#define RTL8188EE_TRANS_END

extern struct wlan_pwr_cfg rtl8188ee_power_on_flow
		[RTL8188EE_TRANS_CARDEMU_TO_ACT_STEPS +
		 RTL8188EE_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8188ee_radio_off_flow
		[RTL8188EE_TRANS_ACT_TO_CARDEMU_STEPS +
		 RTL8188EE_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8188ee_card_disable_flow
		[RTL8188EE_TRANS_ACT_TO_CARDEMU_STEPS +
		 RTL8188EE_TRANS_CARDEMU_TO_PDN_STEPS +
		 RTL8188EE_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8188ee_card_enable_flow
		[RTL8188EE_TRANS_ACT_TO_CARDEMU_STEPS +
		 RTL8188EE_TRANS_CARDEMU_TO_PDN_STEPS +
		 RTL8188EE_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8188ee_suspend_flow
		[RTL8188EE_TRANS_ACT_TO_CARDEMU_STEPS +
		 RTL8188EE_TRANS_CARDEMU_TO_SUS_STEPS +
		 RTL8188EE_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8188ee_resume_flow
		[RTL8188EE_TRANS_ACT_TO_CARDEMU_STEPS +
		 RTL8188EE_TRANS_CARDEMU_TO_SUS_STEPS +
		 RTL8188EE_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8188ee_hwpdn_flow
		[RTL8188EE_TRANS_ACT_TO_CARDEMU_STEPS +
		 RTL8188EE_TRANS_CARDEMU_TO_PDN_STEPS +
		 RTL8188EE_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8188ee_enter_lps_flow
		[RTL8188EE_TRANS_ACT_TO_LPS_STEPS +
		 RTL8188EE_TRANS_END_STEPS];
extern struct wlan_pwr_cfg rtl8188ee_leave_lps_flow
		[RTL8188EE_TRANS_LPS_TO_ACT_STEPS +
		 RTL8188EE_TRANS_END_STEPS];

/* RTL8723 Power Configuration CMDs for PCIe interface */
#define RTL8188EE_NIC_PWR_ON_FLOW
#define RTL8188EE_NIC_RF_OFF_FLOW
#define RTL8188EE_NIC_DISABLE_FLOW
#define RTL8188EE_NIC_ENABLE_FLOW
#define RTL8188EE_NIC_SUSPEND_FLOW
#define RTL8188EE_NIC_RESUME_FLOW
#define RTL8188EE_NIC_PDN_FLOW
#define RTL8188EE_NIC_LPS_ENTER_FLOW
#define RTL8188EE_NIC_LPS_LEAVE_FLOW

#endif