hw_ops.h revision 530abe195df6918d43c9381fd9a70b7e16d55036
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"
26#include "rx.h"
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
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
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
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
68static inline int
69wlcore_hw_prepare_read(struct wl1271 *wl, u32 rx_desc, u32 len)
70{
71	if (wl->ops->prepare_read)
72		return wl->ops->prepare_read(wl, rx_desc, len);
73
74	return 0;
75}
76
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
86static inline int wlcore_hw_tx_delayed_compl(struct wl1271 *wl)
87{
88	if (wl->ops->tx_delayed_compl)
89		return wl->ops->tx_delayed_compl(wl);
90
91	return 0;
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
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
109static inline u32
110wlcore_hw_sta_get_ap_rate_mask(struct wl1271 *wl, struct wl12xx_vif *wlvif)
111{
112	if (!wl->ops->sta_get_ap_rate_mask)
113		BUG_ON(1);
114
115	return wl->ops->sta_get_ap_rate_mask(wl, wlvif);
116}
117
118static inline int wlcore_identify_fw(struct wl1271 *wl)
119{
120	if (wl->ops->identify_fw)
121		return wl->ops->identify_fw(wl);
122
123	return 0;
124}
125
126static inline void
127wlcore_hw_set_tx_desc_csum(struct wl1271 *wl,
128			   struct wl1271_tx_hw_descr *desc,
129			   struct sk_buff *skb)
130{
131	if (!wl->ops->set_tx_desc_csum)
132		BUG_ON(1);
133
134	wl->ops->set_tx_desc_csum(wl, desc, skb);
135}
136
137static inline void
138wlcore_hw_set_rx_csum(struct wl1271 *wl,
139		      struct wl1271_rx_descriptor *desc,
140		      struct sk_buff *skb)
141{
142	if (wl->ops->set_rx_csum)
143		wl->ops->set_rx_csum(wl, desc, skb);
144}
145
146static inline u32
147wlcore_hw_ap_get_mimo_wide_rate_mask(struct wl1271 *wl,
148				     struct wl12xx_vif *wlvif)
149{
150	if (wl->ops->ap_get_mimo_wide_rate_mask)
151		return wl->ops->ap_get_mimo_wide_rate_mask(wl, wlvif);
152
153	return 0;
154}
155
156static inline int
157wlcore_debugfs_init(struct wl1271 *wl, struct dentry *rootdir)
158{
159	if (wl->ops->debugfs_init)
160		return wl->ops->debugfs_init(wl, rootdir);
161
162	return 0;
163}
164
165static inline int
166wlcore_handle_static_data(struct wl1271 *wl, void *static_data)
167{
168	if (wl->ops->handle_static_data)
169		return wl->ops->handle_static_data(wl, static_data);
170
171	return 0;
172}
173
174static inline int
175wlcore_hw_get_spare_blocks(struct wl1271 *wl, bool is_gem)
176{
177	if (!wl->ops->get_spare_blocks)
178		BUG_ON(1);
179
180	return wl->ops->get_spare_blocks(wl, is_gem);
181}
182
183static inline int
184wlcore_hw_set_key(struct wl1271 *wl, enum set_key_cmd cmd,
185		  struct ieee80211_vif *vif,
186		  struct ieee80211_sta *sta,
187		  struct ieee80211_key_conf *key_conf)
188{
189	if (!wl->ops->set_key)
190		BUG_ON(1);
191
192	return wl->ops->set_key(wl, cmd, vif, sta, key_conf);
193}
194
195static inline u32
196wlcore_hw_pre_pkt_send(struct wl1271 *wl, u32 buf_offset, u32 last_len)
197{
198	if (wl->ops->pre_pkt_send)
199		return wl->ops->pre_pkt_send(wl, buf_offset, last_len);
200
201	return buf_offset;
202}
203
204static inline void
205wlcore_hw_sta_rc_update(struct wl1271 *wl, struct wl12xx_vif *wlvif,
206			struct ieee80211_sta *sta, u32 changed)
207{
208	if (wl->ops->sta_rc_update)
209		wl->ops->sta_rc_update(wl, wlvif, sta, changed);
210}
211
212static inline int
213wlcore_hw_set_peer_cap(struct wl1271 *wl,
214		       struct ieee80211_sta_ht_cap *ht_cap,
215		       bool allow_ht_operation,
216		       u32 rate_set, u8 hlid)
217{
218	if (wl->ops->set_peer_cap)
219		return wl->ops->set_peer_cap(wl, ht_cap, allow_ht_operation,
220					     rate_set, hlid);
221
222	return 0;
223}
224
225#endif
226