Commit | Line | Data |
---|---|---|
b3b4b4b8 AN |
1 | /* |
2 | * This file is part of wlcore | |
3 | * | |
4 | * Copyright (C) 2011 Texas Instruments Inc. | |
5 | * | |
6 | * This program is free software; you can redistribute it and/or | |
7 | * modify it under the terms of the GNU General Public License | |
8 | * version 2 as published by the Free Software Foundation. | |
9 | * | |
10 | * This program is distributed in the hope that it will be useful, but | |
11 | * WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
13 | * General Public License for more details. | |
14 | * | |
15 | * You should have received a copy of the GNU General Public License | |
16 | * along with this program; if not, write to the Free Software | |
17 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | |
18 | * 02110-1301 USA | |
19 | * | |
20 | */ | |
21 | ||
22 | #ifndef __WLCORE_HW_OPS_H__ | |
23 | #define __WLCORE_HW_OPS_H__ | |
24 | ||
25 | #include "wlcore.h" | |
cd70f6a4 | 26 | #include "rx.h" |
b3b4b4b8 AN |
27 | |
28 | static inline u32 | |
29 | wlcore_hw_calc_tx_blocks(struct wl1271 *wl, u32 len, u32 spare_blks) | |
30 | { | |
31 | if (!wl->ops->calc_tx_blocks) | |
32 | BUG_ON(1); | |
33 | ||
34 | return wl->ops->calc_tx_blocks(wl, len, spare_blks); | |
35 | } | |
36 | ||
4a3b97ee AN |
37 | static inline void |
38 | wlcore_hw_set_tx_desc_blocks(struct wl1271 *wl, struct wl1271_tx_hw_descr *desc, | |
39 | u32 blks, u32 spare_blks) | |
40 | { | |
41 | if (!wl->ops->set_tx_desc_blocks) | |
42 | BUG_ON(1); | |
43 | ||
44 | return wl->ops->set_tx_desc_blocks(wl, desc, blks, spare_blks); | |
45 | } | |
46 | ||
6f266e91 AN |
47 | static inline void |
48 | wlcore_hw_set_tx_desc_data_len(struct wl1271 *wl, | |
49 | struct wl1271_tx_hw_descr *desc, | |
50 | struct sk_buff *skb) | |
51 | { | |
52 | if (!wl->ops->set_tx_desc_data_len) | |
53 | BUG_ON(1); | |
54 | ||
55 | wl->ops->set_tx_desc_data_len(wl, desc, skb); | |
56 | } | |
57 | ||
cd70f6a4 AN |
58 | static inline enum wl_rx_buf_align |
59 | wlcore_hw_get_rx_buf_align(struct wl1271 *wl, u32 rx_desc) | |
60 | { | |
61 | ||
62 | if (!wl->ops->get_rx_buf_align) | |
63 | BUG_ON(1); | |
64 | ||
65 | return wl->ops->get_rx_buf_align(wl, rx_desc); | |
66 | } | |
67 | ||
eb96f841 | 68 | static inline int |
b14684a0 LC |
69 | wlcore_hw_prepare_read(struct wl1271 *wl, u32 rx_desc, u32 len) |
70 | { | |
71 | if (wl->ops->prepare_read) | |
eb96f841 IY |
72 | return wl->ops->prepare_read(wl, rx_desc, len); |
73 | ||
74 | return 0; | |
b14684a0 LC |
75 | } |
76 | ||
4158149c AN |
77 | static inline u32 |
78 | wlcore_hw_get_rx_packet_len(struct wl1271 *wl, void *rx_data, u32 data_len) | |
79 | { | |
80 | if (!wl->ops->get_rx_packet_len) | |
81 | BUG_ON(1); | |
82 | ||
83 | return wl->ops->get_rx_packet_len(wl, rx_data, data_len); | |
84 | } | |
85 | ||
045b9b5f | 86 | static inline int wlcore_hw_tx_delayed_compl(struct wl1271 *wl) |
53d67a50 AN |
87 | { |
88 | if (wl->ops->tx_delayed_compl) | |
045b9b5f IY |
89 | return wl->ops->tx_delayed_compl(wl); |
90 | ||
91 | return 0; | |
53d67a50 AN |
92 | } |
93 | ||
94 | static inline void wlcore_hw_tx_immediate_compl(struct wl1271 *wl) | |
95 | { | |
96 | if (wl->ops->tx_immediate_compl) | |
97 | wl->ops->tx_immediate_compl(wl); | |
98 | } | |
99 | ||
8a9affc0 AN |
100 | static inline int |
101 | wlcore_hw_init_vif(struct wl1271 *wl, struct wl12xx_vif *wlvif) | |
102 | { | |
103 | if (wl->ops->init_vif) | |
104 | return wl->ops->init_vif(wl, wlvif); | |
105 | ||
106 | return 0; | |
107 | } | |
108 | ||
75fb4df7 EP |
109 | static inline void |
110 | wlcore_hw_convert_fw_status(struct wl1271 *wl, void *raw_fw_status, | |
111 | struct wl_fw_status *fw_status) | |
112 | { | |
113 | BUG_ON(!wl->ops->convert_fw_status); | |
114 | ||
115 | wl->ops->convert_fw_status(wl, raw_fw_status, fw_status); | |
116 | } | |
117 | ||
fa7930af AN |
118 | static inline u32 |
119 | wlcore_hw_sta_get_ap_rate_mask(struct wl1271 *wl, struct wl12xx_vif *wlvif) | |
120 | { | |
121 | if (!wl->ops->sta_get_ap_rate_mask) | |
122 | BUG_ON(1); | |
123 | ||
124 | return wl->ops->sta_get_ap_rate_mask(wl, wlvif); | |
125 | } | |
126 | ||
80cd6610 LC |
127 | static inline int wlcore_identify_fw(struct wl1271 *wl) |
128 | { | |
129 | if (wl->ops->identify_fw) | |
130 | return wl->ops->identify_fw(wl); | |
131 | ||
132 | return 0; | |
133 | } | |
134 | ||
2fc28de5 AN |
135 | static inline void |
136 | wlcore_hw_set_tx_desc_csum(struct wl1271 *wl, | |
137 | struct wl1271_tx_hw_descr *desc, | |
138 | struct sk_buff *skb) | |
139 | { | |
140 | if (!wl->ops->set_tx_desc_csum) | |
141 | BUG_ON(1); | |
142 | ||
143 | wl->ops->set_tx_desc_csum(wl, desc, skb); | |
144 | } | |
145 | ||
169da04f AN |
146 | static inline void |
147 | wlcore_hw_set_rx_csum(struct wl1271 *wl, | |
148 | struct wl1271_rx_descriptor *desc, | |
149 | struct sk_buff *skb) | |
150 | { | |
151 | if (wl->ops->set_rx_csum) | |
152 | wl->ops->set_rx_csum(wl, desc, skb); | |
153 | } | |
154 | ||
ebc7e57d AN |
155 | static inline u32 |
156 | wlcore_hw_ap_get_mimo_wide_rate_mask(struct wl1271 *wl, | |
157 | struct wl12xx_vif *wlvif) | |
158 | { | |
159 | if (wl->ops->ap_get_mimo_wide_rate_mask) | |
160 | return wl->ops->ap_get_mimo_wide_rate_mask(wl, wlvif); | |
161 | ||
162 | return 0; | |
163 | } | |
164 | ||
4987257c LC |
165 | static inline int |
166 | wlcore_debugfs_init(struct wl1271 *wl, struct dentry *rootdir) | |
167 | { | |
168 | if (wl->ops->debugfs_init) | |
169 | return wl->ops->debugfs_init(wl, rootdir); | |
170 | ||
171 | return 0; | |
172 | } | |
173 | ||
7140df6e LC |
174 | static inline int |
175 | wlcore_handle_static_data(struct wl1271 *wl, void *static_data) | |
176 | { | |
177 | if (wl->ops->handle_static_data) | |
178 | return wl->ops->handle_static_data(wl, static_data); | |
179 | ||
180 | return 0; | |
181 | } | |
182 | ||
32bb2c03 AN |
183 | static inline int |
184 | wlcore_hw_get_spare_blocks(struct wl1271 *wl, bool is_gem) | |
185 | { | |
186 | if (!wl->ops->get_spare_blocks) | |
187 | BUG_ON(1); | |
188 | ||
189 | return wl->ops->get_spare_blocks(wl, is_gem); | |
190 | } | |
191 | ||
a1c597f2 AN |
192 | static inline int |
193 | wlcore_hw_set_key(struct wl1271 *wl, enum set_key_cmd cmd, | |
194 | struct ieee80211_vif *vif, | |
195 | struct ieee80211_sta *sta, | |
196 | struct ieee80211_key_conf *key_conf) | |
197 | { | |
198 | if (!wl->ops->set_key) | |
199 | BUG_ON(1); | |
200 | ||
201 | return wl->ops->set_key(wl, cmd, vif, sta, key_conf); | |
202 | } | |
203 | ||
9fccc82e IR |
204 | static inline u32 |
205 | wlcore_hw_pre_pkt_send(struct wl1271 *wl, u32 buf_offset, u32 last_len) | |
206 | { | |
207 | if (wl->ops->pre_pkt_send) | |
208 | return wl->ops->pre_pkt_send(wl, buf_offset, last_len); | |
209 | ||
210 | return buf_offset; | |
211 | } | |
212 | ||
5f9b6777 | 213 | static inline void |
7d3b29e5 | 214 | wlcore_hw_sta_rc_update(struct wl1271 *wl, struct wl12xx_vif *wlvif) |
5f9b6777 AN |
215 | { |
216 | if (wl->ops->sta_rc_update) | |
7d3b29e5 | 217 | wl->ops->sta_rc_update(wl, wlvif); |
5f9b6777 AN |
218 | } |
219 | ||
6d5a748d RA |
220 | static inline int |
221 | wlcore_hw_interrupt_notify(struct wl1271 *wl, bool action) | |
222 | { | |
223 | if (wl->ops->interrupt_notify) | |
224 | return wl->ops->interrupt_notify(wl, action); | |
225 | return 0; | |
226 | } | |
227 | ||
228 | static inline int | |
229 | wlcore_hw_rx_ba_filter(struct wl1271 *wl, bool action) | |
230 | { | |
231 | if (wl->ops->rx_ba_filter) | |
232 | return wl->ops->rx_ba_filter(wl, action); | |
233 | return 0; | |
234 | } | |
235 | ||
e2f1e50f K |
236 | static inline int |
237 | wlcore_hw_ap_sleep(struct wl1271 *wl) | |
238 | { | |
239 | if (wl->ops->ap_sleep) | |
240 | return wl->ops->ap_sleep(wl); | |
241 | ||
242 | return 0; | |
243 | } | |
244 | ||
530abe19 EP |
245 | static inline int |
246 | wlcore_hw_set_peer_cap(struct wl1271 *wl, | |
247 | struct ieee80211_sta_ht_cap *ht_cap, | |
248 | bool allow_ht_operation, | |
249 | u32 rate_set, u8 hlid) | |
250 | { | |
251 | if (wl->ops->set_peer_cap) | |
252 | return wl->ops->set_peer_cap(wl, ht_cap, allow_ht_operation, | |
253 | rate_set, hlid); | |
254 | ||
255 | return 0; | |
256 | } | |
257 | ||
c83cb803 IC |
258 | static inline u32 |
259 | wlcore_hw_convert_hwaddr(struct wl1271 *wl, u32 hwaddr) | |
260 | { | |
261 | if (!wl->ops->convert_hwaddr) | |
262 | BUG_ON(1); | |
263 | ||
264 | return wl->ops->convert_hwaddr(wl, hwaddr); | |
265 | } | |
266 | ||
f1626fd8 AN |
267 | static inline bool |
268 | wlcore_hw_lnk_high_prio(struct wl1271 *wl, u8 hlid, | |
269 | struct wl1271_link *lnk) | |
270 | { | |
271 | if (!wl->ops->lnk_high_prio) | |
272 | BUG_ON(1); | |
273 | ||
274 | return wl->ops->lnk_high_prio(wl, hlid, lnk); | |
275 | } | |
276 | ||
277 | static inline bool | |
278 | wlcore_hw_lnk_low_prio(struct wl1271 *wl, u8 hlid, | |
279 | struct wl1271_link *lnk) | |
280 | { | |
281 | if (!wl->ops->lnk_low_prio) | |
282 | BUG_ON(1); | |
283 | ||
284 | return wl->ops->lnk_low_prio(wl, hlid, lnk); | |
285 | } | |
286 | ||
ccb1df94 EP |
287 | static inline int |
288 | wlcore_smart_config_start(struct wl1271 *wl, u32 group_bitmap) | |
289 | { | |
290 | if (!wl->ops->smart_config_start) | |
291 | return -EINVAL; | |
292 | ||
293 | return wl->ops->smart_config_start(wl, group_bitmap); | |
294 | } | |
295 | ||
296 | static inline int | |
297 | wlcore_smart_config_stop(struct wl1271 *wl) | |
298 | { | |
299 | if (!wl->ops->smart_config_stop) | |
300 | return -EINVAL; | |
301 | ||
302 | return wl->ops->smart_config_stop(wl); | |
303 | } | |
304 | ||
305 | static inline int | |
306 | wlcore_smart_config_set_group_key(struct wl1271 *wl, u16 group_id, | |
307 | u8 key_len, u8 *key) | |
308 | { | |
309 | if (!wl->ops->smart_config_set_group_key) | |
310 | return -EINVAL; | |
311 | ||
312 | return wl->ops->smart_config_set_group_key(wl, group_id, key_len, key); | |
313 | } | |
750e9d15 EP |
314 | |
315 | static inline int | |
316 | wlcore_hw_set_cac(struct wl1271 *wl, struct wl12xx_vif *wlvif, bool start) | |
317 | { | |
318 | if (!wl->ops->set_cac) | |
319 | return -EINVAL; | |
320 | ||
321 | return wl->ops->set_cac(wl, wlvif, start); | |
322 | } | |
b3b4b4b8 | 323 | #endif |