Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp271203ybi; Tue, 18 Jun 2019 22:30:49 -0700 (PDT) X-Google-Smtp-Source: APXvYqx3Cs7jc4gEnWDvD8g2WwrEByT2Y1fno+rTwS4Fx5lTTR4XPwXFRnMjK3f7lfb+r+F9qYPH X-Received: by 2002:a17:902:7b84:: with SMTP id w4mr8759417pll.22.1560922249205; Tue, 18 Jun 2019 22:30:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560922249; cv=none; d=google.com; s=arc-20160816; b=CnQqgzVmYn4L8OEuIgqjqGKUx7aJOaVT/XaKf0Ww5xKBW+OtyeKo0pJMclEr4YOcDJ uABCRxd/l2n4niwfNTAvztaZDDUx721LaIbCVuxfMaYBGqtrY/TJe4KU9AwUDKHnS8I2 KWH4Uyja6+kiTF6AqoV8i1BKI6gL6RK35E+sm5wB/uYwVawW0xiFpQDF2SMYYEqupO6o NZhzXpcsGkVIoCe0U7e6hYGBZ0znmD4NE/eXDdoN7WhNnW6K5gkokexCo/7HKaN3nxt3 5SB99X5vBuHw+/bso/MhFM/yRQCggig2i/YIZJRnc8GXo+/lBDP3GKCes46KHGwTB6Jt pMVg== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=Vj1KH0QbaZDrkIdJaVh0D3ULilb/oICAwMz7r9g85eU=; b=aXKoIm7+k81NoI6Klco5mHduTo1vgUnRNLvCr7no/PcwbLdnzWhERonsxrLSCCAEe9 Jrbm1u5keR0H2ETP3t/Qm4efmG2he2fyt8YCZjlO8jFXupq7zXRDwHwuIFv8UX0li4F5 lwmTnEPNQWEWdkq83xLmR/bh4KST1ZlSsdscywuD929o0/rp6fPLHg8+GzrxLZ006Ptp 7AQHa8R27xl8SY9nLfJE9wM0SpkgXStwiFQlcIjKadjnOnakzABACrZIhFnlc5L1cGBS +UVn+HzEIU7sCCIdNxNzvrvOtBlWz4fH2+z10E9M0W9cuZHXpAAHt4jR7JZNBvFVTqK+ c3bQ== 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 h12si2148898pgr.325.2019.06.18.22.30.33; Tue, 18 Jun 2019 22:30:49 -0700 (PDT) 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 S1730699AbfFSFa2 (ORCPT + 99 others); Wed, 19 Jun 2019 01:30:28 -0400 Received: from nbd.name ([46.4.11.11]:59098 "EHLO nbd.name" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730283AbfFSFa1 (ORCPT ); Wed, 19 Jun 2019 01:30:27 -0400 Received: from pd95fd3e4.dip0.t-ipconnect.de ([217.95.211.228] helo=bertha.fritz.box) by ds12 with esmtpa (Exim 4.89) (envelope-from ) id 1hdTAv-000779-Hl; Wed, 19 Jun 2019 07:30:25 +0200 From: John Crispin To: Johannes Berg Cc: linux-wireless@vger.kernel.org, John Crispin , Shashidhar Lakkavalli Subject: [PATCH V2 1/2] mac80211: add support for parsing ADDBA_EXT IEs Date: Wed, 19 Jun 2019 07:30:19 +0200 Message-Id: <20190619053020.17121-2-john@phrozen.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190619053020.17121-1-john@phrozen.org> References: <20190619053020.17121-1-john@phrozen.org> 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 ADDBA_EXT IEs can be used to negotiate the BA fragmentation level. Signed-off-by: Shashidhar Lakkavalli Signed-off-by: John Crispin --- include/linux/ieee80211.h | 8 ++++++++ net/mac80211/ieee80211_i.h | 1 + net/mac80211/util.c | 7 +++++++ 3 files changed, 16 insertions(+) diff --git a/include/linux/ieee80211.h b/include/linux/ieee80211.h index 538d502902c0..cf6b69bcbc52 100644 --- a/include/linux/ieee80211.h +++ b/include/linux/ieee80211.h @@ -884,6 +884,14 @@ struct ieee80211_tpc_report_ie { u8 link_margin; } __packed; +#define IEEE80211_ADDBA_EXT_FRAG_LEVEL_MASK GENMASK(2, 1) +#define IEEE80211_ADDBA_EXT_FRAG_LEVEL_SHIFT 1 +#define IEEE80211_ADDBA_EXT_NO_FRAG BIT(0) + +struct ieee80211_addba_ext_ie { + u8 data; +} __packed; + struct ieee80211_mgmt { __le16 frame_control; __le16 duration; diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h index 9e8474782a60..acbf5384ad15 100644 --- a/net/mac80211/ieee80211_i.h +++ b/net/mac80211/ieee80211_i.h @@ -1512,6 +1512,7 @@ struct ieee802_11_elems { u8 max_bssid_indicator; u8 dtim_count; u8 dtim_period; + const struct ieee80211_addba_ext_ie *addba_ext_ie; /* length of them, respectively */ u8 ext_capab_len; diff --git a/net/mac80211/util.c b/net/mac80211/util.c index 34ce0ed67e59..ddef5d116431 100644 --- a/net/mac80211/util.c +++ b/net/mac80211/util.c @@ -1203,6 +1203,13 @@ _ieee802_11_parse_elems_crc(const u8 *start, size_t len, bool action, elems->cisco_dtpc_elem = pos; break; + case WLAN_EID_ADDBA_EXT: + if (elen != sizeof(struct ieee80211_addba_ext_ie)) { + elem_parse_failed = true; + break; + } + elems->addba_ext_ie = (void *)pos; + break; case WLAN_EID_TIMEOUT_INTERVAL: if (elen >= sizeof(struct ieee80211_timeout_interval_ie)) elems->timeout_int = (void *)pos; -- 2.20.1