forked from ~ljy/RK356X_SDK_RELEASE

hc
2023-12-06 d38611ca164021d018c1b23eee65bbebc09c63e0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
/* SPDX-License-Identifier: GPL-2.0 */
/******************************************************************************
 *
 * Copyright(c) 2012 - 2017 Realtek Corporation.
 *
 * 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.
 *
 *****************************************************************************/
#ifndef __RTL8192E_CMD_H__
#define __RTL8192E_CMD_H__
 
typedef enum _RTL8192E_H2C_CMD {
   H2C_8192E_RSVDPAGE    = 0x00,
   H2C_8192E_MSRRPT    = 0x01,
   H2C_8192E_SCAN        = 0x02,
   H2C_8192E_KEEP_ALIVE_CTRL = 0x03,
   H2C_8192E_DISCONNECT_DECISION = 0x04,
   H2C_8192E_INIT_OFFLOAD = 0x06,
   H2C_8192E_AP_OFFLOAD = 0x08,
   H2C_8192E_BCN_RSVDPAGE = 0x09,
   H2C_8192E_PROBERSP_RSVDPAGE = 0x0a,
 
   H2C_8192E_AP_WOW_GPIO_CTRL = 0x13,
 
   H2C_8192E_SETPWRMODE = 0x20,
   H2C_8192E_PS_TUNING_PARA = 0x21,
   H2C_8192E_PS_TUNING_PARA2 = 0x22,
   H2C_8192E_PS_LPS_PARA = 0x23,
   H2C_8192E_P2P_PS_OFFLOAD = 0x24,
   H2C_8192E_SAP_PS = 0x26,
   H2C_8192E_RA_MASK = 0x40,
   H2C_8192E_RSSI_REPORT = 0x42,
   H2C_8192E_RA_PARA_ADJUST = 0x46,
 
   H2C_8192E_WO_WLAN = 0x80,
   H2C_8192E_REMOTE_WAKE_CTRL = 0x81,
   H2C_8192E_AOAC_GLOBAL_INFO = 0x82,
   H2C_8192E_AOAC_RSVDPAGE = 0x83,
 
   /* Not defined in new 88E H2C CMD Format */
   H2C_8192E_SELECTIVE_SUSPEND_ROF_CMD,
   H2C_8192E_P2P_PS_MODE,
   H2C_8192E_PSD_RESULT,
   MAX_8192E_H2CCMD
} RTL8192E_H2C_CMD;
 
struct cmd_msg_parm {
   u8 eid; /* element id */
   u8 sz; /* sz */
   u8 buf[6];
};
 
enum {
   PWRS
};
 
typedef struct _SETPWRMODE_PARM {
   u8 Mode;/* 0:Active,1:LPS,2:WMMPS */
   /* u8 RLBM:4; */ /* 0:Min,1:Max,2: User define */
   u8 SmartPS_RLBM;/* LPS=0:PS_Poll,1:PS_Poll,2:NullData,WMM=0:PS_Poll,1:NullData */
   u8 AwakeInterval;    /* unit: beacon interval */
   u8 bAllQueueUAPSD;
   u8 PwrState;/* AllON(0x0c),RFON(0x04),RFOFF(0x00) */
} SETPWRMODE_PARM, *PSETPWRMODE_PARM;
 
struct H2C_SS_RFOFF_PARAM {
   u8 ROFOn; /* 1: on, 0:off */
   u16 gpio_period; /* unit: 1024 us */
} __attribute__((packed));
 
 
typedef struct JOINBSSRPT_PARM_92E {
   u8 OpMode;    /* RT_MEDIA_STATUS */
#ifdef CONFIG_WOWLAN
   u8 MacID;       /* MACID */
#endif /* CONFIG_WOWLAN */
} JOINBSSRPT_PARM_92E, *PJOINBSSRPT_PARM_92E;
 
/* move to hal_com_h2c.h
typedef struct _RSVDPAGE_LOC_92E {
   u8 LocProbeRsp;
   u8 LocPsPoll;
   u8 LocNullData;
   u8 LocQosNull;
   u8 LocBTQosNull;
} RSVDPAGE_LOC_92E, *PRSVDPAGE_LOC_92E;
*/
 
 
/* _SETPWRMODE_PARM */
#define SET_8192E_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value)                SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
#define SET_8192E_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value)                SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
#define SET_8192E_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
#define SET_8192E_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
#define SET_8192E_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
#define SET_8192E_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value)    SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
#define SET_8192E_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
#define GET_8192E_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd)                        LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
 
/* _P2P_PS_OFFLOAD */
#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ENABLE(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ROLE(__pH2CCmd, __Value)                SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_CTWINDOW_EN(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_NOA0_EN(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_NOA1_EN(__pH2CCmd, __Value)            SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
#define SET_8192E_H2CCMD_P2P_PS_OFFLOAD_ALLSTASLEEP(__pH2CCmd, __Value)        SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
 
 
/* host message to firmware cmd */
void rtl8192e_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
void rtl8192e_set_FwJoinBssReport_cmd(PADAPTER padapter, u8 mstatus);
s32 FillH2CCmd_8192E(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
u8 GetTxBufferRsvdPageNum8192E(_adapter *padapter, bool wowlan);
/* u8 rtl8192c_set_FwSelectSuspend_cmd(PADAPTER padapter, u8 bfwpoll, u16 period); */
s32 c2h_handler_8192e(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
#ifdef CONFIG_BT_COEXIST
   void rtl8192e_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
#endif /* CONFIG_BT_COEXIST */
#ifdef CONFIG_P2P_PS
   void rtl8192e_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
#endif /* CONFIG_P2P */
 
#ifdef CONFIG_TDLS
   #ifdef CONFIG_TDLS_CH_SW
       void rtl8192e_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
   #endif
#endif
 
/* / TX Feedback Content */
#define    USEC_UNIT_FOR_8192E_C2H_TX_RPT_QUEUE_TIME            256
 
#define    GET_8192E_C2H_TX_RPT_QUEUE_SELECT(_Header)            LE_BITS_TO_1BYTE((_Header + 0), 0, 5)
#define    GET_8192E_C2H_TX_RPT_PKT_BROCAST(_Header)            LE_BITS_TO_1BYTE((_Header + 0), 5, 1)
#define    GET_8192E_C2H_TX_RPT_LIFE_TIME_OVER(_Header)            LE_BITS_TO_1BYTE((_Header + 0), 6, 1)
#define    GET_8192E_C2H_TX_RPT_RETRY_OVER(_Header)                LE_BITS_TO_1BYTE((_Header + 0), 7, 1)
#define    GET_8192E_C2H_TX_RPT_MAC_ID(_Header)                    LE_BITS_TO_1BYTE((_Header + 1), 0, 8)
#define    GET_8192E_C2H_TX_RPT_DATA_RETRY_CNT(_Header)        LE_BITS_TO_1BYTE((_Header + 2), 0, 6)
#define    GET_8192E_C2H_TX_RPT_QUEUE_TIME(_Header)                LE_BITS_TO_2BYTE((_Header + 3), 0, 16)    /* In unit of 256 microseconds. */
#define    GET_8192E_C2H_TX_RPT_FINAL_DATA_RATE(_Header)        LE_BITS_TO_1BYTE((_Header + 5), 0, 8)
 
#endif /* __RTL8192E_CMD_H__ */