blob: 8361f9e3995bfef0ec7034796a5a95841d043ca3 [file] [log] [blame]
Eugene Krasnikov8e84c252013-10-08 21:25:58 +01001/*
2 * Copyright (c) 2013 Eugene Krasnikov <k.eugene.e@gmail.com>
3 *
4 * Permission to use, copy, modify, and/or distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
7 *
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
11 * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
13 * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
14 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15 */
16
17#ifndef _SMD_H_
18#define _SMD_H_
19
20#include "wcn36xx.h"
21
22/* Max shared size is 4k but we take less.*/
23#define WCN36XX_NV_FRAGMENT_SIZE 3072
24
25#define WCN36XX_HAL_BUF_SIZE 4096
26
Pontus Fuchs546c5052014-02-12 19:04:42 +000027#define HAL_MSG_TIMEOUT 500
Eugene Krasnikov8e84c252013-10-08 21:25:58 +010028#define WCN36XX_SMSM_WLAN_TX_ENABLE 0x00000400
29#define WCN36XX_SMSM_WLAN_TX_RINGS_EMPTY 0x00000200
30/* The PNO version info be contained in the rsp msg */
31#define WCN36XX_FW_MSG_PNO_VERSION_MASK 0x8000
32
33enum wcn36xx_fw_msg_result {
34 WCN36XX_FW_MSG_RESULT_SUCCESS = 0,
35 WCN36XX_FW_MSG_RESULT_SUCCESS_SYNC = 1,
36
37 WCN36XX_FW_MSG_RESULT_MEM_FAIL = 5,
38};
39
40/******************************/
41/* SMD requests and responses */
42/******************************/
43struct wcn36xx_fw_msg_status_rsp {
44 u32 status;
45} __packed;
46
Andy Green40ac77c2015-11-10 03:25:53 -050047/* wcn3620 returns this for tigger_ba */
48
49struct wcn36xx_fw_msg_status_rsp_v2 {
50 u8 bss_id[6];
51 u32 status __packed;
52 u16 count_following_candidates __packed;
53 /* candidate list follows */
54};
55
Eugene Krasnikov8e84c252013-10-08 21:25:58 +010056struct wcn36xx_hal_ind_msg {
57 struct list_head list;
58 u8 *msg;
59 size_t msg_len;
60};
61
62struct wcn36xx;
63
64int wcn36xx_smd_open(struct wcn36xx *wcn);
65void wcn36xx_smd_close(struct wcn36xx *wcn);
66
67int wcn36xx_smd_load_nv(struct wcn36xx *wcn);
68int wcn36xx_smd_start(struct wcn36xx *wcn);
69int wcn36xx_smd_stop(struct wcn36xx *wcn);
70int wcn36xx_smd_init_scan(struct wcn36xx *wcn, enum wcn36xx_hal_sys_mode mode);
71int wcn36xx_smd_start_scan(struct wcn36xx *wcn);
72int wcn36xx_smd_end_scan(struct wcn36xx *wcn);
73int wcn36xx_smd_finish_scan(struct wcn36xx *wcn,
74 enum wcn36xx_hal_sys_mode mode);
75int wcn36xx_smd_update_scan_params(struct wcn36xx *wcn);
76int wcn36xx_smd_add_sta_self(struct wcn36xx *wcn, struct ieee80211_vif *vif);
77int wcn36xx_smd_delete_sta_self(struct wcn36xx *wcn, u8 *addr);
78int wcn36xx_smd_delete_sta(struct wcn36xx *wcn, u8 sta_index);
79int wcn36xx_smd_join(struct wcn36xx *wcn, const u8 *bssid, u8 *vif, u8 ch);
80int wcn36xx_smd_set_link_st(struct wcn36xx *wcn, const u8 *bssid,
81 const u8 *sta_mac,
82 enum wcn36xx_hal_link_state state);
83int wcn36xx_smd_config_bss(struct wcn36xx *wcn, struct ieee80211_vif *vif,
84 struct ieee80211_sta *sta, const u8 *bssid,
85 bool update);
86int wcn36xx_smd_delete_bss(struct wcn36xx *wcn, struct ieee80211_vif *vif);
87int wcn36xx_smd_config_sta(struct wcn36xx *wcn, struct ieee80211_vif *vif,
88 struct ieee80211_sta *sta);
89int wcn36xx_smd_send_beacon(struct wcn36xx *wcn, struct ieee80211_vif *vif,
90 struct sk_buff *skb_beacon, u16 tim_off,
91 u16 p2p_off);
92int wcn36xx_smd_switch_channel(struct wcn36xx *wcn,
93 struct ieee80211_vif *vif, int ch);
94int wcn36xx_smd_update_proberesp_tmpl(struct wcn36xx *wcn,
95 struct ieee80211_vif *vif,
96 struct sk_buff *skb);
97int wcn36xx_smd_set_stakey(struct wcn36xx *wcn,
98 enum ani_ed_type enc_type,
99 u8 keyidx,
100 u8 keylen,
101 u8 *key,
102 u8 sta_index);
103int wcn36xx_smd_set_bsskey(struct wcn36xx *wcn,
104 enum ani_ed_type enc_type,
105 u8 keyidx,
106 u8 keylen,
107 u8 *key);
108int wcn36xx_smd_remove_stakey(struct wcn36xx *wcn,
109 enum ani_ed_type enc_type,
110 u8 keyidx,
111 u8 sta_index);
112int wcn36xx_smd_remove_bsskey(struct wcn36xx *wcn,
113 enum ani_ed_type enc_type,
114 u8 keyidx);
115int wcn36xx_smd_enter_bmps(struct wcn36xx *wcn, struct ieee80211_vif *vif);
116int wcn36xx_smd_exit_bmps(struct wcn36xx *wcn, struct ieee80211_vif *vif);
117int wcn36xx_smd_set_power_params(struct wcn36xx *wcn, bool ignore_dtim);
118int wcn36xx_smd_keep_alive_req(struct wcn36xx *wcn,
119 struct ieee80211_vif *vif,
120 int packet_type);
121int wcn36xx_smd_dump_cmd_req(struct wcn36xx *wcn, u32 arg1, u32 arg2,
122 u32 arg3, u32 arg4, u32 arg5);
123int wcn36xx_smd_feature_caps_exchange(struct wcn36xx *wcn);
Pontus Fuchs2be66362014-02-12 19:04:44 +0000124void set_feat_caps(u32 *bitmap, enum place_holder_in_cap_bitmap cap);
125int get_feat_caps(u32 *bitmap, enum place_holder_in_cap_bitmap cap);
126void clear_feat_caps(u32 *bitmap, enum place_holder_in_cap_bitmap cap);
Eugene Krasnikov8e84c252013-10-08 21:25:58 +0100127
128int wcn36xx_smd_add_ba_session(struct wcn36xx *wcn,
129 struct ieee80211_sta *sta,
130 u16 tid,
131 u16 *ssn,
132 u8 direction,
133 u8 sta_index);
134int wcn36xx_smd_add_ba(struct wcn36xx *wcn);
135int wcn36xx_smd_del_ba(struct wcn36xx *wcn, u16 tid, u8 sta_index);
136int wcn36xx_smd_trigger_ba(struct wcn36xx *wcn, u8 sta_index);
137
138int wcn36xx_smd_update_cfg(struct wcn36xx *wcn, u32 cfg_id, u32 value);
139#endif /* _SMD_H_ */