**This is an old revision of the document!** ----

A PCRE internal error occured. This might be caused by a faulty plugin

====== Joshua Oreman: 802.11 wireless development ====== ===== Journal Week 3 ===== ==== Monday, 8 June ==== **It's ALIIIIIVE!** After a long day of head-scratching and bug-squashing, I've gotten the wireless to work in my test system with no apparent problems. :-) First, the commits: * [[http://git.etherboot.org/?p=people/oremanj/gpxe.git;a=commit;h=44dc8f43a277c84afe6e31c0906fc08acc386748| [drivers rtl8180] Debugging tweaks, decrease ring size, ignore DMA errors]] * [[http://git.etherboot.org/?p=people/oremanj/gpxe.git;a=commit;h=cf950f4e53e32ee74e02c8ba5d2bc8da93868738| [netdevice] Adjust maximum link-layer header length for 802.11]] (then merged with mainline and resolved the conflict) * [[http://git.etherboot.org/?p=people/oremanj/gpxe.git;a=commit;h=255f3fdc6c75ca8419f75748f62412d5fb69a55f| [dhcp] Await link-up before starting DHCP]] * [[http://git.etherboot.org/?p=people/oremanj/gpxe.git;a=commit;h=8182fff820119754b78c3ec8ed6f4de7884777e1| [802.11] Bugfix and minor improvement potpourri]] Also, the obligatory screenshot: {{gpxe-wifi-load.jpg?160x120|gPXE loading a script over 802.11}} I've successfully loaded both the "smoke test" script in that screenshot, and the [[http://etherboot.org/gtest/gtest.gpxe|more rigorous gtest.gpxe]] that loads tomsrtbt. Load time was about 57 seconds from "dhcp net0" to "Uncompressing Linux...", including the time it took for me to type the "chain" command. Compared to 47 seconds on the wired rtl8139 NIC in the same box, which didn't have to go through a 5-second network probe sequence, that's not too bad. The DMA issue I noted on Sunday turned out to be more or less a false alarm. Upon checking the Linux driver I discovered that it simply ignores those DMA_FAIL errors (drops the packet with no record thereof), and when I modified my code to do the same (and fixed a bunch of bugs in the MAC layer), everything was able to work. It may be that we're suffering in performance due to all the errors, and that they could be fixed by some configuration setting, but as Realtek won't give up a datasheet and no other open-source OS has drivers I could compare with, this is the best I can do for now. My working hypothesis is that DMA_FAIL might have been overloaded to apply also to "the radio gave me garbage for this one" scenarios. Things left to do on 802.11 include: * [easy] Provide CTS protection if the network asks for it; required for 802.11 g/b interoperability. * [easy] If we don't get a response to our assoc/auth packets within a few seconds during the association phase, resend them. * [easy] Provide command-line facilities to see what the card's doing, or extend `ifstat' to show it. (Channel, BSSID, signal strength, etc; this stuff can be very useful for network debugging.) Possibly provide a facility to scan for all networks (one way of doing that is prototyped in net80211.h, but I haven't implemented it). * [easy] Include error message tables for the 802.11 status and reason codes. These would be rather big, but "association denied - status 12" is of no help to anyone who doesn't have the 802.11 standard on hand. Perhaps we should just teach them to gpxebot, and/or figure out a way to encode them into the 32-bit return code space. * [medium] Provide some means of intelligent rate control (decrease rate if we're dropping a lot of packets, cautiously increase it if things seem to be going swimmingly). * [hard] Encryption. * [hard] Driver for ath5k cards (very common, very powerful chipset with a cooperative manufacturer). Maybe more drivers than that if I have time, but ath5k is quite a bit more complicated than rtl8180/8185. It probably goes without saying, but I'm really excited about this. :-) I probably won't be doing much work on gPXE tomorrow, because I have to catch up on some other things and I'd like to see some other people successfully test this before I forge boldly ahead.


QR Code
QR Code soc:2009:oremanj:journal:week3 (generated for current page)