From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from nbd.name (nbd.name [IPv6:2a01:4f8:131:30e2::2]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by lists.bufferbloat.net (Postfix) with ESMTPS id B76F43B25E for ; Mon, 5 Sep 2016 14:45:04 -0400 (EDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=nbd.name; s=20160729; h=Content-Transfer-Encoding:Content-Type:In-Reply-To:MIME-Version:Date:Message-ID:From:Cc:References:To:Subject; bh=Vi4jJqx4pVs4/xZwHAgj2B4w/8LbxUIiPaTMw12Cs9A=; b=d6EJOD7eF0Pz3exZl2U/ojQwd1as2nHq+G8bXoReGYsLRdHo4ZaNG4p5g6yvu0yWLiRSX4/ICLit2oTSxXt8pYlm4Bc1Zq5Jld0+tk9kZMQI1VkmjMlX+Sjl7haOSFO5q3QgT1shJ+pErxqYRTW/S43rU29yrf2Fgzl1uZ7/Ggo=; To: =?UTF-8?Q?Toke_H=c3=b8iland-J=c3=b8rgensen?= References: <20160902134104.29309-1-toke@toke.dk> <20160905113042.22271-1-toke@toke.dk> <8ffb5fee-78c1-79aa-2297-e125c59b092c@nbd.name> <87wpiq9qj9.fsf@toke.dk> Cc: make-wifi-fast@lists.bufferbloat.net, linux-wireless@vger.kernel.org From: Felix Fietkau Message-ID: <41f0fbc5-c837-65b4-47c0-c875b774f8d5@nbd.name> User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.11; rv:45.0) Gecko/20100101 Thunderbird/45.3.0 MIME-Version: 1.0 In-Reply-To: <87wpiq9qj9.fsf@toke.dk> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Mailman-Approved-At: Mon, 28 Nov 2016 08:47:10 -0500 Subject: Re: [Make-wifi-fast] [PATCH v7] mac80211: Move reorder-sensitive TX handlers to after TXQ dequeue. X-BeenThere: make-wifi-fast@lists.bufferbloat.net X-Mailman-Version: 2.1.20 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Date: Mon, 05 Sep 2016 18:45:04 -0000 X-Original-Date: Mon, 5 Sep 2016 20:44:59 +0200 X-List-Received-Date: Mon, 05 Sep 2016 18:45:04 -0000 On 2016-09-05 19:59, Toke Høiland-Jørgensen wrote: > Felix Fietkau writes: > >> On 2016-09-05 13:30, Toke Høiland-Jørgensen wrote: >>> The TXQ intermediate queues can cause packet reordering when more than >>> one flow is active to a single station. Since some of the wifi-specific >>> packet handling (notably sequence number and encryption handling) is >>> sensitive to re-ordering, things break if they are applied before the >>> TXQ. >>> >>> This splits up the TX handlers and fast_xmit logic into two parts: An >>> early part and a late part. The former is applied before TXQ enqueue, >>> and the latter after dequeue. The non-TXQ path just applies both parts >>> at once. >>> >>> Because fragments shouldn't be split up or reordered, the fragmentation >>> handler is run after dequeue. Any fragments are then kept in the TXQ and >>> on subsequent dequeues they take precedence over dequeueing from the FQ >>> structure. >>> >>> This approach avoids having to scatter special cases for when TXQ is >>> enabled, at the cost of making the fast_xmit and TX handler code >>> slightly more complex. >> In my test, this one completely breaks ath9k with the txq patch. >> One or two packets go through, then tx stalls completely. > > I assume you are testing on LEDE? It requires a change to work with the > patch in the LEDE tree that puts hdrlen into ieee80211_tx_data. Did you > fix that? Otherwise multicast (and possibly other things) will break > badly. You're right, I missed that. > I have a version that should work with LEDE here: > > https://kau.toke.dk/git/lede/tree/package/kernel/mac80211/patches/346-mac80211-move-reorder-sensitive-tx-handlers-to-after-TXQ-dequeue.patch That one works fine in my test. Thanks, - Felix