wl18xx: add radar detection implementation
[deliverable/linux.git] / drivers / net / wireless / ti / wlcore / hw_ops.h
CommitLineData
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
28static inline u32
29wlcore_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
37static inline void
38wlcore_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
47static inline void
48wlcore_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
58static inline enum wl_rx_buf_align
59wlcore_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 68static inline int
b14684a0
LC
69wlcore_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
77static inline u32
78wlcore_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 86static 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
94static 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
100static inline int
101wlcore_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
109static inline void
110wlcore_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
118static inline u32
119wlcore_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
127static 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
135static inline void
136wlcore_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
146static inline void
147wlcore_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
155static inline u32
156wlcore_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
165static inline int
166wlcore_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
174static inline int
175wlcore_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
183static inline int
184wlcore_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
192static inline int
193wlcore_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
204static inline u32
205wlcore_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 213static inline void
7d3b29e5 214wlcore_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
220static inline int
221wlcore_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
228static inline int
229wlcore_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
236static inline int
237wlcore_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
245static inline int
246wlcore_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
258static inline u32
259wlcore_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
267static inline bool
268wlcore_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
277static inline bool
278wlcore_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
287static inline int
288wlcore_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
296static inline int
297wlcore_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
305static inline int
306wlcore_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
315static inline int
316wlcore_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
This page took 0.223855 seconds and 5 git commands to generate.