diff options
author | Joe Perches <joe@perches.com> | 2010-12-02 22:12:35 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2010-12-07 16:34:39 -0500 |
commit | 21a99f934949807dc0c9dc7642bbf0081b7582f9 (patch) | |
tree | 06411011aa5655d73d809d873d2d80d17842e047 | |
parent | 0ab82b04ac83a05bda3ef8499f415fc6fd6ee206 (diff) |
ath: Add and use ath_printk and ath_<level>
Add ath_printk and ath_<level> similar to
dev_printk and dev_<level> from device.h
This allows a more gradual rename of ath_print
to to ath_dbg or perhaps ath_debug.
This basically removes debug.h leaving
only an #define ath_printk ath_dbg
there and moving all the ATH_DBG_<foo>
enums to ath.h
I do not think there's much purpose for struct
ath_common * being passed to the ath_printk
functions, but perhaps there might be.
Signed-off-by: Joe Perches <joe@perches.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | drivers/net/wireless/ath/ath.h | 103 | ||||
-rw-r--r-- | drivers/net/wireless/ath/debug.c | 20 | ||||
-rw-r--r-- | drivers/net/wireless/ath/debug.h | 72 | ||||
-rw-r--r-- | drivers/net/wireless/ath/main.c | 20 |
4 files changed, 124 insertions, 91 deletions
diff --git a/drivers/net/wireless/ath/ath.h b/drivers/net/wireless/ath/ath.h index 26bdbeee424f..c914f5213c61 100644 --- a/drivers/net/wireless/ath/ath.h +++ b/drivers/net/wireless/ath/ath.h | |||
@@ -186,4 +186,107 @@ bool ath_hw_keyreset(struct ath_common *common, u16 entry); | |||
186 | void ath_hw_cycle_counters_update(struct ath_common *common); | 186 | void ath_hw_cycle_counters_update(struct ath_common *common); |
187 | int32_t ath_hw_get_listen_time(struct ath_common *common); | 187 | int32_t ath_hw_get_listen_time(struct ath_common *common); |
188 | 188 | ||
189 | extern __attribute__ ((format (printf, 3, 4))) int | ||
190 | ath_printk(const char *level, struct ath_common *common, const char *fmt, ...); | ||
191 | |||
192 | #define ath_emerg(common, fmt, ...) \ | ||
193 | ath_printk(KERN_EMERG, common, fmt, ##__VA_ARGS__) | ||
194 | #define ath_alert(common, fmt, ...) \ | ||
195 | ath_printk(KERN_ALERT, common, fmt, ##__VA_ARGS__) | ||
196 | #define ath_crit(common, fmt, ...) \ | ||
197 | ath_printk(KERN_CRIT, common, fmt, ##__VA_ARGS__) | ||
198 | #define ath_err(common, fmt, ...) \ | ||
199 | ath_printk(KERN_ERR, common, fmt, ##__VA_ARGS__) | ||
200 | #define ath_warn(common, fmt, ...) \ | ||
201 | ath_printk(KERN_WARNING, common, fmt, ##__VA_ARGS__) | ||
202 | #define ath_notice(common, fmt, ...) \ | ||
203 | ath_printk(KERN_NOTICE, common, fmt, ##__VA_ARGS__) | ||
204 | #define ath_info(common, fmt, ...) \ | ||
205 | ath_printk(KERN_INFO, common, fmt, ##__VA_ARGS__) | ||
206 | |||
207 | /** | ||
208 | * enum ath_debug_level - atheros wireless debug level | ||
209 | * | ||
210 | * @ATH_DBG_RESET: reset processing | ||
211 | * @ATH_DBG_QUEUE: hardware queue management | ||
212 | * @ATH_DBG_EEPROM: eeprom processing | ||
213 | * @ATH_DBG_CALIBRATE: periodic calibration | ||
214 | * @ATH_DBG_INTERRUPT: interrupt processing | ||
215 | * @ATH_DBG_REGULATORY: regulatory processing | ||
216 | * @ATH_DBG_ANI: adaptive noise immunitive processing | ||
217 | * @ATH_DBG_XMIT: basic xmit operation | ||
218 | * @ATH_DBG_BEACON: beacon handling | ||
219 | * @ATH_DBG_CONFIG: configuration of the hardware | ||
220 | * @ATH_DBG_FATAL: fatal errors, this is the default, DBG_DEFAULT | ||
221 | * @ATH_DBG_PS: power save processing | ||
222 | * @ATH_DBG_HWTIMER: hardware timer handling | ||
223 | * @ATH_DBG_BTCOEX: bluetooth coexistance | ||
224 | * @ATH_DBG_BSTUCK: stuck beacons | ||
225 | * @ATH_DBG_ANY: enable all debugging | ||
226 | * | ||
227 | * The debug level is used to control the amount and type of debugging output | ||
228 | * we want to see. Each driver has its own method for enabling debugging and | ||
229 | * modifying debug level states -- but this is typically done through a | ||
230 | * module parameter 'debug' along with a respective 'debug' debugfs file | ||
231 | * entry. | ||
232 | */ | ||
233 | enum ATH_DEBUG { | ||
234 | ATH_DBG_RESET = 0x00000001, | ||
235 | ATH_DBG_QUEUE = 0x00000002, | ||
236 | ATH_DBG_EEPROM = 0x00000004, | ||
237 | ATH_DBG_CALIBRATE = 0x00000008, | ||
238 | ATH_DBG_INTERRUPT = 0x00000010, | ||
239 | ATH_DBG_REGULATORY = 0x00000020, | ||
240 | ATH_DBG_ANI = 0x00000040, | ||
241 | ATH_DBG_XMIT = 0x00000080, | ||
242 | ATH_DBG_BEACON = 0x00000100, | ||
243 | ATH_DBG_CONFIG = 0x00000200, | ||
244 | ATH_DBG_FATAL = 0x00000400, | ||
245 | ATH_DBG_PS = 0x00000800, | ||
246 | ATH_DBG_HWTIMER = 0x00001000, | ||
247 | ATH_DBG_BTCOEX = 0x00002000, | ||
248 | ATH_DBG_WMI = 0x00004000, | ||
249 | ATH_DBG_BSTUCK = 0x00008000, | ||
250 | ATH_DBG_ANY = 0xffffffff | ||
251 | }; | ||
252 | |||
253 | #define ATH_DBG_DEFAULT (ATH_DBG_FATAL) | ||
254 | |||
255 | #ifdef CONFIG_ATH_DEBUG | ||
256 | |||
257 | #define ath_dbg(common, dbg_mask, fmt, ...) \ | ||
258 | ({ \ | ||
259 | int rtn; \ | ||
260 | if ((common)->debug_mask & dbg_mask) \ | ||
261 | rtn = ath_printk(KERN_DEBUG, common, fmt, \ | ||
262 | ##__VA_ARGS__); \ | ||
263 | else \ | ||
264 | rtn = 0; \ | ||
265 | \ | ||
266 | rtn; \ | ||
267 | }) | ||
268 | #define ATH_DBG_WARN(foo, arg...) WARN(foo, arg) | ||
269 | |||
270 | #else | ||
271 | |||
272 | static inline __attribute__ ((format (printf, 3, 4))) int | ||
273 | ath_dbg(struct ath_common *common, enum ATH_DEBUG dbg_mask, | ||
274 | const char *fmt, ...) | ||
275 | { | ||
276 | return 0; | ||
277 | } | ||
278 | #define ATH_DBG_WARN(foo, arg...) do {} while (0) | ||
279 | |||
280 | #endif /* CONFIG_ATH_DEBUG */ | ||
281 | |||
282 | /** Returns string describing opmode, or NULL if unknown mode. */ | ||
283 | #ifdef CONFIG_ATH_DEBUG | ||
284 | const char *ath_opmode_to_string(enum nl80211_iftype opmode); | ||
285 | #else | ||
286 | static inline const char *ath_opmode_to_string(enum nl80211_iftype opmode) | ||
287 | { | ||
288 | return "UNKNOWN"; | ||
289 | } | ||
290 | #endif | ||
291 | |||
189 | #endif /* ATH_H */ | 292 | #endif /* ATH_H */ |
diff --git a/drivers/net/wireless/ath/debug.c b/drivers/net/wireless/ath/debug.c index a9600ba8ceaa..5367b1086e09 100644 --- a/drivers/net/wireless/ath/debug.c +++ b/drivers/net/wireless/ath/debug.c | |||
@@ -15,26 +15,6 @@ | |||
15 | */ | 15 | */ |
16 | 16 | ||
17 | #include "ath.h" | 17 | #include "ath.h" |
18 | #include "debug.h" | ||
19 | |||
20 | void ath_print(struct ath_common *common, int dbg_mask, const char *fmt, ...) | ||
21 | { | ||
22 | struct va_format vaf; | ||
23 | va_list args; | ||
24 | |||
25 | if (likely(!(common->debug_mask & dbg_mask))) | ||
26 | return; | ||
27 | |||
28 | va_start(args, fmt); | ||
29 | |||
30 | vaf.fmt = fmt; | ||
31 | vaf.va = &args; | ||
32 | |||
33 | printk(KERN_DEBUG "ath: %pV", &vaf); | ||
34 | |||
35 | va_end(args); | ||
36 | } | ||
37 | EXPORT_SYMBOL(ath_print); | ||
38 | 18 | ||
39 | const char *ath_opmode_to_string(enum nl80211_iftype opmode) | 19 | const char *ath_opmode_to_string(enum nl80211_iftype opmode) |
40 | { | 20 | { |
diff --git a/drivers/net/wireless/ath/debug.h b/drivers/net/wireless/ath/debug.h index f207007ee391..cec951cdfac1 100644 --- a/drivers/net/wireless/ath/debug.h +++ b/drivers/net/wireless/ath/debug.h | |||
@@ -17,76 +17,6 @@ | |||
17 | #ifndef ATH_DEBUG_H | 17 | #ifndef ATH_DEBUG_H |
18 | #define ATH_DEBUG_H | 18 | #define ATH_DEBUG_H |
19 | 19 | ||
20 | #include "ath.h" | 20 | #define ath_print ath_dbg |
21 | |||
22 | /** | ||
23 | * enum ath_debug_level - atheros wireless debug level | ||
24 | * | ||
25 | * @ATH_DBG_RESET: reset processing | ||
26 | * @ATH_DBG_QUEUE: hardware queue management | ||
27 | * @ATH_DBG_EEPROM: eeprom processing | ||
28 | * @ATH_DBG_CALIBRATE: periodic calibration | ||
29 | * @ATH_DBG_INTERRUPT: interrupt processing | ||
30 | * @ATH_DBG_REGULATORY: regulatory processing | ||
31 | * @ATH_DBG_ANI: adaptive noise immunitive processing | ||
32 | * @ATH_DBG_XMIT: basic xmit operation | ||
33 | * @ATH_DBG_BEACON: beacon handling | ||
34 | * @ATH_DBG_CONFIG: configuration of the hardware | ||
35 | * @ATH_DBG_FATAL: fatal errors, this is the default, DBG_DEFAULT | ||
36 | * @ATH_DBG_PS: power save processing | ||
37 | * @ATH_DBG_HWTIMER: hardware timer handling | ||
38 | * @ATH_DBG_BTCOEX: bluetooth coexistance | ||
39 | * @ATH_DBG_BSTUCK: stuck beacons | ||
40 | * @ATH_DBG_ANY: enable all debugging | ||
41 | * | ||
42 | * The debug level is used to control the amount and type of debugging output | ||
43 | * we want to see. Each driver has its own method for enabling debugging and | ||
44 | * modifying debug level states -- but this is typically done through a | ||
45 | * module parameter 'debug' along with a respective 'debug' debugfs file | ||
46 | * entry. | ||
47 | */ | ||
48 | enum ATH_DEBUG { | ||
49 | ATH_DBG_RESET = 0x00000001, | ||
50 | ATH_DBG_QUEUE = 0x00000002, | ||
51 | ATH_DBG_EEPROM = 0x00000004, | ||
52 | ATH_DBG_CALIBRATE = 0x00000008, | ||
53 | ATH_DBG_INTERRUPT = 0x00000010, | ||
54 | ATH_DBG_REGULATORY = 0x00000020, | ||
55 | ATH_DBG_ANI = 0x00000040, | ||
56 | ATH_DBG_XMIT = 0x00000080, | ||
57 | ATH_DBG_BEACON = 0x00000100, | ||
58 | ATH_DBG_CONFIG = 0x00000200, | ||
59 | ATH_DBG_FATAL = 0x00000400, | ||
60 | ATH_DBG_PS = 0x00000800, | ||
61 | ATH_DBG_HWTIMER = 0x00001000, | ||
62 | ATH_DBG_BTCOEX = 0x00002000, | ||
63 | ATH_DBG_WMI = 0x00004000, | ||
64 | ATH_DBG_BSTUCK = 0x00008000, | ||
65 | ATH_DBG_ANY = 0xffffffff | ||
66 | }; | ||
67 | |||
68 | #define ATH_DBG_DEFAULT (ATH_DBG_FATAL) | ||
69 | |||
70 | #ifdef CONFIG_ATH_DEBUG | ||
71 | void ath_print(struct ath_common *common, int dbg_mask, const char *fmt, ...) | ||
72 | __attribute__ ((format (printf, 3, 4))); | ||
73 | #define ATH_DBG_WARN(foo, arg...) WARN(foo, arg) | ||
74 | #else | ||
75 | static inline void __attribute__ ((format (printf, 3, 4))) | ||
76 | ath_print(struct ath_common *common, int dbg_mask, const char *fmt, ...) | ||
77 | { | ||
78 | } | ||
79 | #define ATH_DBG_WARN(foo, arg) | ||
80 | #endif /* CONFIG_ATH_DEBUG */ | ||
81 | |||
82 | /** Returns string describing opmode, or NULL if unknown mode. */ | ||
83 | #ifdef CONFIG_ATH_DEBUG | ||
84 | const char *ath_opmode_to_string(enum nl80211_iftype opmode); | ||
85 | #else | ||
86 | static inline const char *ath_opmode_to_string(enum nl80211_iftype opmode) | ||
87 | { | ||
88 | return "UNKNOWN"; | ||
89 | } | ||
90 | #endif | ||
91 | 21 | ||
92 | #endif /* ATH_DEBUG_H */ | 22 | #endif /* ATH_DEBUG_H */ |
diff --git a/drivers/net/wireless/ath/main.c b/drivers/net/wireless/ath/main.c index 487193f1de1a..c325202fdc5f 100644 --- a/drivers/net/wireless/ath/main.c +++ b/drivers/net/wireless/ath/main.c | |||
@@ -56,3 +56,23 @@ struct sk_buff *ath_rxbuf_alloc(struct ath_common *common, | |||
56 | return skb; | 56 | return skb; |
57 | } | 57 | } |
58 | EXPORT_SYMBOL(ath_rxbuf_alloc); | 58 | EXPORT_SYMBOL(ath_rxbuf_alloc); |
59 | |||
60 | int ath_printk(const char *level, struct ath_common *common, | ||
61 | const char *fmt, ...) | ||
62 | { | ||
63 | struct va_format vaf; | ||
64 | va_list args; | ||
65 | int rtn; | ||
66 | |||
67 | va_start(args, fmt); | ||
68 | |||
69 | vaf.fmt = fmt; | ||
70 | vaf.va = &args; | ||
71 | |||
72 | rtn = printk("%sath: %pV", level, &vaf); | ||
73 | |||
74 | va_end(args); | ||
75 | |||
76 | return rtn; | ||
77 | } | ||
78 | EXPORT_SYMBOL(ath_printk); | ||