x86/xen: resume timer irqs early
[linux/fpc-iii.git] / drivers / net / wireless / ti / wlcore / hw_ops.h
blob7fd260c02a0a15aa2a0b8c92867a09fc9af96739
1 /*
2 * This file is part of wlcore
4 * Copyright (C) 2011 Texas Instruments Inc.
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.
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.
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
22 #ifndef __WLCORE_HW_OPS_H__
23 #define __WLCORE_HW_OPS_H__
25 #include "wlcore.h"
26 #include "rx.h"
28 static inline u32
29 wlcore_hw_calc_tx_blocks(struct wl1271 *wl, u32 len, u32 spare_blks)
31 if (!wl->ops->calc_tx_blocks)
32 BUG_ON(1);
34 return wl->ops->calc_tx_blocks(wl, len, spare_blks);
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)
41 if (!wl->ops->set_tx_desc_blocks)
42 BUG_ON(1);
44 return wl->ops->set_tx_desc_blocks(wl, desc, blks, spare_blks);
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)
52 if (!wl->ops->set_tx_desc_data_len)
53 BUG_ON(1);
55 wl->ops->set_tx_desc_data_len(wl, desc, skb);
58 static inline enum wl_rx_buf_align
59 wlcore_hw_get_rx_buf_align(struct wl1271 *wl, u32 rx_desc)
62 if (!wl->ops->get_rx_buf_align)
63 BUG_ON(1);
65 return wl->ops->get_rx_buf_align(wl, rx_desc);
68 static inline int
69 wlcore_hw_prepare_read(struct wl1271 *wl, u32 rx_desc, u32 len)
71 if (wl->ops->prepare_read)
72 return wl->ops->prepare_read(wl, rx_desc, len);
74 return 0;
77 static inline u32
78 wlcore_hw_get_rx_packet_len(struct wl1271 *wl, void *rx_data, u32 data_len)
80 if (!wl->ops->get_rx_packet_len)
81 BUG_ON(1);
83 return wl->ops->get_rx_packet_len(wl, rx_data, data_len);
86 static inline int wlcore_hw_tx_delayed_compl(struct wl1271 *wl)
88 if (wl->ops->tx_delayed_compl)
89 return wl->ops->tx_delayed_compl(wl);
91 return 0;
94 static inline void wlcore_hw_tx_immediate_compl(struct wl1271 *wl)
96 if (wl->ops->tx_immediate_compl)
97 wl->ops->tx_immediate_compl(wl);
100 static inline int
101 wlcore_hw_init_vif(struct wl1271 *wl, struct wl12xx_vif *wlvif)
103 if (wl->ops->init_vif)
104 return wl->ops->init_vif(wl, wlvif);
106 return 0;
109 static inline u32
110 wlcore_hw_sta_get_ap_rate_mask(struct wl1271 *wl, struct wl12xx_vif *wlvif)
112 if (!wl->ops->sta_get_ap_rate_mask)
113 BUG_ON(1);
115 return wl->ops->sta_get_ap_rate_mask(wl, wlvif);
118 static inline int wlcore_identify_fw(struct wl1271 *wl)
120 if (wl->ops->identify_fw)
121 return wl->ops->identify_fw(wl);
123 return 0;
126 static inline void
127 wlcore_hw_set_tx_desc_csum(struct wl1271 *wl,
128 struct wl1271_tx_hw_descr *desc,
129 struct sk_buff *skb)
131 if (!wl->ops->set_tx_desc_csum)
132 BUG_ON(1);
134 wl->ops->set_tx_desc_csum(wl, desc, skb);
137 static inline void
138 wlcore_hw_set_rx_csum(struct wl1271 *wl,
139 struct wl1271_rx_descriptor *desc,
140 struct sk_buff *skb)
142 if (wl->ops->set_rx_csum)
143 wl->ops->set_rx_csum(wl, desc, skb);
146 static inline u32
147 wlcore_hw_ap_get_mimo_wide_rate_mask(struct wl1271 *wl,
148 struct wl12xx_vif *wlvif)
150 if (wl->ops->ap_get_mimo_wide_rate_mask)
151 return wl->ops->ap_get_mimo_wide_rate_mask(wl, wlvif);
153 return 0;
156 static inline int
157 wlcore_debugfs_init(struct wl1271 *wl, struct dentry *rootdir)
159 if (wl->ops->debugfs_init)
160 return wl->ops->debugfs_init(wl, rootdir);
162 return 0;
165 static inline int
166 wlcore_handle_static_data(struct wl1271 *wl, void *static_data)
168 if (wl->ops->handle_static_data)
169 return wl->ops->handle_static_data(wl, static_data);
171 return 0;
174 static inline int
175 wlcore_hw_get_spare_blocks(struct wl1271 *wl, bool is_gem)
177 if (!wl->ops->get_spare_blocks)
178 BUG_ON(1);
180 return wl->ops->get_spare_blocks(wl, is_gem);
183 static inline int
184 wlcore_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)
189 if (!wl->ops->set_key)
190 BUG_ON(1);
192 return wl->ops->set_key(wl, cmd, vif, sta, key_conf);
195 static inline u32
196 wlcore_hw_pre_pkt_send(struct wl1271 *wl, u32 buf_offset, u32 last_len)
198 if (wl->ops->pre_pkt_send)
199 return wl->ops->pre_pkt_send(wl, buf_offset, last_len);
201 return buf_offset;
204 static inline void
205 wlcore_hw_sta_rc_update(struct wl1271 *wl, struct wl12xx_vif *wlvif,
206 struct ieee80211_sta *sta, u32 changed)
208 if (wl->ops->sta_rc_update)
209 wl->ops->sta_rc_update(wl, wlvif, sta, changed);
212 static inline int
213 wlcore_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)
218 if (wl->ops->set_peer_cap)
219 return wl->ops->set_peer_cap(wl, ht_cap, allow_ht_operation,
220 rate_set, hlid);
222 return 0;
225 static inline bool
226 wlcore_hw_lnk_high_prio(struct wl1271 *wl, u8 hlid,
227 struct wl1271_link *lnk)
229 if (!wl->ops->lnk_high_prio)
230 BUG_ON(1);
232 return wl->ops->lnk_high_prio(wl, hlid, lnk);
235 static inline bool
236 wlcore_hw_lnk_low_prio(struct wl1271 *wl, u8 hlid,
237 struct wl1271_link *lnk)
239 if (!wl->ops->lnk_low_prio)
240 BUG_ON(1);
242 return wl->ops->lnk_low_prio(wl, hlid, lnk);
245 #endif