On Wed, Aug 27, 2008 at 11:25 PM, Michael Buesch <mb@xxxxxxxxx> wrote: > On Wednesday 27 August 2008, Tomas Winkler wrote: >> > John W. Linville (1): >> > mac80211: quiet chatty IBSS merge message >> >> This patch is correct yet it suppresses an important warning, meaning >> that you have constant IBSS reconnection, remove all connected station >> and adding them again, This greatly degraded performance. This is >> caused by inability to adjust to TSF of the IBSS leader >> >> <snipt> >> static int ieee80211_sta_join_ibss(struct net_device *dev, >> struct ieee80211_if_sta *ifsta, >> struct ieee80211_sta_bss *bss) >> ..... >> /* Remove possible STA entries from other IBSS networks. */ >> sta_info_flush_delayed(sdata); >> </snip> > > I fail to see how the TSF could be related to an ever reconnecting > station. Can you elaborate on what happens? > > I was under the impression that the firmware would handle TSF stuff. > Also the "IBSS leader" is a new thing to me. I remember from the specs > that the device should accept the TSF from _any_ beacon. Not just a > "leader". Am I mislead? :) What is happening that IBSS station should adopt TSF of the oldest station i.e. with highest TSF. This is also leader of the IBSS (this is not spec definition just local jargon) Adaptation mean we adjust to the same clock if (beacon_timestamp > rx_timestamp) merge beacon_timestamp (what STA advertise in the beacon ) is bigger then time reception of the beacon according our local TSF. If this is true then there is merging meaing we call reset_tsf, remove all the stations form the list and add the leader. In IBSS all the station race on sending beacon. so adjusting clock is important for power save. > I also fail to see how we could _ever_ set the TSF to something remotely > correct from the driver because of the FIFO delay. > Exactly also iwlwifi driver is not able to really adjust TSF and always lag behind we've really tried to make it work...no success. The result is you are constantly removing and joining the same station. The patch from Assaf just disable reporting RX timestamp to mac and thus disabling merging which gives incorrect spec behavior but smooth traffic. Actually we've checked few cards including broadcom and various windows NICs and non of them implements this correctly so this WA is probably the solution. Other solution would be to mark leader with highest TSF and not reconnecting to the same station again and again. Last solution would be to remove this merging all together but then I'm not sure if Bruno added this code just implement the spec or really tested it with any hardware. I'm not sure if any vendor implements PS in IBSS so this merging is probably not important anyway. >> >> > Assaf Krauss (1): >> > iwlwifi: W/A for the TSF correction in IBSS > > I cannot find this patch in wireless-testing and I don't > have a copy of wireless-2.6 here. Can you send me the patch, or > explain what it does? > Explained above just disable get_tsf and also report to mac by removing line rx_status.flag |= RX_FLAG_TSFT; Tomas -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html