blob: ce58c654ade118cd24ef484ad0a9491c43670282 [file] [log] [blame]
Ivo van Doorn95ea3622007-09-25 17:57:13 -07001/*
2 Copyright (C) 2004 - 2007 rt2x00 SourceForge Project
3 <http://rt2x00.serialmonkey.com>
4
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU 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
17 Free Software Foundation, Inc.,
18 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19 */
20
21/*
22 Module: rt2x00lib
23 Abstract: Data structures and definitions for the rt2x00lib module.
24 */
25
26#ifndef RT2X00LIB_H
27#define RT2X00LIB_H
28
29/*
30 * Interval defines
Ivo van Doorn81873e92007-10-06 14:14:06 +020031 * Both the link tuner as the rfkill will be called once per second.
Ivo van Doorn95ea3622007-09-25 17:57:13 -070032 */
Anton Blanchardb239bd72007-10-15 00:40:34 -050033#define LINK_TUNE_INTERVAL ( round_jiffies_relative(HZ) )
Ivo van Doorn81873e92007-10-06 14:14:06 +020034#define RFKILL_POLL_INTERVAL ( 1000 )
Ivo van Doorn95ea3622007-09-25 17:57:13 -070035
36/*
37 * Radio control handlers.
38 */
39int rt2x00lib_enable_radio(struct rt2x00_dev *rt2x00dev);
40void rt2x00lib_disable_radio(struct rt2x00_dev *rt2x00dev);
Ivo van Doorn5cbf8302007-10-06 14:16:09 +020041void rt2x00lib_toggle_rx(struct rt2x00_dev *rt2x00dev, enum dev_state state);
Ivo van Doorn95ea3622007-09-25 17:57:13 -070042void rt2x00lib_reset_link_tuner(struct rt2x00_dev *rt2x00dev);
43
44/*
45 * Initialization handlers.
46 */
Ivo van Doorne37ea212008-01-06 23:40:07 +010047int rt2x00lib_start(struct rt2x00_dev *rt2x00dev);
48void rt2x00lib_stop(struct rt2x00_dev *rt2x00dev);
Ivo van Doorn95ea3622007-09-25 17:57:13 -070049
50/*
51 * Configuration handlers.
52 */
53void rt2x00lib_config_mac_addr(struct rt2x00_dev *rt2x00dev, u8 *mac);
54void rt2x00lib_config_bssid(struct rt2x00_dev *rt2x00dev, u8 *bssid);
Ivo van Doornfeb24692007-10-06 14:14:29 +020055void rt2x00lib_config_type(struct rt2x00_dev *rt2x00dev, const int type);
Ivo van Doorn69f81a22007-10-13 16:26:36 +020056void rt2x00lib_config_antenna(struct rt2x00_dev *rt2x00dev,
57 enum antenna rx, enum antenna tx);
Ivo van Doorn066cb632007-09-25 20:55:39 +020058void rt2x00lib_config(struct rt2x00_dev *rt2x00dev,
59 struct ieee80211_conf *conf, const int force_config);
Ivo van Doorn95ea3622007-09-25 17:57:13 -070060
61/*
62 * Firmware handlers.
63 */
64#ifdef CONFIG_RT2X00_LIB_FIRMWARE
65int rt2x00lib_load_firmware(struct rt2x00_dev *rt2x00dev);
66void rt2x00lib_free_firmware(struct rt2x00_dev *rt2x00dev);
67#else
68static inline int rt2x00lib_load_firmware(struct rt2x00_dev *rt2x00dev)
69{
70 return 0;
71}
72static inline void rt2x00lib_free_firmware(struct rt2x00_dev *rt2x00dev)
73{
74}
75#endif /* CONFIG_RT2X00_LIB_FIRMWARE */
76
77/*
78 * Debugfs handlers.
79 */
80#ifdef CONFIG_RT2X00_LIB_DEBUGFS
81void rt2x00debug_register(struct rt2x00_dev *rt2x00dev);
82void rt2x00debug_deregister(struct rt2x00_dev *rt2x00dev);
Ivo van Doorn4d8dd662007-11-27 21:49:29 +010083void rt2x00debug_dump_frame(struct rt2x00_dev *rt2x00dev, struct sk_buff *skb);
Ivo van Doorn95ea3622007-09-25 17:57:13 -070084#else
85static inline void rt2x00debug_register(struct rt2x00_dev *rt2x00dev)
86{
87}
88
89static inline void rt2x00debug_deregister(struct rt2x00_dev *rt2x00dev)
90{
91}
Ivo van Doorn4d8dd662007-11-27 21:49:29 +010092
93static inline void rt2x00debug_dump_frame(struct rt2x00_dev *rt2x00dev,
John W. Linville2b1ea592007-12-04 17:24:35 -050094 struct sk_buff *skb)
Ivo van Doorn4d8dd662007-11-27 21:49:29 +010095{
96}
Ivo van Doorn95ea3622007-09-25 17:57:13 -070097#endif /* CONFIG_RT2X00_LIB_DEBUGFS */
98
99/*
100 * RFkill handlers.
101 */
102#ifdef CONFIG_RT2X00_LIB_RFKILL
Ivo van Doorn1682fe62008-03-13 15:38:03 +0100103void rt2x00rfkill_register(struct rt2x00_dev *rt2x00dev);
Ivo van Doorn95ea3622007-09-25 17:57:13 -0700104void rt2x00rfkill_unregister(struct rt2x00_dev *rt2x00dev);
Ivo van Doorn1682fe62008-03-13 15:38:03 +0100105void rt2x00rfkill_allocate(struct rt2x00_dev *rt2x00dev);
Ivo van Doorn95ea3622007-09-25 17:57:13 -0700106void rt2x00rfkill_free(struct rt2x00_dev *rt2x00dev);
Ivo van Doorn1682fe62008-03-13 15:38:03 +0100107void rt2x00rfkill_suspend(struct rt2x00_dev *rt2x00dev);
108void rt2x00rfkill_resume(struct rt2x00_dev *rt2x00dev);
Ivo van Doorn95ea3622007-09-25 17:57:13 -0700109#else
Ivo van Doorn1682fe62008-03-13 15:38:03 +0100110static inline void rt2x00rfkill_register(struct rt2x00_dev *rt2x00dev)
Ivo van Doorn95ea3622007-09-25 17:57:13 -0700111{
Ivo van Doorn95ea3622007-09-25 17:57:13 -0700112}
113
114static inline void rt2x00rfkill_unregister(struct rt2x00_dev *rt2x00dev)
115{
116}
117
Ivo van Doorn1682fe62008-03-13 15:38:03 +0100118static inline void rt2x00rfkill_allocate(struct rt2x00_dev *rt2x00dev)
Ivo van Doorn95ea3622007-09-25 17:57:13 -0700119{
Ivo van Doorn95ea3622007-09-25 17:57:13 -0700120}
121
122static inline void rt2x00rfkill_free(struct rt2x00_dev *rt2x00dev)
123{
124}
Ivo van Doorn1682fe62008-03-13 15:38:03 +0100125
126static inline void rt2x00rfkill_suspend(struct rt2x00_dev *rt2x00dev)
127{
128}
129
130static inline void rt2x00rfkill_resume(struct rt2x00_dev *rt2x00dev)
131{
132}
Ivo van Doorn95ea3622007-09-25 17:57:13 -0700133#endif /* CONFIG_RT2X00_LIB_RFKILL */
134
135#endif /* RT2X00LIB_H */