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
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
/******************************************************************************
 *
 * 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 __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 SET_8192E_H2CCMD_PWRMODE_PARM_BYTE5(__pH2CCmd, __Value)                SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 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);
u8 rtl8192e_set_rssi_cmd(PADAPTER padapter, u8 *param);
void rtl8192e_set_raid_cmd(PADAPTER padapter, u32 bitmap, u8* arg);
void rtl8192e_Add_RateATid(PADAPTER padapter, u64 rate_bitmap, u8 *arg, u8 rssi_level);
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(PADAPTER padapter, u8 *buf);
#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
 
void CheckFwRsvdPageContent(PADAPTER padapter);
 
#ifdef CONFIG_TDLS
#ifdef CONFIG_TDLS_CH_SW
void rtl8192e_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
#endif
#endif
 
#ifdef CONFIG_TSF_RESET_OFFLOAD
int reset_tsf(PADAPTER Adapter, u8 reset_port );
#endif    // CONFIG_TSF_RESET_OFFLOAD
 
/// 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)
 
 
 
void C2HContentParsing8192E(
   IN    PADAPTER        Adapter,
   IN    u1Byte            c2hCmdId, 
   IN    u1Byte            c2hCmdLen,
   IN    pu1Byte             tmpBuf
);
VOID
C2HPacketHandler_8192E(
   IN    PADAPTER        Adapter,
   IN    pu1Byte            Buffer,
   IN    u1Byte            Length
);
 
#endif//__RTL8192E_CMD_H__