blob: ba2f938ef83ac78802d458f9c09b34aea24d8054 [file] [log] [blame]
Gopichand Nakkalabd9fa2d2013-01-08 13:16:22 -08001/*
2 * Copyright (c) 2012-2013, The Linux Foundation. All rights reserved.
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 */
Kiran V1ccee932012-12-12 14:49:46 -080021#ifndef __HDD_TDSL_H
22#define __HDD_TDSL_H
23/**===========================================================================
24
25\file wlan_hdd_tdls.h
26
27\brief Linux HDD TDLS include file
Gopichand Nakkala0c1331e2013-01-07 22:49:07 -080028
Kiran V1ccee932012-12-12 14:49:46 -080029==========================================================================*/
30
Chilam NG571c65a2013-01-19 12:27:36 +053031#define MAX_NUM_TDLS_PEER 3
Kiran V1ccee932012-12-12 14:49:46 -080032
Gopichand Nakkalac3694582013-02-13 20:51:22 -080033#define TDLS_SUB_DISCOVERY_PERIOD 100
34
35#define TDLS_MAX_DISCOVER_REQS_PER_TIMER 1
Kiran V1ccee932012-12-12 14:49:46 -080036
Chilam NG571c65a2013-01-19 12:27:36 +053037#define TDLS_DISCOVERY_PERIOD 3600000
Kiran V1ccee932012-12-12 14:49:46 -080038
Chilam NG571c65a2013-01-19 12:27:36 +053039#define TDLS_TX_STATS_PERIOD 3600000
40
41#define TDLS_IMPLICIT_TRIGGER_PKT_THRESHOLD 100
42
43#define TDLS_RX_IDLE_TIMEOUT 5000
44
45#define TDLS_RSSI_TRIGGER_HYSTERESIS 50
46
Gopichand Nakkalaccd3a382013-03-19 13:56:10 -070047/* before UpdateTimer expires, we want to timeout discovery response.
48should not be more than 2000 */
49#define TDLS_DISCOVERY_TIMEOUT_BEFORE_UPDATE 1000
Gopichand Nakkala75e7b282013-03-15 18:37:13 -070050
Hoonki Lee93e67ff2013-03-19 15:49:25 -070051#define TDLS_CTX_MAGIC 0x54444c53 // "TDLS"
52
53#define TDLS_MAX_SCAN_SCHEDULE 10
54#define TDLS_DELAY_SCAN_PER_CONNECTION 100
55
Gopichand Nakkalae7cbc5d2013-03-27 21:09:23 -070056#define TDLS_IS_CONNECTED(peer) \
57 ((eTDLS_LINK_CONNECTED == (peer)->link_status) || \
58 (eTDLS_LINK_TEARING == (peer)->link_status))
Chilam NG571c65a2013-01-19 12:27:36 +053059typedef struct
60{
Chilam Ng01120412013-02-19 18:32:21 -080061 tANI_U32 tdls;
Chilam NG571c65a2013-01-19 12:27:36 +053062 tANI_U32 tx_period_t;
63 tANI_U32 tx_packet_n;
64 tANI_U32 discovery_period_t;
65 tANI_U32 discovery_tries_n;
Chilam Ng01120412013-02-19 18:32:21 -080066 tANI_U32 idle_timeout_t;
67 tANI_U32 idle_packet_n;
Chilam NG571c65a2013-01-19 12:27:36 +053068 tANI_U32 rssi_hysteresis;
Chilam Ng01120412013-02-19 18:32:21 -080069 tANI_S32 rssi_trigger_threshold;
70 tANI_S32 rssi_teardown_threshold;
Chilam NG571c65a2013-01-19 12:27:36 +053071} tdls_config_params_t;
72
Hoonki Lee93e67ff2013-03-19 15:49:25 -070073typedef struct
74{
75 struct wiphy *wiphy;
76#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,6,0))
77 struct net_device *dev;
78#endif
79 struct cfg80211_scan_request *scan_request;
80 int magic;
81 int attempt;
82 struct delayed_work tdls_scan_work;
83} tdls_scan_context_t;
84
Chilam NG571c65a2013-01-19 12:27:36 +053085typedef enum {
Hoonki Lee27511902013-03-14 18:19:06 -070086 eTDLS_SUPPORT_NOT_ENABLED = 0,
87 eTDLS_SUPPORT_DISABLED, /* suppress implicit trigger and not respond to the peer */
88 eTDLS_SUPPORT_EXPLICIT_TRIGGER_ONLY, /* suppress implicit trigger, but respond to the peer */
89 eTDLS_SUPPORT_ENABLED, /* implicit trigger */
Chilam Ng01120412013-02-19 18:32:21 -080090} eTDLSSupportMode;
91
Gopichand Nakkala901e8922013-03-04 23:45:58 -080092typedef enum eTDLSCapType{
Chilam NG571c65a2013-01-19 12:27:36 +053093 eTDLS_CAP_NOT_SUPPORTED = -1,
94 eTDLS_CAP_UNKNOWN = 0,
95 eTDLS_CAP_SUPPORTED = 1,
Gopichand Nakkala901e8922013-03-04 23:45:58 -080096} tTDLSCapType;
Chilam NG571c65a2013-01-19 12:27:36 +053097
Gopichand Nakkala901e8922013-03-04 23:45:58 -080098typedef enum eTDLSLinkStatus {
99 eTDLS_LINK_IDLE = 0,
100 eTDLS_LINK_DISCOVERING,
Gopichand Nakkala05922802013-03-14 12:23:19 -0700101 eTDLS_LINK_DISCOVERED,
Gopichand Nakkala901e8922013-03-04 23:45:58 -0800102 eTDLS_LINK_CONNECTING,
103 eTDLS_LINK_CONNECTED,
Gopichand Nakkalae7cbc5d2013-03-27 21:09:23 -0700104 eTDLS_LINK_TEARING,
Gopichand Nakkala901e8922013-03-04 23:45:58 -0800105} tTDLSLinkStatus;
Chilam NG571c65a2013-01-19 12:27:36 +0530106
107typedef struct {
108 tANI_U16 period;
109 tANI_U16 bytes;
110} tdls_tx_tput_config_t;
111
112typedef struct {
113 tANI_U16 period;
114 tANI_U16 tries;
115} tdls_discovery_config_t;
116
117typedef struct {
118 tANI_U16 timeout;
119} tdls_rx_idle_config_t;
120
121typedef struct {
122 tANI_U16 rssi_thres;
123} tdls_rssi_config_t;
124
Hoonki Lee387663d2013-02-05 18:08:43 -0800125typedef struct {
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800126 struct list_head peer_list[256];
127 hdd_adapter_t *pAdapter;
128 vos_timer_t peerDiscoverTimer;
129 vos_timer_t peerUpdateTimer;
Gopichand Nakkala75e7b282013-03-15 18:37:13 -0700130 vos_timer_t peerDiscoveryTimeoutTimer;
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800131 tdls_config_params_t threshold_config;
132 tANI_S32 discovery_peer_cnt;
Gopichand Nakkala75e7b282013-03-15 18:37:13 -0700133 tANI_U32 discovery_sent_cnt;
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800134 tANI_S8 ap_rssi;
135} tdlsCtx_t;
136
137typedef struct {
Hoonki Lee387663d2013-02-05 18:08:43 -0800138 struct list_head node;
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800139 tdlsCtx_t *pHddTdlsCtx;
Hoonki Lee387663d2013-02-05 18:08:43 -0800140 tSirMacAddr peerMac;
141 tANI_U16 staId ;
142 tANI_S8 rssi;
Gopichand Nakkala901e8922013-03-04 23:45:58 -0800143 tTDLSCapType tdls_support;
144 tTDLSLinkStatus link_status;
Hoonki Lee11f7dda2013-02-14 16:55:44 -0800145 tANI_U8 signature;
Hoonki Leea34dd892013-02-05 22:56:02 -0800146 tANI_U8 is_responder;
Gopichand Nakkalac3694582013-02-13 20:51:22 -0800147 tANI_U8 discovery_processed;
Hoonki Lee387663d2013-02-05 18:08:43 -0800148 tANI_U16 discovery_attempt;
149 tANI_U16 tx_pkt;
150 tANI_U16 rx_pkt;
151 vos_timer_t peerIdleTimer;
152} hddTdlsPeer_t;
153
Hoonki Lee387663d2013-02-05 18:08:43 -0800154typedef struct {
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800155 /* Session ID */
156 tANI_U8 sessionId;
157 /*TDLS peer station id */
158 v_U8_t staId;
159 /* TDLS peer mac Address */
160 v_MACADDR_t peerMac;
161} tdlsConnInfo_t;
Chilam NG571c65a2013-01-19 12:27:36 +0530162
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800163int wlan_hdd_tdls_init(hdd_adapter_t *pAdapter);
Chilam NG571c65a2013-01-19 12:27:36 +0530164
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800165void wlan_hdd_tdls_exit(hdd_adapter_t *pAdapter);
Chilam NG571c65a2013-01-19 12:27:36 +0530166
Hoonki Lee387663d2013-02-05 18:08:43 -0800167void wlan_hdd_tdls_extract_da(struct sk_buff *skb, u8 *mac);
Chilam NG571c65a2013-01-19 12:27:36 +0530168
Hoonki Lee387663d2013-02-05 18:08:43 -0800169void wlan_hdd_tdls_extract_sa(struct sk_buff *skb, u8 *mac);
Chilam Ng1279e232013-01-25 15:06:52 -0800170
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800171int wlan_hdd_tdls_increment_pkt_count(hdd_adapter_t *pAdapter, u8 *mac, u8 tx);
Chilam NG571c65a2013-01-19 12:27:36 +0530172
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800173int wlan_hdd_tdls_set_sta_id(hdd_adapter_t *pAdapter, u8 *mac, u8 staId);
Chilam NG571c65a2013-01-19 12:27:36 +0530174
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800175hddTdlsPeer_t *wlan_hdd_tdls_find_peer(hdd_adapter_t *pAdapter, u8 *mac);
Chilam NG571c65a2013-01-19 12:27:36 +0530176
Hoonki Leea6d49be2013-04-05 09:43:25 -0700177hddTdlsPeer_t *wlan_hdd_tdls_find_all_peer(hdd_context_t *pHddCtx, u8 *mac);
178
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800179hddTdlsPeer_t *wlan_hdd_tdls_get_peer(hdd_adapter_t *pAdapter, u8 *mac);
Hoonki Lee387663d2013-02-05 18:08:43 -0800180
Gopichand Nakkala34d1b062013-03-19 15:28:33 -0700181int wlan_hdd_tdls_set_cap(hdd_adapter_t *pAdapter, u8* mac, tTDLSCapType cap);
Hoonki Lee27511902013-03-14 18:19:06 -0700182
Gopichand Nakkala8b00c632013-03-08 19:47:52 -0800183void wlan_hdd_tdls_set_peer_link_status(hddTdlsPeer_t *curr_peer, tTDLSLinkStatus status);
184
185void wlan_hdd_tdls_set_link_status(hdd_adapter_t *pAdapter, u8* mac, tTDLSLinkStatus status);
Chilam NG571c65a2013-01-19 12:27:36 +0530186
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800187int wlan_hdd_tdls_recv_discovery_resp(hdd_adapter_t *pAdapter, u8 *mac);
Chilam NG571c65a2013-01-19 12:27:36 +0530188
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800189int wlan_hdd_tdls_set_rssi(hdd_adapter_t *pAdapter, u8 *mac, tANI_S8 rxRssi);
Chilam NG571c65a2013-01-19 12:27:36 +0530190
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800191int wlan_hdd_tdls_set_responder(hdd_adapter_t *pAdapter, u8 *mac, tANI_U8 responder);
Hoonki Leea34dd892013-02-05 22:56:02 -0800192
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800193int wlan_hdd_tdls_get_responder(hdd_adapter_t *pAdapter, u8 *mac);
Hoonki Leea34dd892013-02-05 22:56:02 -0800194
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800195int wlan_hdd_tdls_set_signature(hdd_adapter_t *pAdapter, u8 *mac, tANI_U8 uSignature);
Hoonki Lee11f7dda2013-02-14 16:55:44 -0800196
Chilam Ng01120412013-02-19 18:32:21 -0800197int wlan_hdd_tdls_set_params(struct net_device *dev, tdls_config_params_t *config);
Chilam NG571c65a2013-01-19 12:27:36 +0530198
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800199int wlan_hdd_tdls_reset_peer(hdd_adapter_t *pAdapter, u8 *mac);
Hoonki Lee387663d2013-02-05 18:08:43 -0800200
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800201tANI_U16 wlan_hdd_tdlsConnectedPeers(hdd_adapter_t *pAdapter);
Lee Hoonkic1262f22013-01-24 21:59:00 -0800202
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800203int wlan_hdd_tdls_get_all_peers(hdd_adapter_t *pAdapter, char *buf, int buflen);
Chilam Ng16a2a1c2013-01-29 01:27:29 -0800204
Gopichand Nakkalac3694582013-02-13 20:51:22 -0800205void wlan_hdd_tdls_connection_callback(hdd_adapter_t *pAdapter);
206
207void wlan_hdd_tdls_disconnection_callback(hdd_adapter_t *pAdapter);
208
Gopichand Nakkalab977a972013-02-18 19:15:09 -0800209void wlan_hdd_tdls_mgmt_completion_callback(hdd_adapter_t *pAdapter, tANI_U32 statusCode);
210
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800211void wlan_hdd_tdls_increment_peer_count(hdd_adapter_t *pAdapter);
Gopichand Nakkalab977a972013-02-18 19:15:09 -0800212
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800213void wlan_hdd_tdls_decrement_peer_count(hdd_adapter_t *pAdapter);
Gopichand Nakkalab977a972013-02-18 19:15:09 -0800214
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800215void wlan_hdd_tdls_check_bmps(hdd_adapter_t *pAdapter);
Gopichand Nakkalab977a972013-02-18 19:15:09 -0800216
Gopichand Nakkala34d1b062013-03-19 15:28:33 -0700217u8 wlan_hdd_tdls_is_peer_progress(hdd_adapter_t *pAdapter, u8 *mac);
218
Gopichand Nakkala4327a152013-03-04 23:22:42 -0800219u8 wlan_hdd_tdls_is_progress(hdd_adapter_t *pAdapter, u8* mac, u8 skip_self);
Hoonki Lee387663d2013-02-05 18:08:43 -0800220
Gopichand Nakkaladcbcf4e2013-03-23 14:32:39 -0700221void wlan_hdd_tdls_set_mode(hdd_context_t *pHddCtx,
222 eTDLSSupportMode tdls_mode,
223 v_BOOL_t bUpdateLast);
Hoonki Lee27511902013-03-14 18:19:06 -0700224
Gopichand Nakkala75e7b282013-03-15 18:37:13 -0700225void wlan_hdd_tdls_pre_setup(tdlsCtx_t *pHddTdlsCtx, hddTdlsPeer_t *curr_peer);
226
Gopichand Nakkalaccd3a382013-03-19 13:56:10 -0700227tANI_U32 wlan_hdd_tdls_discovery_sent_cnt(hdd_context_t *pHddCtx);
228
Gopichand Nakkala34d1b062013-03-19 15:28:33 -0700229void wlan_hdd_tdls_check_power_save_prohibited(hdd_adapter_t *pAdapter);
Gopichand Nakkalaccd3a382013-03-19 13:56:10 -0700230
Hoonki Lee93e67ff2013-03-19 15:49:25 -0700231void wlan_hdd_tdls_free_scan_request (tdls_scan_context_t *tdls_scan_ctx);
232
233int wlan_hdd_tdls_copy_scan_context(hdd_context_t *pHddCtx,
234 struct wiphy *wiphy,
235#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,6,0))
236 struct net_device *dev,
237#endif
238 struct cfg80211_scan_request *request);
239
240int wlan_hdd_tdls_scan_callback (hdd_adapter_t *pAdapter,
241 struct wiphy *wiphy,
242#if (LINUX_VERSION_CODE < KERNEL_VERSION(3,6,0))
243 struct net_device *dev,
244#endif
245 struct cfg80211_scan_request *request);
246
247void wlan_hdd_tdls_scan_done_callback(hdd_adapter_t *pAdapter);
248
Gopichand Nakkala3046fc92013-03-23 13:56:43 -0700249void wlan_hdd_tdls_timer_restart(hdd_adapter_t *pAdapter,
250 vos_timer_t *timer,
251 v_U32_t expirationTime);
Gopichand Nakkalae7cbc5d2013-03-27 21:09:23 -0700252void wlan_hdd_tdls_indicate_teardown(hdd_adapter_t *pAdapter,
253 hddTdlsPeer_t *curr_peer,
254 tANI_U16 reason);
255
Gopichand Nakkala3046fc92013-03-23 13:56:43 -0700256
Kiran V1ccee932012-12-12 14:49:46 -0800257#endif // __HDD_TDSL_H