Return-path: Received: from s3.sipsolutions.net ([144.76.43.152]:48030 "EHLO sipsolutions.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752310AbaC1IcQ (ORCPT ); Fri, 28 Mar 2014 04:32:16 -0400 Message-ID: <1395995531.4175.3.camel@jlt4.sipsolutions.net> (sfid-20140328_093222_597560_A8FC0F8A) Subject: Re: [PATCH] ath10k: dont call csa_finish more than once From: Johannes Berg To: Michal Kazior Cc: "ath10k@lists.infradead.org" , linux-wireless Date: Fri, 28 Mar 2014 09:32:11 +0100 In-Reply-To: (sfid-20140324_073736_101334_2EBC9F24) References: <1395410520-26939-1-git-send-email-michal.kazior@tieto.com> <1395411440.4164.15.camel@jlt4.sipsolutions.net> <1395414428.4164.16.camel@jlt4.sipsolutions.net> (sfid-20140324_073736_101334_2EBC9F24) Content-Type: text/plain; charset="UTF-8" Mime-Version: 1.0 Sender: linux-wireless-owner@vger.kernel.org List-ID: On Mon, 2014-03-24 at 07:37 +0100, Michal Kazior wrote: > > Yeah I guess. What was the reason for this though? Here it's multi-vif? > > Before I think we were talking about races? > > Before multi-vif if ieee80211_csa_finalize() failed and left > csa_active==true driver could end up poking the csa_finalize_work() > over and over again I guess? I think the concern previously was about races, where finalize_work doesn't actually get to run before the next beacon. > For multi-vif csa using reservation there are 2 reasons: > a) channel switches across interfaces may not be tightly > synchronized. I did tests where 2 long (cs_count=100) channel switches > were a few seconds apart. In that case driver poked csa_finalize work > quite a lot resulting in a mess. > b) my current approach has the following flow: > > 1. reserve_chanctx() > 2. (some time later) driver calls csa_finish, and csa_finalize calls > use_reserved_chanctx() because reserved_chanctx is set > 3. (possibly some time later, for multi-vif reservations) csa_finalize > is called again but this time without reserved_chanctx, so it verifies > if bss_conf.chandef is csa_chandef (after successful reservation it > should be). > > This means if driver would poke csa_finalize() more than once then > use_reserved_chanctx() would be called again and again as a result. Yeah but that seems better to catch in mac80211? johannes