Date: Sat, 29 Apr 2006 16:00:53 -0700 From: Sam Leffler <sam@errno.com> To: JoaoBR <joao@matik.com.br> Cc: freebsd-stable@freebsd.org Subject: Re: ath0: ath_chan_set: unable to reset channel 5 (2432 Mhz, flags 0x3e0 hal flags 0x140) Message-ID: <4453F025.90001@errno.com> In-Reply-To: <200604291825.17780.joao@matik.com.br> References: <200604252258.k3PMwJ74026969@monk.cnd.dundas.on.ca> <444EF0C7.8040407@errno.com> <200604291825.17780.joao@matik.com.br>
next in thread | previous in thread | raw e-mail | index | archive | help
JoaoBR wrote: > On Wednesday 26 April 2006 01:02, Sam Leffler wrote: > >> Attached are two patches; one for the ath driver and another for >> sys/net80211/ieee80211.c in releng6 (note changes to the latter in head >> are different). I believe this will resolve your problem; you can check >> by updating your code and looking at what ifconfig ath0 list chan gives >> you. >> > > I checked now with an unaltered ag530 (regdomain18) and look how strange > > Channel 1 : 2412 Mhz 11g Channel 136 : 4942* Mhz 11a > Channel 2 : 2417 Mhz 11g Channel 136 : 4945* Mhz 11a > Channel 3 : 2422 Mhz 11g Channel 136 : 4950* Mhz 11a > Channel 4 : 2427 Mhz 11g Channel 137 : 4955* Mhz 11a > Channel 5 : 2432 Mhz 11g Channel 137 : 4960* Mhz 11a > Channel 6 : 2437 Mhz 11g Channel 137 : 4965* Mhz 11a > Channel 7 : 2442 Mhz 11g Channel 137 : 4970* Mhz 11a > Channel 8 : 2447 Mhz 11g Channel 138 : 4975* Mhz 11a > Channel 9 : 2452 Mhz 11g Channel 138 : 4980* Mhz 11a > Channel 10 : 2457 Mhz 11g Channel 138 : 4985* Mhz 11a > Channel 11 : 2462 Mhz 11g > > the 5,3 and 5.8Ghz range is gone > > > this card should show the 2.4b/g range as usual, the 4.9, the 5.3 and the 5.8 > range regdomain 18 gives you b/g channels 1-11 and public safety channels in the range 4942-4985. What you are seeing is that ifconfig does not know how to handle mapping the public safety channels to ieee channel numbers. > > > > ath sysctl from this machine > > hw.ath.hal.swba_backoff: 0 > hw.ath.hal.sw_brt: 10 > hw.ath.hal.dma_brt: 2 > hw.ath.hal.version: 0.9.16.16 > hw.ath.txbuf: 100 > hw.ath.rxbuf: 40 > hw.ath.regdomain: 0 > hw.ath.countrycode: 0 > hw.ath.xchanmode: 1 > hw.ath.outdoor: 1 > hw.ath.calibrate: 30 > hw.ath.dwell: 200 > user.cs_path: /usr/bin:/bin:/usr/sbin:/sbin: > dev.ath.0.%desc: Atheros 5212 > dev.ath.0.%driver: ath > dev.ath.0.%location: slot=8 function=0 > dev.ath.0.%pnpinfo: vendor=0x168c device=0x0013 subvendor=0x1186 > subdevice=0x3a14 class=0x020000 > dev.ath.0.%parent: pci0 > dev.ath.0.rate_interval: 1000 > dev.ath.0.rate_raise: 10 > dev.ath.0.rate_raise_threshold: 10 > dev.ath.0.countrycode: 0 > dev.ath.0.regdomain: 18 > dev.ath.0.slottime: 20 > dev.ath.0.acktimeout: 48 > dev.ath.0.ctstimeout: 48 > dev.ath.0.softled: 0 > dev.ath.0.ledpin: 0 > dev.ath.0.ledon: 0 > dev.ath.0.ledidle: 2700 > dev.ath.0.txantenna: 0 > dev.ath.0.rxantenna: 2 > dev.ath.0.diversity: 0 > dev.ath.0.txintrperiod: 5 > dev.ath.0.diag: 0 > dev.ath.0.tpscale: 0 > dev.ath.0.tpc: 0 > dev.ath.0.tpack: 63 > dev.ath.0.tpcts: 63 > dev.ath.0.monpass: 24 > > > > > setting 0x10 I get then > > Channel 1 : 2412 Mhz 11g Channel 48 : 5240 Mhz 11a > Channel 2 : 2417 Mhz 11g Channel 50 : 5250 Mhz 11a Turbo > Channel 3 : 2422 Mhz 11g Channel 52 : 5260 Mhz 11a > Channel 4 : 2427 Mhz 11g Channel 56 : 5280 Mhz 11a > Channel 5 : 2432 Mhz 11g Channel 58 : 5290 Mhz 11a Turbo > Channel 6 : 2437 Mhz 11g Channel 60 : 5300 Mhz 11a > Channel 7 : 2442 Mhz 11g Channel 64 : 5320 Mhz 11a > Channel 8 : 2447 Mhz 11g Channel 149 : 5745 Mhz 11a > Channel 9 : 2452 Mhz 11g Channel 152 : 5760 Mhz 11a Turbo > Channel 10 : 2457 Mhz 11g Channel 153 : 5765 Mhz 11a > Channel 11 : 2462 Mhz 11g Channel 157 : 5785 Mhz 11a > Channel 36 : 5180 Mhz 11a Channel 160 : 5800 Mhz 11a Turbo > Channel 40 : 5200 Mhz 11a Channel 161 : 5805 Mhz 11a > Channel 42 : 5210 Mhz 11a Turbo Channel 165 : 5825 Mhz 11a > Channel 44 : 5220 Mhz 11a > > ath sysctl from this machine: > > hw.ath.hal.swba_backoff: 0 > hw.ath.hal.sw_brt: 10 > hw.ath.hal.dma_brt: 2 > hw.ath.hal.version: 0.9.16.16 > hw.ath.txbuf: 100 > hw.ath.rxbuf: 40 > hw.ath.regdomain: 0 > hw.ath.countrycode: 0 > hw.ath.xchanmode: 1 > hw.ath.outdoor: 1 > hw.ath.calibrate: 30 > hw.ath.dwell: 200 > dev.ath.0.%desc: Atheros 5212 > dev.ath.0.%driver: ath > dev.ath.0.%location: slot=11 function=0 > dev.ath.0.%pnpinfo: vendor=0x168c device=0x0013 subvendor=0x1186 > subdevice=0x3a14 class=0x020000 > dev.ath.0.%parent: pci0 > dev.ath.0.rate_interval: 1000 > dev.ath.0.rate_raise: 10 > dev.ath.0.rate_raise_threshold: 10 > dev.ath.0.countrycode: 0 > dev.ath.0.regdomain: 16 > dev.ath.0.slottime: 20 > dev.ath.0.acktimeout: 48 > dev.ath.0.ctstimeout: 48 > dev.ath.0.softled: 0 > dev.ath.0.ledpin: 0 > dev.ath.0.ledon: 0 > dev.ath.0.ledidle: 2700 > dev.ath.0.txantenna: 0 > dev.ath.0.rxantenna: 1 > dev.ath.0.diversity: 0 > dev.ath.0.txintrperiod: 5 > dev.ath.0.diag: 0 > dev.ath.0.tpscale: 0 > dev.ath.0.tpc: 0 > dev.ath.0.tpack: 63 > dev.ath.0.tpcts: 63 > dev.ath.0.monpass: 24 It turns out that handling this correctly is more involved than I remembered. Not only are the public safety channels special in their freq<->ieee# mapping but they also require 1/4- and 1/2-speed tx rates. The linux code handles this but it's done with some awkward code that I'd prefer to cleanup before integrating into freebsd. Regardless I suspect most people aren't going to use these channels since they require a special license (search for "public safety channels" and you'll find the relevant documentation). To be honest I have no idea why vendors are shipping cards with these channels enabled. I can hack the ath driver to just ignore the public safety channels and may do that. Otherwise it seems like the best thing is to change the regdomain in the eeprom (those who don't know how can find it with a search engine). Sam
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?4453F025.90001>