Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 1 | /* |
Anurag Chouhan | ce0dc99 | 2016-02-16 18:18:03 +0530 | [diff] [blame] | 2 | * Copyright (c) 2011-2016 The Linux Foundation. All rights reserved. |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 3 | * |
| 4 | * Previously licensed under the ISC license by Qualcomm Atheros, Inc. |
| 5 | * |
| 6 | * |
| 7 | * Permission to use, copy, modify, and/or distribute this software for |
| 8 | * any purpose with or without fee is hereby granted, provided that the |
| 9 | * above copyright notice and this permission notice appear in all |
| 10 | * copies. |
| 11 | * |
| 12 | * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL |
| 13 | * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED |
| 14 | * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE |
| 15 | * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL |
| 16 | * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR |
| 17 | * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER |
| 18 | * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR |
| 19 | * PERFORMANCE OF THIS SOFTWARE. |
| 20 | */ |
| 21 | |
| 22 | /* |
| 23 | * This file was originally distributed by Qualcomm Atheros, Inc. |
| 24 | * under proprietary terms before Copyright ownership was assigned |
| 25 | * to the Linux Foundation. |
| 26 | */ |
| 27 | |
| 28 | #if !defined(__SMEINTERNAL_H) |
| 29 | #define __SMEINTERNAL_H |
| 30 | |
| 31 | /** |
| 32 | * \file sme_internal.h |
| 33 | * |
| 34 | * \brief prototype for SME internal structures and APIs used for SME and MAC |
| 35 | */ |
| 36 | |
| 37 | /*-------------------------------------------------------------------------- |
| 38 | Include Files |
| 39 | ------------------------------------------------------------------------*/ |
Anurag Chouhan | ce0dc99 | 2016-02-16 18:18:03 +0530 | [diff] [blame] | 40 | #include "qdf_status.h" |
Anurag Chouhan | a37b5b7 | 2016-02-21 14:53:42 +0530 | [diff] [blame] | 41 | #include "qdf_lock.h" |
Anurag Chouhan | b2dc16f | 2016-02-25 11:47:37 +0530 | [diff] [blame] | 42 | #include "qdf_trace.h" |
Anurag Chouhan | 600c3a0 | 2016-03-01 10:33:54 +0530 | [diff] [blame] | 43 | #include "qdf_mem.h" |
Anurag Chouhan | 6d76066 | 2016-02-20 16:05:43 +0530 | [diff] [blame] | 44 | #include "qdf_types.h" |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 45 | #include "host_diag_core_event.h" |
| 46 | #include "csr_link_list.h" |
| 47 | #include "sme_power_save.h" |
| 48 | |
| 49 | /*-------------------------------------------------------------------------- |
| 50 | Type declarations |
| 51 | ------------------------------------------------------------------------*/ |
| 52 | |
| 53 | /* Mask can be only have one bit set */ |
| 54 | typedef enum eSmeCommandType { |
| 55 | eSmeNoCommand = 0, |
| 56 | eSmeDropCommand, |
| 57 | /* this is not a command, it is to identify this is a CSR command */ |
| 58 | eSmeCsrCommandMask = 0x10000, |
| 59 | eSmeCommandScan, |
| 60 | eSmeCommandRoam, |
| 61 | eSmeCommandWmStatusChange, |
| 62 | eSmeCommandSetKey, |
| 63 | eSmeCommandAddStaSession, |
| 64 | eSmeCommandDelStaSession, |
| 65 | #ifdef FEATURE_WLAN_TDLS |
| 66 | /* |
| 67 | * eSmeTdlsCommandMask = 0x80000, |
| 68 | * To identify TDLS commands <TODO> |
| 69 | * These can be considered as csr commands. |
| 70 | */ |
| 71 | eSmeCommandTdlsSendMgmt, |
| 72 | eSmeCommandTdlsAddPeer, |
| 73 | eSmeCommandTdlsDelPeer, |
| 74 | eSmeCommandTdlsLinkEstablish, |
| 75 | #endif |
| 76 | /* PMC */ |
| 77 | eSmePmcCommandMask = 0x20000, /* To identify PMC commands */ |
| 78 | eSmeCommandEnterBmps, |
| 79 | eSmeCommandExitBmps, |
| 80 | eSmeCommandEnterUapsd, |
| 81 | eSmeCommandExitUapsd, |
| 82 | eSmeCommandExitWowl, |
| 83 | eSmeCommandEnterStandby, |
| 84 | /* QOS */ |
| 85 | eSmeQosCommandMask = 0x40000, /* To identify Qos commands */ |
| 86 | eSmeCommandAddTs, |
| 87 | eSmeCommandDelTs, |
| 88 | #ifdef FEATURE_OEM_DATA_SUPPORT |
| 89 | eSmeCommandOemDataReq = 0x80000, /* To identify the oem data commands */ |
| 90 | #endif |
| 91 | eSmeCommandRemainOnChannel, |
| 92 | e_sme_command_set_hw_mode, |
| 93 | e_sme_command_nss_update, |
| 94 | e_sme_command_set_dual_mac_config, |
Archana Ramachandran | d41c3ed | 2016-02-10 15:48:06 -0800 | [diff] [blame] | 95 | e_sme_command_set_antenna_mode, |
Deepak Dhamdhere | 0f076bd | 2016-06-02 11:29:21 -0700 | [diff] [blame] | 96 | eSmeCommandNdpInitiatorRequest, |
Abhishek Singh | 4fef747 | 2016-06-06 11:36:03 -0700 | [diff] [blame] | 97 | eSmeCommandNdpResponderRequest, |
Naveen Rawat | f28315c | 2016-06-29 18:06:02 -0700 | [diff] [blame] | 98 | eSmeCommandNdpDataEndInitiatorRequest, |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 99 | } eSmeCommandType; |
| 100 | |
| 101 | typedef enum eSmeState { |
| 102 | SME_STATE_STOP, |
| 103 | SME_STATE_START, |
| 104 | SME_STATE_READY, |
| 105 | } eSmeState; |
| 106 | |
| 107 | #define SME_IS_START(pMac) (SME_STATE_STOP != (pMac)->sme.state) |
| 108 | #define SME_IS_READY(pMac) (SME_STATE_READY == (pMac)->sme.state) |
| 109 | |
Rajeev Kumar | 8e3e283 | 2015-11-06 16:02:54 -0800 | [diff] [blame] | 110 | /* HDD Callback function */ |
Rajeev Kumar | 94c9b45 | 2016-03-24 12:58:47 -0700 | [diff] [blame] | 111 | typedef void (*pIbssPeerInfoCb)(void *pUserData, |
| 112 | tSirPeerInfoRspParams *infoParam); |
Rajeev Kumar | 8e3e283 | 2015-11-06 16:02:54 -0800 | [diff] [blame] | 113 | |
| 114 | /* Peer info */ |
| 115 | typedef struct tagSmePeerInfoHddCbkInfo { |
| 116 | void *pUserData; |
| 117 | pIbssPeerInfoCb peerInfoCbk; |
| 118 | } tSmePeerInfoHddCbkInfo; |
| 119 | |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 120 | typedef struct sStatsExtEvent { |
| 121 | uint32_t vdev_id; |
| 122 | uint32_t event_data_len; |
| 123 | uint8_t event_data[]; |
| 124 | } tStatsExtEvent, *tpStatsExtEvent; |
| 125 | |
| 126 | #define MAX_ACTIVE_CMD_STATS 16 |
| 127 | |
| 128 | typedef struct sActiveCmdStats { |
| 129 | eSmeCommandType command; |
| 130 | uint32_t reason; |
| 131 | uint32_t sessionId; |
| 132 | uint64_t timestamp; |
| 133 | } tActiveCmdStats; |
| 134 | |
| 135 | typedef struct sSelfRecoveryStats { |
| 136 | tActiveCmdStats activeCmdStats[MAX_ACTIVE_CMD_STATS]; |
| 137 | uint8_t cmdStatsIndx; |
| 138 | } tSelfRecoveryStats; |
| 139 | |
| 140 | #ifdef WLAN_FEATURE_GTK_OFFLOAD |
| 141 | /* GTK Offload Information Callback declaration */ |
| 142 | typedef void (*gtk_offload_get_info_callback)(void *callback_context, |
| 143 | tpSirGtkOffloadGetInfoRspParams |
| 144 | pGtkOffloadGetInfoRsp); |
| 145 | #endif |
| 146 | #ifdef FEATURE_WLAN_SCAN_PNO |
| 147 | /*Pref netw found Cb declaration*/ |
| 148 | typedef void (*preferred_network_found_ind_cb)(void *callback_context, |
| 149 | tpSirPrefNetworkFoundInd |
| 150 | pPrefNetworkFoundInd); |
| 151 | #endif |
| 152 | |
| 153 | typedef void (*ocb_callback)(void *context, void *response); |
| 154 | typedef void (*sme_set_thermal_level_callback)(void *context, u_int8_t level); |
Peng Xu | 8fdaa49 | 2016-06-22 10:20:47 -0700 | [diff] [blame] | 155 | typedef void (*p2p_lo_callback)(void *context, void *event); |
Krishna Kumaar Natarajan | c1fa17d | 2016-08-03 14:19:20 -0700 | [diff] [blame] | 156 | typedef void (*sme_send_oem_data_rsp_msg)(struct oem_data_rsp *); |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 157 | |
| 158 | typedef struct tagSmeStruct { |
| 159 | eSmeState state; |
Anurag Chouhan | a37b5b7 | 2016-02-21 14:53:42 +0530 | [diff] [blame] | 160 | qdf_mutex_t lkSmeGlobalLock; |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 161 | uint32_t totalSmeCmd; |
Naveen Rawat | e7d8605 | 2015-11-13 12:01:43 -0800 | [diff] [blame] | 162 | /* following pointer contains array of pointers for tSmeCmd* */ |
| 163 | void **pSmeCmdBufAddr; |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 164 | tDblLinkList smeCmdActiveList; |
| 165 | tDblLinkList smeCmdPendingList; |
| 166 | tDblLinkList smeCmdFreeList; /* preallocated roam cmd list */ |
Anurag Chouhan | 6d76066 | 2016-02-20 16:05:43 +0530 | [diff] [blame] | 167 | enum tQDF_ADAPTER_MODE currDeviceMode; |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 168 | #ifdef FEATURE_WLAN_LPHB |
| 169 | void (*pLphbIndCb)(void *pHddCtx, tSirLPHBInd *indParam); |
| 170 | #endif /* FEATURE_WLAN_LPHB */ |
| 171 | /* pending scan command list */ |
| 172 | tDblLinkList smeScanCmdPendingList; |
| 173 | /* active scan command list */ |
| 174 | tDblLinkList smeScanCmdActiveList; |
Rajeev Kumar | 8e3e283 | 2015-11-06 16:02:54 -0800 | [diff] [blame] | 175 | tSmePeerInfoHddCbkInfo peerInfoParams; |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 176 | #ifdef FEATURE_WLAN_DIAG_SUPPORT_CSR |
| 177 | host_event_wlan_status_payload_type eventPayload; |
| 178 | #endif |
| 179 | #ifdef FEATURE_WLAN_CH_AVOID |
| 180 | void (*pChAvoidNotificationCb)(void *hdd_context, void *indi_param); |
| 181 | #endif /* FEATURE_WLAN_CH_AVOID */ |
| 182 | #ifdef WLAN_FEATURE_LINK_LAYER_STATS |
| 183 | void (*pLinkLayerStatsIndCallback)(void *callbackContext, |
| 184 | int indType, void *pRsp); |
| 185 | #endif /* WLAN_FEATURE_LINK_LAYER_STATS */ |
| 186 | #ifdef FEATURE_WLAN_AUTO_SHUTDOWN |
| 187 | void (*pAutoShutdownNotificationCb)(void); |
| 188 | #endif |
| 189 | /* Maximum interfaces allowed by the host */ |
| 190 | uint8_t max_intf_count; |
| 191 | void (*StatsExtCallback)(void *, tStatsExtEvent *); |
| 192 | /* linkspeed callback */ |
| 193 | void (*pLinkSpeedIndCb)(tSirLinkSpeedInfo *indParam, |
| 194 | void *pDevContext); |
| 195 | void *pLinkSpeedCbContext; |
| 196 | #ifdef FEATURE_WLAN_EXTSCAN |
| 197 | void (*pExtScanIndCb)(void *, const uint16_t, void *); |
| 198 | #endif /* FEATURE_WLAN_EXTSCAN */ |
| 199 | #ifdef WLAN_FEATURE_NAN |
| 200 | void (*nanCallback)(void *, tSirNanEvent *); |
| 201 | #endif |
| 202 | bool enableSelfRecovery; |
| 203 | tCsrLinkStatusCallback linkStatusCallback; |
| 204 | void *linkStatusContext; |
Manikandan Mohan | dcc21ba | 2016-03-15 14:31:56 -0700 | [diff] [blame] | 205 | int (*get_tsf_cb)(void *pcb_cxt, struct stsf *ptsf); |
| 206 | void *get_tsf_cxt; |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 207 | /* get temperature event context and callback */ |
| 208 | void *pTemperatureCbContext; |
| 209 | void (*pGetTemperatureCb)(int temperature, void *context); |
| 210 | uint8_t miracast_value; |
| 211 | struct ps_global_info ps_global_info; |
| 212 | #ifdef WLAN_FEATURE_GTK_OFFLOAD |
| 213 | /* routine to call for GTK Offload Information */ |
| 214 | gtk_offload_get_info_callback gtk_offload_get_info_cb; |
| 215 | /* value to be passed as parameter to routine specified above */ |
| 216 | void *gtk_offload_get_info_cb_context; |
| 217 | #endif /* WLAN_FEATURE_GTK_OFFLOAD */ |
| 218 | #ifdef FEATURE_WLAN_SCAN_PNO |
| 219 | /* routine to call for Preferred Network Found Indication */ |
| 220 | preferred_network_found_ind_cb pref_netw_found_cb; |
| 221 | /* value to be passed as parameter to routine specified above */ |
| 222 | void *preferred_network_found_ind_cb_ctx; |
| 223 | #endif /* FEATURE_WLAN_SCAN_PNO */ |
| 224 | void (*rssi_threshold_breached_cb)(void *, struct rssi_breach_event *); |
| 225 | #ifdef WLAN_FEATURE_MEMDUMP |
| 226 | void (*fw_dump_callback)(void *context, struct fw_dump_rsp *rsp); |
| 227 | #endif |
| 228 | hw_mode_transition_cb sme_hw_mode_trans_cb; |
| 229 | /* OCB callbacks */ |
| 230 | void *ocb_set_config_context; |
| 231 | ocb_callback ocb_set_config_callback; |
| 232 | void *ocb_get_tsf_timer_context; |
| 233 | ocb_callback ocb_get_tsf_timer_callback; |
| 234 | void *dcc_get_stats_context; |
| 235 | ocb_callback dcc_get_stats_callback; |
| 236 | void *dcc_update_ndl_context; |
| 237 | ocb_callback dcc_update_ndl_callback; |
| 238 | void *dcc_stats_event_context; |
| 239 | ocb_callback dcc_stats_event_callback; |
| 240 | sme_set_thermal_level_callback set_thermal_level_cb; |
Chandrasekaran, Manishekar | ef70c0d | 2015-10-20 19:54:55 +0530 | [diff] [blame] | 241 | void *saved_scan_cmd; |
Arun Khandavalli | 2476ef5 | 2016-04-26 20:19:43 +0530 | [diff] [blame] | 242 | void (*pbpf_get_offload_cb)(void *context, |
| 243 | struct sir_bpf_get_offload *); |
Peng Xu | 8fdaa49 | 2016-06-22 10:20:47 -0700 | [diff] [blame] | 244 | p2p_lo_callback p2p_lo_event_callback; |
| 245 | void *p2p_lo_event_context; |
Krishna Kumaar Natarajan | bbbf2ef | 2016-08-03 14:06:26 -0700 | [diff] [blame] | 246 | sme_send_oem_data_rsp_msg oem_data_rsp_callback; |
Padma, Santhosh Kumar | d7cc079 | 2016-06-28 18:54:12 +0530 | [diff] [blame^] | 247 | void (*encrypt_decrypt_cb)(void *, |
| 248 | struct sir_encrypt_decrypt_rsp_params *); |
Prakash Dhavali | 7090c5f | 2015-11-02 17:55:19 -0800 | [diff] [blame] | 249 | } tSmeStruct, *tpSmeStruct; |
| 250 | |
| 251 | #endif /* #if !defined( __SMEINTERNAL_H ) */ |