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