Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp4280212ybg; Tue, 29 Oct 2019 04:57:22 -0700 (PDT) X-Google-Smtp-Source: APXvYqwjMmTYWD/CTOFYonJC9N1aZpUiIttQO88Dy8feXTBKHFo4Sqrwq93dFBr86EDSSTsI+nk3 X-Received: by 2002:a17:906:79c9:: with SMTP id m9mr2723809ejo.297.1572350242881; Tue, 29 Oct 2019 04:57:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572350242; cv=none; d=google.com; s=arc-20160816; b=Z5YlNRtjyzvk4dY33al5e2ihNwkdl29ZITh+sQ4QlPrlaWDKkMLotKYjBhc9daJBuC qPXIiS9ixogtVBRFUtqAarzrRvPIj3efqEOSMLMUVJiIq4dXHY5uFI3O7N7dssisQxfT zGVl3RwNx5F72Mla+f+AB1R9TwVZPUplSo4aiFRwgHsKIpApGoDTa6Zkv7uCMdgluDSP 6Grqsf0UK60NhtBtu8CKo13TINJ0AUmImAhr+oDlc9HtESKQ/uu0Wf4mljTCpaeZEAp/ afKsVSpFZAAYzYlseWJTZwtfDv9tTJtsCDWOff04zpaLvJCgrHGNFwBqpc/+u51cPsMA DACQ== 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=jrgXcG9GtKMjU8ALPQSK5nXywkbmK2y7D8z3M4R1u2s=; b=y75Lr9zzeJvZ90jzhUJm0pu488HvUMWpxwVRrsQ968Egji36rglW775DSbyOD4Fo3n uFzseHEdjmfYKLnoqSkF/BzuFS40aY++wSrNbMKx1iPOe+WJSQdm0ESE1ALBa0GuAnxV x/+0BDLyAf0jJ51CNDzGt9U3udJjrbHUS1V01pTw1YDml3z+gK/Ug8HVtVnfG48+7JML /FkkespUVcrmo18SGPTP32g1hPmuUg51vayVn2xpU8oYg5shyNPX3L1dsYF/GTAWCzjc 4Ayr9pQ9bNYrotjq8DwDqqeqyn6xpyNsFiZziw8xAH/FyV8kgcgtYpyJT4vAy5VsMHja Cpdw== 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 s7si7392122eds.215.2019.10.29.04.56.48; Tue, 29 Oct 2019 04:57:22 -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 S1730377AbfJ2L4Q (ORCPT + 99 others); Tue, 29 Oct 2019 07:56:16 -0400 Received: from smail.rz.tu-ilmenau.de ([141.24.186.67]:44169 "EHLO smail.rz.tu-ilmenau.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728432AbfJ2L4Q (ORCPT ); Tue, 29 Oct 2019 07:56:16 -0400 Received: from localhost.localdomain (unknown [141.24.212.108]) (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 DD3D8580063; Tue, 29 Oct 2019 12:56:14 +0100 (CET) From: Markus Theil To: Johannes Berg Cc: linux-wireless@vger.kernel.org, Markus Theil Subject: [PATCH] nl80211: allow more operations for mesh and ad-hoc interfaces Date: Tue, 29 Oct 2019 12:56:02 +0100 Message-Id: <20191029115602.78990-1-markus.theil@tu-ilmenau.de> X-Mailer: git-send-email 2.23.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 change allows mesh and ad-hoc interfaces to change beacons and tx queue settings. The direct change of these settings should be ok for these kind of interfaces and should maybe only forbidden for station-like interface types. Signed-off-by: Markus Theil --- net/wireless/nl80211.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index d1451e731bb8..c4ff8c2033af 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c @@ -2923,7 +2923,9 @@ static int nl80211_set_wiphy(struct sk_buff *skb, struct genl_info *info) return -EINVAL; if (netdev->ieee80211_ptr->iftype != NL80211_IFTYPE_AP && - netdev->ieee80211_ptr->iftype != NL80211_IFTYPE_P2P_GO) + netdev->ieee80211_ptr->iftype != NL80211_IFTYPE_P2P_GO && + netdev->ieee80211_ptr->iftype != NL80211_IFTYPE_MESH_POINT && + netdev->ieee80211_ptr->iftype != NL80211_IFTYPE_ADHOC) return -EINVAL; if (!netif_running(netdev)) @@ -4831,7 +4833,9 @@ static int nl80211_set_beacon(struct sk_buff *skb, struct genl_info *info) int err; if (dev->ieee80211_ptr->iftype != NL80211_IFTYPE_AP && - dev->ieee80211_ptr->iftype != NL80211_IFTYPE_P2P_GO) + dev->ieee80211_ptr->iftype != NL80211_IFTYPE_P2P_GO && + dev->ieee80211_ptr->iftype != NL80211_IFTYPE_MESH_POINT && + dev->ieee80211_ptr->iftype != NL80211_IFTYPE_ADHOC) return -EOPNOTSUPP; if (!rdev->ops->change_beacon) -- 2.23.0