xref: /OK3568_Linux_fs/external/rkwifibt/drivers/rtl8852bs/include/rtw_security.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /******************************************************************************
2*4882a593Smuzhiyun  *
3*4882a593Smuzhiyun  * Copyright(c) 2007 - 2019 Realtek Corporation.
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * This program is free software; you can redistribute it and/or modify it
6*4882a593Smuzhiyun  * under the terms of version 2 of the GNU General Public License as
7*4882a593Smuzhiyun  * published by the Free Software Foundation.
8*4882a593Smuzhiyun  *
9*4882a593Smuzhiyun  * This program is distributed in the hope that it will be useful, but WITHOUT
10*4882a593Smuzhiyun  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11*4882a593Smuzhiyun  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12*4882a593Smuzhiyun  * more details.
13*4882a593Smuzhiyun  *
14*4882a593Smuzhiyun  *****************************************************************************/
15*4882a593Smuzhiyun #ifndef __RTW_SECURITY_H_
16*4882a593Smuzhiyun #define __RTW_SECURITY_H_
17*4882a593Smuzhiyun 
18*4882a593Smuzhiyun enum security_type {
19*4882a593Smuzhiyun 	/* TYPE */
20*4882a593Smuzhiyun 	_NO_PRIVACY_	= 0x00,
21*4882a593Smuzhiyun 	_WEP40_		= 0x01,
22*4882a593Smuzhiyun 	_TKIP_		= 0x02,
23*4882a593Smuzhiyun 	_TKIP_WTMIC_	= 0x03,
24*4882a593Smuzhiyun 	_AES_		= 0x04,
25*4882a593Smuzhiyun 	_WEP104_	= 0x05,
26*4882a593Smuzhiyun 	_SMS4_		= 0x06,
27*4882a593Smuzhiyun 	_GCMP_		= 0x07,
28*4882a593Smuzhiyun 	_SEC_TYPE_MAX_,
29*4882a593Smuzhiyun 
30*4882a593Smuzhiyun 	/* EXT_SECTYPE=1 */
31*4882a593Smuzhiyun 	_SEC_TYPE_256_	= 0x10,
32*4882a593Smuzhiyun 	_CCMP_256_	= (_AES_ | _SEC_TYPE_256_),
33*4882a593Smuzhiyun 	_GCMP_256_	= (_GCMP_ | _SEC_TYPE_256_),
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun #ifdef CONFIG_IEEE80211W
36*4882a593Smuzhiyun 	/* EXT_SECTYPE=0, MGNT=1, GK=0/1, KEYID=00/01 */
37*4882a593Smuzhiyun 	_SEC_TYPE_BIT_	= 0x20,
38*4882a593Smuzhiyun 	_BIP_CMAC_128_	= (_SEC_TYPE_BIT_),
39*4882a593Smuzhiyun 	_BIP_GMAC_128_	= (_SEC_TYPE_BIT_ + 1),
40*4882a593Smuzhiyun 	_BIP_GMAC_256_	= (_SEC_TYPE_BIT_ + 2),
41*4882a593Smuzhiyun 	/* EXT_SECTYPE=1, MGNT=1, GK=1, KEYID=00/01 */
42*4882a593Smuzhiyun 	_BIP_CMAC_256_	= (_SEC_TYPE_BIT_ + 3),
43*4882a593Smuzhiyun 	_BIP_MAX_,
44*4882a593Smuzhiyun #endif
45*4882a593Smuzhiyun };
46*4882a593Smuzhiyun 
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun /* 802.11W use wrong key */
49*4882a593Smuzhiyun #define IEEE80211W_RIGHT_KEY	0x0
50*4882a593Smuzhiyun #define IEEE80211W_WRONG_KEY	0x1
51*4882a593Smuzhiyun #define IEEE80211W_NO_KEY		0x2
52*4882a593Smuzhiyun 
53*4882a593Smuzhiyun #define CCMPH_2_PN(ch)	((ch) & 0x000000000000ffff) \
54*4882a593Smuzhiyun 			| (((ch) & 0xffffffff00000000) >> 16)
55*4882a593Smuzhiyun 
56*4882a593Smuzhiyun #define is_wep_enc(alg) (((alg) == _WEP40_) || ((alg) == _WEP104_))
57*4882a593Smuzhiyun 
58*4882a593Smuzhiyun const char *security_type_str(u8 value);
59*4882a593Smuzhiyun #ifdef CONFIG_IEEE80211W
60*4882a593Smuzhiyun u32 security_type_bip_to_gmcs(enum security_type type);
61*4882a593Smuzhiyun #endif
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun #define _WPA_IE_ID_	0xdd
64*4882a593Smuzhiyun #define _WPA2_IE_ID_	0x30
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun #define RTW_KEK_LEN 16
67*4882a593Smuzhiyun #define RTW_KCK_LEN 16
68*4882a593Smuzhiyun #define RTW_TKIP_MIC_LEN 8
69*4882a593Smuzhiyun #define RTW_REPLAY_CTR_LEN 8
70*4882a593Smuzhiyun /* For CCMP-128 only */
71*4882a593Smuzhiyun #define RTW_PTK_LEN 16
72*4882a593Smuzhiyun /* For BIP-CMAC-128 only */
73*4882a593Smuzhiyun #define RTW_IGTK_LEN 16
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun #define INVALID_SEC_MAC_CAM_ID	0xFF
76*4882a593Smuzhiyun 
77*4882a593Smuzhiyun typedef enum {
78*4882a593Smuzhiyun 	ENCRYP_PROTOCOL_OPENSYS,   /* open system */
79*4882a593Smuzhiyun 	ENCRYP_PROTOCOL_WEP,       /* WEP */
80*4882a593Smuzhiyun 	ENCRYP_PROTOCOL_WPA,       /* WPA */
81*4882a593Smuzhiyun 	ENCRYP_PROTOCOL_RSN,       /* RSN(WPA2/WPA3) */
82*4882a593Smuzhiyun 	ENCRYP_PROTOCOL_WAPI,      /* WAPI: Not support in this version */
83*4882a593Smuzhiyun 	ENCRYP_PROTOCOL_MAX
84*4882a593Smuzhiyun } ENCRYP_PROTOCOL_E;
85*4882a593Smuzhiyun 
86*4882a593Smuzhiyun 
87*4882a593Smuzhiyun #ifndef Ndis802_11AuthModeWPA2
88*4882a593Smuzhiyun #define Ndis802_11AuthModeWPA2 (Ndis802_11AuthModeWPANone + 1)
89*4882a593Smuzhiyun #endif
90*4882a593Smuzhiyun 
91*4882a593Smuzhiyun #ifndef Ndis802_11AuthModeWPA2PSK
92*4882a593Smuzhiyun #define Ndis802_11AuthModeWPA2PSK (Ndis802_11AuthModeWPANone + 2)
93*4882a593Smuzhiyun #endif
94*4882a593Smuzhiyun 
95*4882a593Smuzhiyun union pn48	{
96*4882a593Smuzhiyun 
97*4882a593Smuzhiyun 	u64	val;
98*4882a593Smuzhiyun 
99*4882a593Smuzhiyun #ifdef CONFIG_LITTLE_ENDIAN
100*4882a593Smuzhiyun 
101*4882a593Smuzhiyun struct {
102*4882a593Smuzhiyun 	u8 TSC0;
103*4882a593Smuzhiyun 	u8 TSC1;
104*4882a593Smuzhiyun 	u8 TSC2;
105*4882a593Smuzhiyun 	u8 TSC3;
106*4882a593Smuzhiyun 	u8 TSC4;
107*4882a593Smuzhiyun 	u8 TSC5;
108*4882a593Smuzhiyun 	u8 TSC6;
109*4882a593Smuzhiyun 	u8 TSC7;
110*4882a593Smuzhiyun } _byte_;
111*4882a593Smuzhiyun 
112*4882a593Smuzhiyun #elif defined(CONFIG_BIG_ENDIAN)
113*4882a593Smuzhiyun 
114*4882a593Smuzhiyun struct {
115*4882a593Smuzhiyun 	u8 TSC7;
116*4882a593Smuzhiyun 	u8 TSC6;
117*4882a593Smuzhiyun 	u8 TSC5;
118*4882a593Smuzhiyun 	u8 TSC4;
119*4882a593Smuzhiyun 	u8 TSC3;
120*4882a593Smuzhiyun 	u8 TSC2;
121*4882a593Smuzhiyun 	u8 TSC1;
122*4882a593Smuzhiyun 	u8 TSC0;
123*4882a593Smuzhiyun } _byte_;
124*4882a593Smuzhiyun 
125*4882a593Smuzhiyun #endif
126*4882a593Smuzhiyun 
127*4882a593Smuzhiyun };
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun union Keytype {
130*4882a593Smuzhiyun 	u8 skey[32];
131*4882a593Smuzhiyun };
132*4882a593Smuzhiyun 
133*4882a593Smuzhiyun typedef struct _RT_PMKID_LIST {
134*4882a593Smuzhiyun 	u8						bUsed;
135*4882a593Smuzhiyun 	u8						Bssid[6];
136*4882a593Smuzhiyun 	u8						PMKID[16];
137*4882a593Smuzhiyun 	u8						SsidBuf[33];
138*4882a593Smuzhiyun 	u8						*ssid_octet;
139*4882a593Smuzhiyun 	u16						ssid_length;
140*4882a593Smuzhiyun } RT_PMKID_LIST, *PRT_PMKID_LIST;
141*4882a593Smuzhiyun 
142*4882a593Smuzhiyun 
143*4882a593Smuzhiyun struct security_priv {
144*4882a593Smuzhiyun 	u32	  dot11AuthAlgrthm;		/* 802.11 auth, could be open, shared, 8021x and authswitch */
145*4882a593Smuzhiyun 	u32	  dot11PrivacyAlgrthm;	/* This specify the privacy for shared auth. algorithm. */
146*4882a593Smuzhiyun 
147*4882a593Smuzhiyun 	/* WEP */
148*4882a593Smuzhiyun 	u32	  dot11PrivacyKeyIndex;	/* this is only valid for legendary wep, 0~3 for key id. (tx key index) */
149*4882a593Smuzhiyun 	union Keytype dot11DefKey[6];			/* this is only valid for def. key	 */
150*4882a593Smuzhiyun 	u32	dot11DefKeylen[6];
151*4882a593Smuzhiyun 	u8	dot11Def_camid[6];
152*4882a593Smuzhiyun 	u8 	key_mask; /* use to restore wep key after hal_init */
153*4882a593Smuzhiyun 
154*4882a593Smuzhiyun 	u32 dot118021XGrpPrivacy;	/* This specify the privacy algthm. used for Grp key */
155*4882a593Smuzhiyun 	u32	dot118021XGrpKeyid;		/* key id used for Grp Key ( tx key index) */
156*4882a593Smuzhiyun 	union Keytype	dot118021XGrpKey[6];	/* 802.1x Group Key, for inx0 and inx1	 */
157*4882a593Smuzhiyun 	union Keytype	dot118021XGrptxmickey[6];
158*4882a593Smuzhiyun 	union Keytype	dot118021XGrprxmickey[6];
159*4882a593Smuzhiyun 	union pn48		dot11Grptxpn;			/* PN48 used for Grp Key xmit. */
160*4882a593Smuzhiyun 	union pn48		dot11Grprxpn;			/* PN48 used for Grp Key recv. */
161*4882a593Smuzhiyun 	u8				iv_seq[4][8];
162*4882a593Smuzhiyun #ifdef CONFIG_IEEE80211W
163*4882a593Smuzhiyun 	enum security_type dot11wCipher;
164*4882a593Smuzhiyun 	u32	dot11wBIPKeyid;						/* key id used for BIP Key ( tx key index) */
165*4882a593Smuzhiyun 	union Keytype	dot11wBIPKey[6];		/* BIP Key, for index4 and index5 */
166*4882a593Smuzhiyun 	union pn48		dot11wBIPtxpn;			/* PN48 used for BIP xmit. */
167*4882a593Smuzhiyun 	union pn48		dot11wBIPrxpn;			/* PN48 used for BIP recv. */
168*4882a593Smuzhiyun #endif /* CONFIG_IEEE80211W */
169*4882a593Smuzhiyun #ifdef CONFIG_AP_MODE
170*4882a593Smuzhiyun 	/* extend security capabilities for AP_MODE */
171*4882a593Smuzhiyun 	unsigned int dot8021xalg;/* 0:disable, 1:psk, 2:802.1x */
172*4882a593Smuzhiyun 	unsigned int wpa_psk;/* 0:disable, bit(0): WPA, bit(1):WPA2 */
173*4882a593Smuzhiyun 	unsigned int wpa_group_cipher;
174*4882a593Smuzhiyun 	unsigned int wpa2_group_cipher;
175*4882a593Smuzhiyun 	unsigned int wpa_pairwise_cipher;
176*4882a593Smuzhiyun 	unsigned int wpa2_pairwise_cipher;
177*4882a593Smuzhiyun 	unsigned int akmp; /* An authentication and key management protocol */
178*4882a593Smuzhiyun 	u8 mfp_opt;
179*4882a593Smuzhiyun #endif
180*4882a593Smuzhiyun #ifdef CONFIG_CONCURRENT_MODE
181*4882a593Smuzhiyun 	u8	dot118021x_bmc_cam_id;
182*4882a593Smuzhiyun #endif
183*4882a593Smuzhiyun 	/*IEEE802.11-2012 Std. Table 8-101 AKM Suite Selectors*/
184*4882a593Smuzhiyun 	u32	rsn_akm_suite_type;
185*4882a593Smuzhiyun 
186*4882a593Smuzhiyun 	u8 wps_ie[MAX_WPS_IE_LEN];/* added in assoc req */
187*4882a593Smuzhiyun 	int wps_ie_len;
188*4882a593Smuzhiyun 
189*4882a593Smuzhiyun 	u8 owe_ie[MAX_OWE_IE_LEN];/* added in assoc req */
190*4882a593Smuzhiyun 	int owe_ie_len;
191*4882a593Smuzhiyun 
192*4882a593Smuzhiyun 	u8	binstallGrpkey;
193*4882a593Smuzhiyun #ifdef CONFIG_GTK_OL
194*4882a593Smuzhiyun 	u8	binstallKCK_KEK;
195*4882a593Smuzhiyun #endif /* CONFIG_GTK_OL */
196*4882a593Smuzhiyun #ifdef CONFIG_IEEE80211W
197*4882a593Smuzhiyun 	u8	binstallBIPkey;
198*4882a593Smuzhiyun #endif /* CONFIG_IEEE80211W */
199*4882a593Smuzhiyun 	u8	busetkipkey;
200*4882a593Smuzhiyun 	u8	bcheck_grpkey;
201*4882a593Smuzhiyun 	u8	bgrpkey_handshake;
202*4882a593Smuzhiyun 
203*4882a593Smuzhiyun 	u8	auth_alg;
204*4882a593Smuzhiyun 	u8	auth_type;
205*4882a593Smuzhiyun 	u8	extauth_status;
206*4882a593Smuzhiyun 	/* u8	packet_cnt; */ /* unused, removed */
207*4882a593Smuzhiyun 
208*4882a593Smuzhiyun 	s32	sw_encrypt;/* from registry_priv */
209*4882a593Smuzhiyun 	s32	sw_decrypt;/* from registry_priv */
210*4882a593Smuzhiyun 
211*4882a593Smuzhiyun 	s32 hw_decrypted; /* Broadcast HW security is ready or not */
212*4882a593Smuzhiyun 
213*4882a593Smuzhiyun 
214*4882a593Smuzhiyun 	/* keeps the auth_type & enc_status from upper layer ioctl(wpa_supplicant or wzc) */
215*4882a593Smuzhiyun 	u32 ndisauthtype;	/* NDIS_802_11_AUTHENTICATION_MODE */
216*4882a593Smuzhiyun 	u32 ndisencryptstatus;	/* NDIS_802_11_ENCRYPTION_STATUS */
217*4882a593Smuzhiyun 
218*4882a593Smuzhiyun 	NDIS_802_11_WEP ndiswep;
219*4882a593Smuzhiyun 
220*4882a593Smuzhiyun 	u8 authenticator_ie[256];  /* store ap security information element */
221*4882a593Smuzhiyun 	u8 supplicant_ie[256];  /* store sta security information element */
222*4882a593Smuzhiyun 
223*4882a593Smuzhiyun 
224*4882a593Smuzhiyun 	/* for tkip countermeasure */
225*4882a593Smuzhiyun 	systime last_mic_err_time;
226*4882a593Smuzhiyun 	u8	btkip_countermeasure;
227*4882a593Smuzhiyun 	u8	btkip_wait_report;
228*4882a593Smuzhiyun 	systime btkip_countermeasure_time;
229*4882a593Smuzhiyun 
230*4882a593Smuzhiyun 	/* --------------------------------------------------------------------------- */
231*4882a593Smuzhiyun 	/* For WPA2 Pre-Authentication. */
232*4882a593Smuzhiyun 	/* --------------------------------------------------------------------------- */
233*4882a593Smuzhiyun 	/* u8				RegEnablePreAuth;				 */ /* Default value: Pre-Authentication enabled or not, from registry "EnablePreAuth". Added by Annie, 2005-11-01. */
234*4882a593Smuzhiyun 	/* u8				EnablePreAuthentication;			 */ /* Current Value: Pre-Authentication enabled or not. */
235*4882a593Smuzhiyun 	RT_PMKID_LIST		PMKIDList[NUM_PMKID_CACHE];	/* Renamed from PreAuthKey[NUM_PRE_AUTH_KEY]. Annie, 2006-10-13. */
236*4882a593Smuzhiyun 	u8				PMKIDIndex;
237*4882a593Smuzhiyun 	/* u32				PMKIDCount;						 */ /* Added by Annie, 2006-10-13. */
238*4882a593Smuzhiyun 	/* u8				szCapability[256];				 */ /* For WPA2-PSK using zero-config, by Annie, 2005-09-20. */
239*4882a593Smuzhiyun 
240*4882a593Smuzhiyun 	u8 bWepDefaultKeyIdxSet;
241*4882a593Smuzhiyun 
242*4882a593Smuzhiyun #define DBG_SW_SEC_CNT
243*4882a593Smuzhiyun #ifdef DBG_SW_SEC_CNT
244*4882a593Smuzhiyun 	u64 wep_sw_enc_cnt_bc;
245*4882a593Smuzhiyun 	u64 wep_sw_enc_cnt_mc;
246*4882a593Smuzhiyun 	u64 wep_sw_enc_cnt_uc;
247*4882a593Smuzhiyun 	u64 wep_sw_dec_cnt_bc;
248*4882a593Smuzhiyun 	u64 wep_sw_dec_cnt_mc;
249*4882a593Smuzhiyun 	u64 wep_sw_dec_cnt_uc;
250*4882a593Smuzhiyun 
251*4882a593Smuzhiyun 	u64 tkip_sw_enc_cnt_bc;
252*4882a593Smuzhiyun 	u64 tkip_sw_enc_cnt_mc;
253*4882a593Smuzhiyun 	u64 tkip_sw_enc_cnt_uc;
254*4882a593Smuzhiyun 	u64 tkip_sw_dec_cnt_bc;
255*4882a593Smuzhiyun 	u64 tkip_sw_dec_cnt_mc;
256*4882a593Smuzhiyun 	u64 tkip_sw_dec_cnt_uc;
257*4882a593Smuzhiyun 
258*4882a593Smuzhiyun 	u64 aes_sw_enc_cnt_bc;
259*4882a593Smuzhiyun 	u64 aes_sw_enc_cnt_mc;
260*4882a593Smuzhiyun 	u64 aes_sw_enc_cnt_uc;
261*4882a593Smuzhiyun 	u64 aes_sw_dec_cnt_bc;
262*4882a593Smuzhiyun 	u64 aes_sw_dec_cnt_mc;
263*4882a593Smuzhiyun 	u64 aes_sw_dec_cnt_uc;
264*4882a593Smuzhiyun 
265*4882a593Smuzhiyun 	u64 gcmp_sw_enc_cnt_bc;
266*4882a593Smuzhiyun 	u64 gcmp_sw_enc_cnt_mc;
267*4882a593Smuzhiyun 	u64 gcmp_sw_enc_cnt_uc;
268*4882a593Smuzhiyun 	u64 gcmp_sw_dec_cnt_bc;
269*4882a593Smuzhiyun 	u64 gcmp_sw_dec_cnt_mc;
270*4882a593Smuzhiyun 	u64 gcmp_sw_dec_cnt_uc;
271*4882a593Smuzhiyun #endif /* DBG_SW_SEC_CNT */
272*4882a593Smuzhiyun };
273*4882a593Smuzhiyun 
274*4882a593Smuzhiyun #ifdef CONFIG_IEEE80211W
275*4882a593Smuzhiyun #define SEC_IS_BIP_KEY_INSTALLED(sec) ((sec)->binstallBIPkey)
276*4882a593Smuzhiyun #else
277*4882a593Smuzhiyun #define SEC_IS_BIP_KEY_INSTALLED(sec) _FALSE
278*4882a593Smuzhiyun #endif
279*4882a593Smuzhiyun 
280*4882a593Smuzhiyun #define GET_ENCRY_ALGO(psecuritypriv, psta, encry_algo, bmcst)\
281*4882a593Smuzhiyun 	do {\
282*4882a593Smuzhiyun 		switch (psecuritypriv->dot11AuthAlgrthm) {\
283*4882a593Smuzhiyun 		case dot11AuthAlgrthm_Open:\
284*4882a593Smuzhiyun 		case dot11AuthAlgrthm_Shared:\
285*4882a593Smuzhiyun 		case dot11AuthAlgrthm_Auto:\
286*4882a593Smuzhiyun 			encry_algo = (u8)psecuritypriv->dot11PrivacyAlgrthm;\
287*4882a593Smuzhiyun 			break;\
288*4882a593Smuzhiyun 		case dot11AuthAlgrthm_8021X:\
289*4882a593Smuzhiyun 			if (bmcst)\
290*4882a593Smuzhiyun 				encry_algo = (u8)psecuritypriv->dot118021XGrpPrivacy;\
291*4882a593Smuzhiyun 			else\
292*4882a593Smuzhiyun 				encry_algo = (u8) psta->dot118021XPrivacy;\
293*4882a593Smuzhiyun 			break;\
294*4882a593Smuzhiyun 		case dot11AuthAlgrthm_WAPI:\
295*4882a593Smuzhiyun 			encry_algo = (u8)psecuritypriv->dot11PrivacyAlgrthm;\
296*4882a593Smuzhiyun 			break;\
297*4882a593Smuzhiyun 		} \
298*4882a593Smuzhiyun 	} while (0)
299*4882a593Smuzhiyun 
300*4882a593Smuzhiyun #define _AES_IV_LEN_ 8
301*4882a593Smuzhiyun 
302*4882a593Smuzhiyun #define SET_ICE_IV_LEN(iv_len, icv_len, encrypt)\
303*4882a593Smuzhiyun 	do {\
304*4882a593Smuzhiyun 		switch (encrypt) {\
305*4882a593Smuzhiyun 		case _WEP40_:\
306*4882a593Smuzhiyun 		case _WEP104_:\
307*4882a593Smuzhiyun 			iv_len = 4;\
308*4882a593Smuzhiyun 			icv_len = 4;\
309*4882a593Smuzhiyun 			break;\
310*4882a593Smuzhiyun 		case _TKIP_:\
311*4882a593Smuzhiyun 			iv_len = 8;\
312*4882a593Smuzhiyun 			icv_len = 4;\
313*4882a593Smuzhiyun 			break;\
314*4882a593Smuzhiyun 		case _AES_:\
315*4882a593Smuzhiyun 			iv_len = 8;\
316*4882a593Smuzhiyun 			icv_len = 8;\
317*4882a593Smuzhiyun 			break;\
318*4882a593Smuzhiyun 		case _GCMP_:\
319*4882a593Smuzhiyun 		case _GCMP_256_:\
320*4882a593Smuzhiyun 			iv_len = 8;\
321*4882a593Smuzhiyun 			icv_len = 16;\
322*4882a593Smuzhiyun 			break;\
323*4882a593Smuzhiyun 		case _CCMP_256_:\
324*4882a593Smuzhiyun 			iv_len = 8;\
325*4882a593Smuzhiyun 			icv_len = 16;\
326*4882a593Smuzhiyun 			break;\
327*4882a593Smuzhiyun 		case _SMS4_:\
328*4882a593Smuzhiyun 			iv_len = 18;\
329*4882a593Smuzhiyun 			icv_len = 16;\
330*4882a593Smuzhiyun 			break;\
331*4882a593Smuzhiyun 		default:\
332*4882a593Smuzhiyun 			iv_len = 0;\
333*4882a593Smuzhiyun 			icv_len = 0;\
334*4882a593Smuzhiyun 			break;\
335*4882a593Smuzhiyun 		} \
336*4882a593Smuzhiyun 	} while (0)
337*4882a593Smuzhiyun 
338*4882a593Smuzhiyun 
339*4882a593Smuzhiyun #define GET_TKIP_PN(iv, dot11txpn)\
340*4882a593Smuzhiyun 	do {\
341*4882a593Smuzhiyun 		dot11txpn._byte_.TSC0 = iv[2];\
342*4882a593Smuzhiyun 		dot11txpn._byte_.TSC1 = iv[0];\
343*4882a593Smuzhiyun 		dot11txpn._byte_.TSC2 = iv[4];\
344*4882a593Smuzhiyun 		dot11txpn._byte_.TSC3 = iv[5];\
345*4882a593Smuzhiyun 		dot11txpn._byte_.TSC4 = iv[6];\
346*4882a593Smuzhiyun 		dot11txpn._byte_.TSC5 = iv[7];\
347*4882a593Smuzhiyun 	} while (0)
348*4882a593Smuzhiyun 
349*4882a593Smuzhiyun 
350*4882a593Smuzhiyun #define ROL32(A, n)	(((A) << (n)) | (((A)>>(32-(n)))  & ((1UL << (n)) - 1)))
351*4882a593Smuzhiyun #define ROR32(A, n)	ROL32((A), 32-(n))
352*4882a593Smuzhiyun 
353*4882a593Smuzhiyun struct mic_data {
354*4882a593Smuzhiyun 	u32  K0, K1;         /* Key */
355*4882a593Smuzhiyun 	u32  L, R;           /* Current state */
356*4882a593Smuzhiyun 	u32  M;              /* Message accumulator (single word) */
357*4882a593Smuzhiyun 	u32     nBytesInM;      /*  # bytes in M */
358*4882a593Smuzhiyun };
359*4882a593Smuzhiyun 
360*4882a593Smuzhiyun void rtw_secmicsetkey(struct mic_data *pmicdata, u8 *key);
361*4882a593Smuzhiyun void rtw_secmicappendbyte(struct mic_data *pmicdata, u8 b);
362*4882a593Smuzhiyun void rtw_secmicappend(struct mic_data *pmicdata, u8 *src, u32 nBytes);
363*4882a593Smuzhiyun void rtw_secgetmic(struct mic_data *pmicdata, u8 *dst);
364*4882a593Smuzhiyun 
365*4882a593Smuzhiyun void rtw_seccalctkipmic(
366*4882a593Smuzhiyun 	u8 *key,
367*4882a593Smuzhiyun 	u8 *header,
368*4882a593Smuzhiyun 	u8 *data,
369*4882a593Smuzhiyun 	u32 data_len,
370*4882a593Smuzhiyun 	u8 *Miccode,
371*4882a593Smuzhiyun 	u8   priority);
372*4882a593Smuzhiyun 
373*4882a593Smuzhiyun u32 rtw_aes_encrypt(_adapter *padapter, u8 *pxmitframe);
374*4882a593Smuzhiyun u32 rtw_tkip_encrypt(_adapter *padapter, u8 *pxmitframe);
375*4882a593Smuzhiyun void rtw_wep_encrypt(_adapter *padapter, u8  *pxmitframe);
376*4882a593Smuzhiyun 
377*4882a593Smuzhiyun u32 rtw_aes_decrypt(_adapter *padapter, u8  *precvframe);
378*4882a593Smuzhiyun u32 rtw_tkip_decrypt(_adapter *padapter, u8  *precvframe);
379*4882a593Smuzhiyun void rtw_wep_decrypt(_adapter *padapter, u8  *precvframe);
380*4882a593Smuzhiyun 
381*4882a593Smuzhiyun u32 rtw_gcmp_encrypt(_adapter *padapter, u8 *pxmitframe);
382*4882a593Smuzhiyun u32 rtw_gcmp_decrypt(_adapter *padapter, u8 *precvframe);
383*4882a593Smuzhiyun 
384*4882a593Smuzhiyun #if 0 //RTW_PHL_TX: mark un-finished codes for reading
385*4882a593Smuzhiyun u32 rtw_core_aes_encrypt(_adapter *padapter, u8 *pxframe);
386*4882a593Smuzhiyun #endif
387*4882a593Smuzhiyun 
388*4882a593Smuzhiyun #ifdef CONFIG_RTW_MESH_AEK
389*4882a593Smuzhiyun int rtw_aes_siv_encrypt(const u8 *key, size_t key_len,
390*4882a593Smuzhiyun 	const u8 *pw, size_t pwlen, size_t num_elem,
391*4882a593Smuzhiyun 	const u8 *addr[], const size_t *len, u8 *out);
392*4882a593Smuzhiyun int rtw_aes_siv_decrypt(const u8 *key, size_t key_len,
393*4882a593Smuzhiyun 	const u8 *iv_crypt, size_t iv_c_len, size_t num_elem,
394*4882a593Smuzhiyun 	const u8 *addr[], const size_t *len, u8 *out);
395*4882a593Smuzhiyun #endif /* CONFIG_RTW_MESH_AEK */
396*4882a593Smuzhiyun 
397*4882a593Smuzhiyun #ifdef CONFIG_IEEE80211W
398*4882a593Smuzhiyun u8 rtw_calculate_bip_mic(enum security_type gmcs, u8 *whdr_pos, s32 len,
399*4882a593Smuzhiyun 	const u8 *key, const u8 *data, size_t data_len, u8 *mic);
400*4882a593Smuzhiyun u32 rtw_bip_verify(enum security_type gmcs, u16 pkt_len,
401*4882a593Smuzhiyun 	u8 *whdr_pos, sint flen, const u8 *key, u16 keyid, u64 *ipn,
402*4882a593Smuzhiyun 	u8 *precvframe);
403*4882a593Smuzhiyun #endif
404*4882a593Smuzhiyun #ifdef CONFIG_TDLS
405*4882a593Smuzhiyun void wpa_tdls_generate_tpk(_adapter *padapter, void *sta);
406*4882a593Smuzhiyun int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq,
407*4882a593Smuzhiyun 			u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie,
408*4882a593Smuzhiyun 			u8 *mic);
409*4882a593Smuzhiyun int wpa_tdls_teardown_ftie_mic(u8 *kck, u8 *lnkid, u16 reason,
410*4882a593Smuzhiyun 			u8 dialog_token, u8 trans_seq, u8 *ftie, u8 *mic);
411*4882a593Smuzhiyun int tdls_verify_mic(u8 *kck, u8 trans_seq,
412*4882a593Smuzhiyun 			u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie);
413*4882a593Smuzhiyun #endif /* CONFIG_TDLS */
414*4882a593Smuzhiyun 
415*4882a593Smuzhiyun void rtw_sec_restore_wep_key(_adapter *adapter);
416*4882a593Smuzhiyun u8 rtw_handle_tkip_countermeasure(_adapter *adapter, const char *caller);
417*4882a593Smuzhiyun 
418*4882a593Smuzhiyun #ifdef CONFIG_WOWLAN
419*4882a593Smuzhiyun u16 rtw_calc_crc(u8  *pdata, int length);
420*4882a593Smuzhiyun #endif /*CONFIG_WOWLAN*/
421*4882a593Smuzhiyun 
422*4882a593Smuzhiyun #define rtw_sec_chk_auth_alg(a, s) \
423*4882a593Smuzhiyun 	((a)->securitypriv.auth_alg == (s))
424*4882a593Smuzhiyun 
425*4882a593Smuzhiyun #define rtw_sec_chk_auth_type(a, s) \
426*4882a593Smuzhiyun 	((a)->securitypriv.auth_type == (s))
427*4882a593Smuzhiyun 
428*4882a593Smuzhiyun #define IV_FMT "0x%02x%02x%02x%02x%02x%02x%02x%02x"
429*4882a593Smuzhiyun #define IV_ARG(iv) iv[7], iv[6], iv[5], iv[4], iv[3], iv[2], iv[1], iv[0]
430*4882a593Smuzhiyun #define PN_FMT "0x%02x%02x%02x%02x%02x%02x"
431*4882a593Smuzhiyun #define PN_ARG(pn) pn[5], pn[4], pn[3], pn[2], pn[1], pn[0]
432*4882a593Smuzhiyun u8 rtw_iv_to_pn(u8 *iv, u8 *pn, u8 *key_id, u32 enc_algo);
433*4882a593Smuzhiyun u8 rtw_pn_to_iv(u8 *pn, u8 *iv, u8 key_id, u32 enc_algo);
434*4882a593Smuzhiyun #endif /* __RTL871X_SECURITY_H_ */
435*4882a593Smuzhiyun 
436*4882a593Smuzhiyun u32 rtw_calc_crc32(u8 *data, size_t len);
437