diff options
author | Luis R. Rodriguez <mcgrof@winlab.rutgers.edu> | 2008-02-04 10:03:54 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-02-29 15:19:37 -0500 |
commit | b446197cc14ef060baeed5acbcddf148c04d03f8 (patch) | |
tree | 74fd1867ef8e31d3572b5e3b09ceeccd296376bf | |
parent | e9ddc0f25ce524d257e6cf779e495f567ed7678f (diff) |
ath5k: Port debug.c over to the new band API and enable as build option
This patch finishes the port and enables debug as an build option.
This was tested on:
Atheros AR5213A chip found (MAC: 0x59, PHY: 0x43)
RF5112A multiband radio found (0x36)
Note:
For 2 GHz band on the above card I noticed we get negative channel
numbers. Will look into this unless someone beats me to it.
Example out put when loading using:
sudo modprobe ath5k debug=0x00000400
Band 2 GHz: channels 26, rates 12
channels:
1 2412 00c0 0000
2 2417 00c0 0000
3 2422 00c0 0000
4 2427 00c0 0000
5 2432 00c0 0000
6 2437 00c0 0000
7 2442 00c0 0000
8 2447 00c0 0000
9 2452 00c0 0000
10 2457 00c0 0000
11 2462 00c0 0000
12 2467 00c0 0000
13 2472 00c0 0000
14 2484 00c0 0000
-498 2512 00c0 0000
-494 2532 00c0 0000
-490 2552 00c0 0000
-486 2572 00c0 0000
-482 2592 00c0 0000
-478 2612 00c0 0000
-474 2632 00c0 0000
-470 2652 00c0 0000
-466 2672 00c0 0000
-462 2692 00c0 0000
-458 2712 00c0 0000
-454 2732 00c0 0000
Band 5 GHz: channels 194, rates 8
channels:
27 5135 0140 0000
28 5140 0140 0000
[... etc ]
219 6095 0140 0000
220 6100 0140 0000
rates:
60 000b 0000 0000
90 000f 0000 0000
120 000a 0000 0000
180 000e 0000 0000
240 0009 0000 0000
360 000d 0000 0000
480 0008 0000 0000
540 000c 0000 0000
Changes to base.c, base.h
Changes-licensed-under: 3-Clause-BSD
Changes to debug.c, debug.h
Changes-licensed-under: GPL
Signed-off-by: Luis R. Rodriguez <mcgrof@winlab.rutgers.edu>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | drivers/net/wireless/ath5k/Kconfig | 21 | ||||
-rw-r--r-- | drivers/net/wireless/ath5k/Makefile | 2 | ||||
-rw-r--r-- | drivers/net/wireless/ath5k/base.c | 2 | ||||
-rw-r--r-- | drivers/net/wireless/ath5k/base.h | 4 | ||||
-rw-r--r-- | drivers/net/wireless/ath5k/debug.c | 55 | ||||
-rw-r--r-- | drivers/net/wireless/ath5k/debug.h | 19 |
6 files changed, 67 insertions, 36 deletions
diff --git a/drivers/net/wireless/ath5k/Kconfig b/drivers/net/wireless/ath5k/Kconfig index af1b6b8c991a..f1f2aea2eab4 100644 --- a/drivers/net/wireless/ath5k/Kconfig +++ b/drivers/net/wireless/ath5k/Kconfig | |||
@@ -14,3 +14,24 @@ config ATH5K | |||
14 | 14 | ||
15 | If you choose to build a module, it'll be called ath5k. Say M if | 15 | If you choose to build a module, it'll be called ath5k. Say M if |
16 | unsure. | 16 | unsure. |
17 | |||
18 | config ATH5K_DEBUG | ||
19 | bool "Atheros 5xxx debugging" | ||
20 | depends on ATH5K | ||
21 | ---help--- | ||
22 | Atheros 5xxx debugging messages. | ||
23 | |||
24 | Say Y, if and you will get debug options for ath5k. | ||
25 | To use this, you need to mount debugfs: | ||
26 | |||
27 | mkdir /debug/ | ||
28 | mount -t debugfs debug /debug/ | ||
29 | |||
30 | You will get access to files under: | ||
31 | /debug/ath5k/phy0/ | ||
32 | |||
33 | To enable debug, pass the debug level to the debug module | ||
34 | parameter. For example: | ||
35 | |||
36 | modprobe ath5k debug=0x00000400 | ||
37 | |||
diff --git a/drivers/net/wireless/ath5k/Makefile b/drivers/net/wireless/ath5k/Makefile index 0f14b00f648e..564ecd0c5d4b 100644 --- a/drivers/net/wireless/ath5k/Makefile +++ b/drivers/net/wireless/ath5k/Makefile | |||
@@ -2,5 +2,5 @@ ath5k-y += base.o | |||
2 | ath5k-y += hw.o | 2 | ath5k-y += hw.o |
3 | ath5k-y += initvals.o | 3 | ath5k-y += initvals.o |
4 | ath5k-y += phy.o | 4 | ath5k-y += phy.o |
5 | ath5k-y += debug.o | 5 | ath5k-$(CONFIG_ATH5K_DEBUG) += debug.o |
6 | obj-$(CONFIG_ATH5K) += ath5k.o | 6 | obj-$(CONFIG_ATH5K) += ath5k.o |
diff --git a/drivers/net/wireless/ath5k/base.c b/drivers/net/wireless/ath5k/base.c index 44c0133e844f..5ca441d7a6c1 100644 --- a/drivers/net/wireless/ath5k/base.c +++ b/drivers/net/wireless/ath5k/base.c | |||
@@ -994,7 +994,7 @@ ath5k_getchannels(struct ieee80211_hw *hw) | |||
994 | hw->wiphy->bands[IEEE80211_BAND_5GHZ] = sband; | 994 | hw->wiphy->bands[IEEE80211_BAND_5GHZ] = sband; |
995 | } | 995 | } |
996 | 996 | ||
997 | /* FIXME: ath5k_debug_dump_modes(sc, modes); */ | 997 | ath5k_debug_dump_bands(sc); |
998 | 998 | ||
999 | return 0; | 999 | return 0; |
1000 | } | 1000 | } |
diff --git a/drivers/net/wireless/ath5k/base.h b/drivers/net/wireless/ath5k/base.h index bbe7a5438154..3a9755893018 100644 --- a/drivers/net/wireless/ath5k/base.h +++ b/drivers/net/wireless/ath5k/base.h | |||
@@ -108,9 +108,9 @@ struct ath5k_softc { | |||
108 | u8 g_rates; | 108 | u8 g_rates; |
109 | u8 xr_rates; | 109 | u8 xr_rates; |
110 | 110 | ||
111 | #if ATH5K_DEBUG | 111 | #ifdef CONFIG_ATH5K_DEBUG |
112 | struct ath5k_dbg_info debug; /* debug info */ | 112 | struct ath5k_dbg_info debug; /* debug info */ |
113 | #endif | 113 | #endif /* CONFIG_ATH5K_DEBUG */ |
114 | 114 | ||
115 | struct ath5k_buf *bufptr; /* allocated buffer ptr */ | 115 | struct ath5k_buf *bufptr; /* allocated buffer ptr */ |
116 | struct ath5k_desc *desc; /* TX/RX descriptors */ | 116 | struct ath5k_desc *desc; /* TX/RX descriptors */ |
diff --git a/drivers/net/wireless/ath5k/debug.c b/drivers/net/wireless/ath5k/debug.c index bb581ef6d1ef..05bf4fb8f907 100644 --- a/drivers/net/wireless/ath5k/debug.c +++ b/drivers/net/wireless/ath5k/debug.c | |||
@@ -65,7 +65,7 @@ static unsigned int ath5k_debug; | |||
65 | module_param_named(debug, ath5k_debug, uint, 0); | 65 | module_param_named(debug, ath5k_debug, uint, 0); |
66 | 66 | ||
67 | 67 | ||
68 | #if ATH5K_DEBUG | 68 | #ifdef CONFIG_ATH5K_DEBUG |
69 | 69 | ||
70 | #include <linux/seq_file.h> | 70 | #include <linux/seq_file.h> |
71 | #include "reg.h" | 71 | #include "reg.h" |
@@ -340,7 +340,7 @@ static struct { | |||
340 | { ATH5K_DEBUG_LED, "led", "LED mamagement" }, | 340 | { ATH5K_DEBUG_LED, "led", "LED mamagement" }, |
341 | { ATH5K_DEBUG_DUMP_RX, "dumprx", "print received skb content" }, | 341 | { ATH5K_DEBUG_DUMP_RX, "dumprx", "print received skb content" }, |
342 | { ATH5K_DEBUG_DUMP_TX, "dumptx", "print transmit skb content" }, | 342 | { ATH5K_DEBUG_DUMP_TX, "dumptx", "print transmit skb content" }, |
343 | { ATH5K_DEBUG_DUMPMODES, "dumpmodes", "dump modes" }, | 343 | { ATH5K_DEBUG_DUMPBANDS, "dumpbands", "dump bands" }, |
344 | { ATH5K_DEBUG_TRACE, "trace", "trace function calls" }, | 344 | { ATH5K_DEBUG_TRACE, "trace", "trace function calls" }, |
345 | { ATH5K_DEBUG_ANY, "all", "show all debug levels" }, | 345 | { ATH5K_DEBUG_ANY, "all", "show all debug levels" }, |
346 | }; | 346 | }; |
@@ -452,30 +452,47 @@ ath5k_debug_finish_device(struct ath5k_softc *sc) | |||
452 | /* functions used in other places */ | 452 | /* functions used in other places */ |
453 | 453 | ||
454 | void | 454 | void |
455 | ath5k_debug_dump_modes(struct ath5k_softc *sc, struct ieee80211_hw_mode *modes) | 455 | ath5k_debug_dump_bands(struct ath5k_softc *sc) |
456 | { | 456 | { |
457 | unsigned int m, i; | 457 | unsigned int b, i; |
458 | 458 | ||
459 | if (likely(!(sc->debug.level & ATH5K_DEBUG_DUMPMODES))) | 459 | if (likely(!(sc->debug.level & ATH5K_DEBUG_DUMPBANDS))) |
460 | return; | 460 | return; |
461 | 461 | ||
462 | for (m = 0; m < NUM_DRIVER_MODES; m++) { | 462 | BUG_ON(!sc->sbands); |
463 | printk(KERN_DEBUG "Mode %u: channels %d, rates %d\n", m, | 463 | |
464 | modes[m].num_channels, modes[m].num_rates); | 464 | for (b = 0; b < IEEE80211_NUM_BANDS; b++) { |
465 | struct ieee80211_supported_band *band = &sc->sbands[b]; | ||
466 | char bname[5]; | ||
467 | switch (band->band) { | ||
468 | case IEEE80211_BAND_2GHZ: | ||
469 | strcpy(bname, "2 GHz"); | ||
470 | break; | ||
471 | case IEEE80211_BAND_5GHZ: | ||
472 | strcpy(bname, "5 GHz"); | ||
473 | break; | ||
474 | default: | ||
475 | printk(KERN_DEBUG "Band not supported: %d\n", | ||
476 | band->band); | ||
477 | return; | ||
478 | } | ||
479 | printk(KERN_DEBUG "Band %s: channels %d, rates %d\n", bname, | ||
480 | band->n_channels, band->n_bitrates); | ||
465 | printk(KERN_DEBUG " channels:\n"); | 481 | printk(KERN_DEBUG " channels:\n"); |
466 | for (i = 0; i < modes[m].num_channels; i++) | 482 | for (i = 0; i < band->n_channels; i++) |
467 | printk(KERN_DEBUG " %3d %d %.4x %.4x\n", | 483 | printk(KERN_DEBUG " %3d %d %.4x %.4x\n", |
468 | modes[m].channels[i].chan, | 484 | ieee80211_frequency_to_channel( |
469 | modes[m].channels[i].freq, | 485 | band->channels[i].center_freq), |
470 | modes[m].channels[i].val, | 486 | band->channels[i].center_freq, |
471 | modes[m].channels[i].flag); | 487 | band->channels[i].hw_value, |
488 | band->channels[i].flags); | ||
472 | printk(KERN_DEBUG " rates:\n"); | 489 | printk(KERN_DEBUG " rates:\n"); |
473 | for (i = 0; i < modes[m].num_rates; i++) | 490 | for (i = 0; i < band->n_bitrates; i++) |
474 | printk(KERN_DEBUG " %4d %.4x %.4x %.4x\n", | 491 | printk(KERN_DEBUG " %4d %.4x %.4x %.4x\n", |
475 | modes[m].rates[i].rate, | 492 | band->bitrates[i].bitrate, |
476 | modes[m].rates[i].val, | 493 | band->bitrates[i].hw_value, |
477 | modes[m].rates[i].flags, | 494 | band->bitrates[i].flags, |
478 | modes[m].rates[i].val2); | 495 | band->bitrates[i].hw_value_short); |
479 | } | 496 | } |
480 | } | 497 | } |
481 | 498 | ||
@@ -548,4 +565,4 @@ ath5k_debug_printtxbuf(struct ath5k_softc *sc, | |||
548 | !done ? ' ' : (ds->ds_txstat.ts_status == 0) ? '*' : '!'); | 565 | !done ? ' ' : (ds->ds_txstat.ts_status == 0) ? '*' : '!'); |
549 | } | 566 | } |
550 | 567 | ||
551 | #endif /* if ATH5K_DEBUG */ | 568 | #endif /* ifdef CONFIG_ATH5K_DEBUG */ |
diff --git a/drivers/net/wireless/ath5k/debug.h b/drivers/net/wireless/ath5k/debug.h index c4fd8c43df0c..16fbb6fbab35 100644 --- a/drivers/net/wireless/ath5k/debug.h +++ b/drivers/net/wireless/ath5k/debug.h | |||
@@ -61,11 +61,6 @@ | |||
61 | #ifndef _ATH5K_DEBUG_H | 61 | #ifndef _ATH5K_DEBUG_H |
62 | #define _ATH5K_DEBUG_H | 62 | #define _ATH5K_DEBUG_H |
63 | 63 | ||
64 | /* set this to 1 for debugging output */ | ||
65 | #ifndef ATH5K_DEBUG | ||
66 | #define ATH5K_DEBUG 0 | ||
67 | #endif | ||
68 | |||
69 | struct ath5k_softc; | 64 | struct ath5k_softc; |
70 | struct ath5k_hw; | 65 | struct ath5k_hw; |
71 | struct ieee80211_hw_mode; | 66 | struct ieee80211_hw_mode; |
@@ -96,7 +91,7 @@ struct ath5k_dbg_info { | |||
96 | * @ATH5K_DEBUG_LED: led management | 91 | * @ATH5K_DEBUG_LED: led management |
97 | * @ATH5K_DEBUG_DUMP_RX: print received skb content | 92 | * @ATH5K_DEBUG_DUMP_RX: print received skb content |
98 | * @ATH5K_DEBUG_DUMP_TX: print transmit skb content | 93 | * @ATH5K_DEBUG_DUMP_TX: print transmit skb content |
99 | * @ATH5K_DEBUG_DUMPMODES: dump modes | 94 | * @ATH5K_DEBUG_DUMPBANDS: dump bands |
100 | * @ATH5K_DEBUG_TRACE: trace function calls | 95 | * @ATH5K_DEBUG_TRACE: trace function calls |
101 | * @ATH5K_DEBUG_ANY: show at any debug level | 96 | * @ATH5K_DEBUG_ANY: show at any debug level |
102 | * | 97 | * |
@@ -118,12 +113,12 @@ enum ath5k_debug_level { | |||
118 | ATH5K_DEBUG_LED = 0x00000080, | 113 | ATH5K_DEBUG_LED = 0x00000080, |
119 | ATH5K_DEBUG_DUMP_RX = 0x00000100, | 114 | ATH5K_DEBUG_DUMP_RX = 0x00000100, |
120 | ATH5K_DEBUG_DUMP_TX = 0x00000200, | 115 | ATH5K_DEBUG_DUMP_TX = 0x00000200, |
121 | ATH5K_DEBUG_DUMPMODES = 0x00000400, | 116 | ATH5K_DEBUG_DUMPBANDS = 0x00000400, |
122 | ATH5K_DEBUG_TRACE = 0x00001000, | 117 | ATH5K_DEBUG_TRACE = 0x00001000, |
123 | ATH5K_DEBUG_ANY = 0xffffffff | 118 | ATH5K_DEBUG_ANY = 0xffffffff |
124 | }; | 119 | }; |
125 | 120 | ||
126 | #if ATH5K_DEBUG | 121 | #ifdef CONFIG_ATH5K_DEBUG |
127 | 122 | ||
128 | #define ATH5K_TRACE(_sc) do { \ | 123 | #define ATH5K_TRACE(_sc) do { \ |
129 | if (unlikely((_sc)->debug.level & ATH5K_DEBUG_TRACE)) \ | 124 | if (unlikely((_sc)->debug.level & ATH5K_DEBUG_TRACE)) \ |
@@ -158,8 +153,7 @@ void | |||
158 | ath5k_debug_printrxbuffs(struct ath5k_softc *sc, struct ath5k_hw *ah); | 153 | ath5k_debug_printrxbuffs(struct ath5k_softc *sc, struct ath5k_hw *ah); |
159 | 154 | ||
160 | void | 155 | void |
161 | ath5k_debug_dump_modes(struct ath5k_softc *sc, | 156 | ath5k_debug_dump_bands(struct ath5k_softc *sc); |
162 | struct ieee80211_hw_mode *modes); | ||
163 | 157 | ||
164 | void | 158 | void |
165 | ath5k_debug_dump_skb(struct ath5k_softc *sc, | 159 | ath5k_debug_dump_skb(struct ath5k_softc *sc, |
@@ -196,8 +190,7 @@ static inline void | |||
196 | ath5k_debug_printrxbuffs(struct ath5k_softc *sc, struct ath5k_hw *ah) {} | 190 | ath5k_debug_printrxbuffs(struct ath5k_softc *sc, struct ath5k_hw *ah) {} |
197 | 191 | ||
198 | static inline void | 192 | static inline void |
199 | ath5k_debug_dump_modes(struct ath5k_softc *sc, | 193 | ath5k_debug_dump_bands(struct ath5k_softc *sc) {} |
200 | struct ieee80211_hw_mode *modes) {} | ||
201 | 194 | ||
202 | static inline void | 195 | static inline void |
203 | ath5k_debug_dump_skb(struct ath5k_softc *sc, | 196 | ath5k_debug_dump_skb(struct ath5k_softc *sc, |
@@ -207,6 +200,6 @@ static inline void | |||
207 | ath5k_debug_printtxbuf(struct ath5k_softc *sc, | 200 | ath5k_debug_printtxbuf(struct ath5k_softc *sc, |
208 | struct ath5k_buf *bf, int done) {} | 201 | struct ath5k_buf *bf, int done) {} |
209 | 202 | ||
210 | #endif /* if ATH5K_DEBUG */ | 203 | #endif /* ifdef CONFIG_ATH5K_DEBUG */ |
211 | 204 | ||
212 | #endif /* ifndef _ATH5K_DEBUG_H */ | 205 | #endif /* ifndef _ATH5K_DEBUG_H */ |