blob: 5aa57a7639bfe3fd76e3ca888f78d7ec96036c80 [file] [log] [blame]
Kalle Valobdcd8172011-07-18 00:22:30 +03001/*
2 * Copyright (c) 2011 Atheros Communications Inc.
Vasanthakumar Thiagarajan1b2df402012-02-06 20:15:53 +05303 * Copyright (c) 2011-2012 Qualcomm Atheros, Inc.
Kalle Valobdcd8172011-07-18 00:22:30 +03004 *
5 * Permission to use, copy, modify, and/or distribute this software for any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
8 *
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16 */
17
18#ifndef ATH6KL_CFG80211_H
19#define ATH6KL_CFG80211_H
20
Kalle Valo52d81a62011-11-01 08:44:21 +020021enum ath6kl_cfg_suspend_mode {
22 ATH6KL_CFG_SUSPEND_DEEPSLEEP,
Kalle Valob4b2a0b2011-11-01 08:44:44 +020023 ATH6KL_CFG_SUSPEND_CUTPOWER,
Kalle Valo10509f92011-12-13 14:52:07 +020024 ATH6KL_CFG_SUSPEND_WOW,
Kalle Valo52d81a62011-11-01 08:44:21 +020025};
26
Johannes Berg552bff02012-09-19 09:26:06 +020027struct wireless_dev *ath6kl_interface_add(struct ath6kl *ar, const char *name,
Tom Gundersen6bab2e192015-03-18 11:13:39 +010028 unsigned char name_assign_type,
Johannes Berg84efbb82012-06-16 00:00:26 +020029 enum nl80211_iftype type,
30 u8 fw_vif_idx, u8 nw_type);
Thomas Pedersenc4f78632012-04-06 13:35:48 -070031void ath6kl_cfg80211_ch_switch_notify(struct ath6kl_vif *vif, int freq,
32 enum wmi_phy_mode mode);
Kalle Valo1c17d312011-11-01 08:43:56 +020033void ath6kl_cfg80211_scan_complete_event(struct ath6kl_vif *vif, bool aborted);
Kalle Valobdcd8172011-07-18 00:22:30 +030034
Vasanthakumar Thiagarajan240d2792011-10-25 19:34:13 +053035void ath6kl_cfg80211_connect_event(struct ath6kl_vif *vif, u16 channel,
Kalle Valobdcd8172011-07-18 00:22:30 +030036 u8 *bssid, u16 listen_intvl,
37 u16 beacon_intvl,
38 enum network_type nw_type,
39 u8 beacon_ie_len, u8 assoc_req_len,
40 u8 assoc_resp_len, u8 *assoc_info);
41
Vasanthakumar Thiagarajan240d2792011-10-25 19:34:13 +053042void ath6kl_cfg80211_disconnect_event(struct ath6kl_vif *vif, u8 reason,
Kalle Valobdcd8172011-07-18 00:22:30 +030043 u8 *bssid, u8 assoc_resp_len,
44 u8 *assoc_info, u16 proto_reason);
45
Vasanthakumar Thiagarajan240d2792011-10-25 19:34:13 +053046void ath6kl_cfg80211_tkip_micerr_event(struct ath6kl_vif *vif, u8 keyid,
Kalle Valobdcd8172011-07-18 00:22:30 +030047 bool ismcast);
48
Kalle Valo52d81a62011-11-01 08:44:21 +020049int ath6kl_cfg80211_suspend(struct ath6kl *ar,
Raja Mani0f60e9f2011-11-07 22:52:45 +020050 enum ath6kl_cfg_suspend_mode mode,
51 struct cfg80211_wowlan *wow);
52
Kalle Valo52d81a62011-11-01 08:44:21 +020053int ath6kl_cfg80211_resume(struct ath6kl *ar);
54
Kalle Valoc25889e2012-01-17 20:08:27 +020055void ath6kl_cfg80211_vif_cleanup(struct ath6kl_vif *vif);
56
Kalle Valo7125f012011-12-13 14:51:37 +020057void ath6kl_cfg80211_stop(struct ath6kl_vif *vif);
58void ath6kl_cfg80211_stop_all(struct ath6kl *ar);
Kalle Valoec4b7f62011-11-01 08:44:04 +020059
Kalle Valo46d33a22012-01-17 20:08:40 +020060int ath6kl_cfg80211_init(struct ath6kl *ar);
61void ath6kl_cfg80211_cleanup(struct ath6kl *ar);
62
Kalle Valo45eaa782012-01-17 20:09:05 +020063struct ath6kl *ath6kl_cfg80211_create(void);
64void ath6kl_cfg80211_destroy(struct ath6kl *ar);
65
Kalle Valobdcd8172011-07-18 00:22:30 +030066#endif /* ATH6KL_CFG80211_H */