Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp3557545ybc; Thu, 21 Nov 2019 10:04:01 -0800 (PST) X-Google-Smtp-Source: APXvYqwG44N6/6kdnQYIAzD8PY2atBxipzXzu5v7ys74sCU+dWOSNlWd5bPsz97TVTWxFswAEsx9 X-Received: by 2002:a17:906:c57:: with SMTP id t23mr15467055ejf.240.1574359441298; Thu, 21 Nov 2019 10:04:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574359441; cv=none; d=google.com; s=arc-20160816; b=lorh6YJtHyqyb2FHOllKpCtO3+4AjIHQRkH9PO8mxTSUxJNTor+iMpaCu4oJKEhmDk njrFtdTmwuwC/iGOqCbdriDSSp6hZj3C/Enq0WcaKSP4cEeTB0KV8oH+18XnQ1qIhAla u1yIVuegPH/VpWIVhvm61ZXvKrmESi0nqi0uVYkBX+9DoLfEJZUvFtdx7tziDGmNZKti z+/d37eYGnfsXcGVksO//gfL4MPZ2JQkx6Wj9rWJyEPSbMWuUwqClJgQyFxxnM6GTDEP EE5dJDRE0EvTuE+01jVdZQCZjfmvTEM7xklbj57mEymHeiRmzzhchPRYEl7fs3ap/lPf G4+Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=nCjZPDPc7m3fNGft7utta//I5XI3Pn2PuDxZ71Wvbos=; b=mMYuSM640U+BI53mSQMxuW8Xx53M1bd1rHmv7feH4dVt2y0pX+nSRIAnxe8K7Im1lt 05NSHt2XwmD9Rvw0ziGaDW2YXhoL8iaucz468BthwHHwRkkjpHZl4DBIL4f8JbX8eJX4 N9LzxtUmrNjiKLQSJalXaB7KpeS61O0HKRxaJOWnpRT4ajCl9pc7np+aNRvkJe3Ml145 w3xRLjZ9YXAEHnLBKY1lktAGrCK0VkdGwJPitZcjhvmiqja2Gj5vWqF7UaEduv05fSji WJPx9ci6XEFp3/zIzfRsyY/RkLiGagse/kjsVAPeWECEuKUxGlfa2+RRNmk9I9HikF0p wEoA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i16si2277222ejh.75.2019.11.21.10.03.35; Thu, 21 Nov 2019 10:04:01 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726880AbfKUSA0 (ORCPT + 99 others); Thu, 21 Nov 2019 13:00:26 -0500 Received: from smail.rz.tu-ilmenau.de ([141.24.186.67]:53950 "EHLO smail.rz.tu-ilmenau.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726541AbfKUSAZ (ORCPT ); Thu, 21 Nov 2019 13:00:25 -0500 Received: from localhost.localdomain (unknown [141.24.207.101]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smail.rz.tu-ilmenau.de (Postfix) with ESMTPSA id D6BD0580065; Thu, 21 Nov 2019 19:00:23 +0100 (CET) From: Markus Theil To: nbd@nbd.name Cc: linux-wireless@vger.kernel.org, lorenzo.bianconi@redhat.com, Stanislaw Gruszka , Markus Theil Subject: [PATCH v8 0/6] mt76: channel switch support for USB devices Date: Thu, 21 Nov 2019 18:59:55 +0100 Message-Id: <20191121180001.22451-1-markus.theil@tu-ilmenau.de> X-Mailer: git-send-email 2.24.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org This patch series adds channel switch support for mt76 usb interfaces. When testing, I noticed that between 5 or 7 consecutive beacons had the identical channel switch count set. After some debugging I found out, that beacon copying over usb took far too long (up to 700ms for one call of mt76x02u_pre_tbtt_work). Therefore the first five patches speed up beacon copying and provide beaconing fixes. The last patch enables channel switch support also for usb interfaces. Thanks to Stanislaw and Lorenzo for their help. v8: * fix mbss beaconing * fix adding vifs with idx 8 * fix memory leaks by dropping beacon buffer * permanently enable 7 additional bss to save another usb call and make beacon masking easier * added beacon_prepare call again, which now also clears beacon_data_mask v7: * fix mbss beacon settings (incorrect try) * fix compilation with latest upstream v6: * use min_t in mt76u_copy * use round_up in mt76u_copy * use additional copy for mmio beacon set again v5: * ommit empty mt76x2u_channel_switch_beacon * copy txwi into beacon skb v4: * use multiple of 4 len for usb copy again v3: * fixed checkpatch errors v2: * correctly track beacon data mask * clean-ups * make channel switch fn static (reported by kbuild test robot) Markus Theil (6): mt76: mt76x02: ommit beacon slot clearing mt76: mt76x02: split beaconing mt76: mt76x02: add check for invalid vif idx mt76: mt76x02: remove a copy call for usb speedup mt76: speed up usb bulk copy mt76: mt76x02: add channel switch support for usb interfaces drivers/net/wireless/mediatek/mt76/mt76.h | 2 +- drivers/net/wireless/mediatek/mt76/mt76x02.h | 1 - .../wireless/mediatek/mt76/mt76x02_beacon.c | 83 ++++++++----------- .../net/wireless/mediatek/mt76/mt76x02_mac.c | 2 + .../net/wireless/mediatek/mt76/mt76x02_mac.h | 5 +- .../net/wireless/mediatek/mt76/mt76x02_mmio.c | 4 + .../wireless/mediatek/mt76/mt76x02_usb_core.c | 21 +++-- .../net/wireless/mediatek/mt76/mt76x02_util.c | 6 +- drivers/net/wireless/mediatek/mt76/usb.c | 24 ++++-- 9 files changed, 79 insertions(+), 69 deletions(-) -- 2.24.0