| /* |
| * Copyright (c) 2013-2015, 2017 The Linux Foundation. All rights reserved. |
| * |
| * Previously licensed under the ISC license by Qualcomm Atheros, Inc. |
| * |
| * |
| * Permission to use, copy, modify, and/or distribute this software for |
| * any purpose with or without fee is hereby granted, provided that the |
| * above copyright notice and this permission notice appear in all |
| * copies. |
| * |
| * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL |
| * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED |
| * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE |
| * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL |
| * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR |
| * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER |
| * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR |
| * PERFORMANCE OF THIS SOFTWARE. |
| */ |
| |
| /* |
| * This file was originally distributed by Qualcomm Atheros, Inc. |
| * under proprietary terms before Copyright ownership was assigned |
| * to the Linux Foundation. |
| */ |
| |
| #if defined WLAN_FEATURE_VOWIFI_11R |
| /**========================================================================= |
| |
| Macros and Function prototypes FT and 802.11R purposes |
| |
| ========================================================================*/ |
| |
| #ifndef __LIMFTDEFS_H__ |
| #define __LIMFTDEFS_H__ |
| |
| |
| #include <palTypes.h> |
| #include "halMsgApi.h" |
| |
| /*-------------------------------------------------------------------------- |
| Preprocessor definitions and constants |
| ------------------------------------------------------------------------*/ |
| #define SIR_MDIE_SIZE 3 // MD ID(2 bytes), Capability(1 byte) |
| #define MAX_FTIE_SIZE 384 // Max size limited to 384, on acct. of IW custom events |
| |
| |
| /*-------------------------------------------------------------------------- |
| Type declarations |
| ------------------------------------------------------------------------*/ |
| /*-------------------------------------------------------------------------- |
| FT Pre Auth Req SME<->PE |
| ------------------------------------------------------------------------*/ |
| typedef struct sSirFTPreAuthReq |
| { |
| tANI_U16 messageType; // eWNI_SME_FT_PRE_AUTH_REQ |
| tANI_U16 length; |
| tANI_U32 dot11mode; |
| tANI_BOOLEAN bPreAuthRspProcessed; /* Track if response is processed for this request |
| We expect only one response per request. */ |
| tANI_U8 preAuthchannelNum; |
| tSirMacAddr currbssId; // BSSID currently associated to suspend the link |
| tSirMacAddr preAuthbssId; // BSSID to preauth to |
| tANI_U16 ft_ies_length; |
| tANI_U8 ft_ies[MAX_FTIE_SIZE]; |
| tpSirBssDescription pbssDescription; |
| } tSirFTPreAuthReq, *tpSirFTPreAuthReq; |
| |
| /*------------------------------------------------------------------------- |
| FT Pre Auth Rsp PE<->SME |
| ------------------------------------------------------------------------*/ |
| typedef struct sSirFTPreAuthRsp |
| { |
| tANI_U16 messageType; // eWNI_SME_FT_PRE_AUTH_RSP |
| tANI_U16 length; |
| tANI_U8 smeSessionId; |
| tSirMacAddr preAuthbssId; // BSSID to preauth to |
| tSirRetStatus status; |
| tANI_U16 ft_ies_length; |
| tANI_U8 ft_ies[MAX_FTIE_SIZE]; |
| tANI_U16 ric_ies_length; |
| tANI_U8 ric_ies[MAX_FTIE_SIZE]; |
| } tSirFTPreAuthRsp, *tpSirFTPreAuthRsp; |
| |
| /*-------------------------------------------------------------------------- |
| FT Pre Auth Rsp Key SME<->PE |
| ------------------------------------------------------------------------*/ |
| typedef struct sSirFTUpdateKeyInfo |
| { |
| tANI_U16 messageType; |
| tANI_U16 length; |
| tANI_U32 smeSessionId; |
| tSirMacAddr bssId; |
| tSirKeyMaterial keyMaterial; |
| } tSirFTUpdateKeyInfo, *tpSirFTUpdateKeyInfo; |
| |
| /*-------------------------------------------------------------------------- |
| FT Pre Auth Rsp Key SME<->PE |
| ------------------------------------------------------------------------*/ |
| typedef struct sSirFTPreAuthKeyInfo |
| { |
| tANI_U8 extSetStaKeyParamValid; //Ext Bss Config Msg if set |
| tLimMlmSetKeysReq extSetStaKeyParam; //SetStaKeyParams for ext bss msg |
| } tSirFTPreAuthKeyInfo, *tpSirFTPreAuthKeyInfo; |
| |
| /*------------------------------------------------------------------------- |
| Global FT Information |
| ------------------------------------------------------------------------*/ |
| typedef struct sFTPEContext |
| { |
| tpSirFTPreAuthReq pFTPreAuthReq; /* Saved FT Pre Auth Req */ |
| tSirRetStatus ftPreAuthStatus; |
| tANI_U16 saved_auth_rsp_length; |
| tANI_U8 saved_auth_rsp[MAX_FTIE_SIZE]; |
| tSirFTPreAuthKeyInfo PreAuthKeyInfo; |
| /* Items created for the new FT, session */ |
| void *pAddBssReq; /* Save add bss req */ |
| void *pAddStaReq; /*Save add sta req */ |
| tANI_U32 peSessionId; |
| tANI_U32 smeSessionId; |
| |
| /* This flag is required to indicate on which session the preauth |
| * has taken place, since the auth reponse for preauth will come |
| * for a new BSSID for which there is no session yet. This flag |
| * will be used to extract the session from the session preauth |
| * has been initiated |
| */ |
| tANI_BOOLEAN ftPreAuthSession; |
| } tftPEContext, *tpftPEContext; |
| |
| #endif /* __LIMFTDEFS_H__ */ |
| |
| #endif /* WLAN_FEATURE_VOWIFI_11R */ |