Bug 11802
Summary: | prism 2.5 broke in 2.6.27 | ||
---|---|---|---|
Product: | Drivers | Reporter: | Yasen Balev (fraxinus.excelsior) |
Component: | network-wireless | Assignee: | drivers_network-wireless (drivers_network-wireless) |
Status: | CLOSED CODE_FIX | ||
Severity: | normal | CC: | akpm, johannes |
Priority: | P1 | ||
Hardware: | All | ||
OS: | Linux | ||
Kernel Version: | 2.6.27 | Subsystem: | |
Regression: | Yes | Bisected commit-id: |
Description
Yasen Balev
2008-10-21 13:26:14 UTC
Try this patch. --- everything.orig/drivers/net/wireless/hostap/hostap_wlan.h 2008-10-24 16:27:46.000000000 +0200 +++ everything/drivers/net/wireless/hostap/hostap_wlan.h 2008-10-24 16:29:17.000000000 +0200 @@ -918,9 +918,12 @@ struct hostap_interface { /* * TX meta data - stored in skb->cb buffer, so this must not be increased over - * the 40-byte limit + * the 48-byte limit. + * THE PADDING THIS STARTS WITH IS A HORRIBLE HACK THAT SHOULD NOT LIVE + * TO SEE THE DAY. */ struct hostap_skb_tx_data { + unsigned int __padding_for_default_qdiscs; u32 magic; /* HOSTAP_SKB_TX_DATA_MAGIC */ u8 rate; /* transmit rate */ #define HOSTAP_TX_FLAGS_WDS BIT(0) (In reply to comment #1) The patch works, thank you. Shoud we consider the "HORRIBLE HACK" worse than the driver in 2.6.26? > Try this patch. > Johannes, could you please ensure that this patch (or whatever patch we end up using) gets cc'ed to stable@kernel.org for the backport? Thanks. Sorry, forgot to add myself as CC to the patch so I missed your note. Let me explain the patch a bit: the networking layer mandates that the skb->cb is always owned by whoever has the skb queued. This commonly is first the IP layer, then the qdisc, and finally the driver. This driver, on the other hand, puts information into the skb->cb and then hands the skb back to the qdisc layer. It has always done that, and it has always been wrong of it to assume that the cb would be untouched when the skb got back to the driver's second network interface. Now, it still has worked most of the time because the default qdisc never touched skb->cb until 2.6.27, where the qdisc layer started using four bytes in skb->cb unconditionally. These four bytes are reserved by the patch above, and then the information the hostap driver needs is left intact across the qdisc layer. Actually really fixing this would probably mean a complete rewrite of the hostap driver, or, preferably, porting the STA-mode bits to the orinoco driver and the AP-mode bits to mac80211 to get rid of hostap completely, it already overlaps for some hardware but supports WPA for more hardware than orinoco. Or we can just put in this hack and wait until all the hardware has been replaced. I wouldn't recommend building an AP with this old hardware anyway because getting an ath5k or b43 card is cheap and supports many more features, for example encryption offloaded to the hardware. I don't really want to make a decision about this patch just because I analysed why and how it breaks, but somebody will have to I guess. Johannes, thank you for your explanation. Sorry to say that I am even less qualified to decide what to do with the bug. The fix works for me, here and now. p.s. Yes, I know that Atheros or Broadcom board would be better. But, since no one's life depends on this very AP and 11Mbps is pretty much enough, I desided to use a board already scrapped. the above patch produces the following on an openwrt 2.6.27.4 x86 system: wifi2: 00:02:6f:35:8f:21 assoc_cb - STA associated ------------[ cut here ]------------ WARNING: at kernel/softirq.c:136 () Modules linked in: hostap_pci hostap ath_pci ath_rate_minstrel ath_hal(P) wlan_scan_sta wlan ieee80211 ieee80211_crypt Call Trace:[<8000e990>] 0x8000e990 [<8000e990>] 0x8000e990 [<80024cb8>] 0x80024cb8 [<c010b3f0>] 0xc010b3f0 [<c0116b64>] 0xc0116b64 [<c0111ee0>] 0xc0111ee0 [<c010f36c>] 0xc010f36c [<c011a874>] 0xc011a874 [<c00b8548>] 0xc00b8548 [<c0096538>] 0xc0096538 [<c008fdbc>] 0xc008fdbc [<8016b6e4>] 0x8016b6e4 [<8002ad38>] 0x8002ad38 [<801648fc>] 0x801648fc [<80183710>] 0x80183710 [<8017ee44>] 0x8017ee44 [<c00bbcb8>] 0xc00bbcb8 [<c00b175c>] 0xc00b175c [<c00b67e4>] 0xc00b67e4 [<80155870>] 0x80155870 [<80004ec0>] 0x80004ec0 [<c00b7d2c>] 0xc00b7d2c [<80155870>] 0x80155870 [<c011cc8c>] 0xc011cc8c [<8015e47c>] 0x8015e47c [<8002f04c>] 0x8002f04c [<8002a418>] 0x8002a418 [<8002a4fc>] 0x8002a4fc [<8002aa84>] 0x8002aa84 [<8002a924>] 0x8002a924 [<80001444>] 0x80001444 [<80001444>] 0x80001444 [<80001660>] 0x80001660 [<8000f528>] 0x8000f528 [<8000b660>] 0x8000b660 [<80001680>] 0x80001680 ---[ end trace 276a316f0ed04cd6 ]--- wifi2: STA 00:02:6f:35:8f:21 did not ACK activity poll frame wifi2: sending disassociation info to STA 00:02:6f:35:8f:21(last=4294928330, jiffies=36286) wifi2: sending deauthentication info to STA 00:02:6f:35:8f:21(last=4294928330, jiffies=36536) You're going to have to provide symbols for that trace, and it's surely not this patch causing it but an unrelated problem. |