Received: by 2002:ab2:6a05:0:b0:1f8:1780:a4ed with SMTP id w5csp374497lqo; Fri, 10 May 2024 02:32:55 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUVQvjnEMg/W19QPBTE9OqqnUhExlFKyIO/6kFPQlQndLCnrfV2W0TCysN0jHIztWHI92Dx+2CDuWUshn2OLJ3E1mHRLF7+PzmSMpfgTw== X-Google-Smtp-Source: AGHT+IHKyY4/aS0huidz5sf/WyfTmb4A3KS3QLvqQBmjv6vlikUqj4Kw0AQiQr4sgedCZPgSECV/ X-Received: by 2002:a05:6830:14cd:b0:6f0:706c:1382 with SMTP id 46e09a7af769-6f0e91099a5mr2091051a34.7.1715333575026; Fri, 10 May 2024 02:32:55 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1715333574; cv=pass; d=google.com; s=arc-20160816; b=pcGsKrGHWorDC9XEbjTzlvO6FnDVyXNfQNWkpdv1GRB8lSBKxLhWAppd1J/E2mZPEn GU06A2GA0Hx2E5WwMvXtAnfWr2KoWb98Q/+OFurL/PsGToK0I2bInB7zGP+mbfJJsSZb vd50QOP26TEpSdaIaZbBb98EzNNRqqgIroeBM0r4ocdkCxZF7w48fQOnGRGa5oJ9N22X /pQOz19q72kCLlaC9wmnKtuhdmKwr5EdD4oXjOx39MYX5M27arfkr/vmyEp9NO04oBfc EY97E5yeaYOa0pI9pIhRp69/l0YSZ1j3ouc5WEsmtFKCvK4dWJ/zw5m/+/IXDOH8Aock jkDA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from:dkim-signature; bh=/ouwYcx5LwcRnlw9YQcs5oI/xIme3lYSJKLo4Qt3eYs=; fh=08sSKwCm4boYGwwEDuPkh4zjgQ1ztkfghlDGb0QBclY=; b=P9zJpWYs+OGj+gFJInvzQxWV03r9ryIj08VofUNjA9AL3MGqvKA4NqfaMOoyYOuHdn 1EPddyVfVj5HITwpFi66Wgkgj2rL/qtktMecXcIfy/cQTBJPODMfvWx/i9j62AecF47w iLb5NDtl9606ElDmxqrfr6nhEUZ4HdJPUB0X9fyXL6soAs2n1F6FseOttOq3+p3SJ/Yp lw48N2TAg0mU1tli2RLlzKucJ7nXIgwAfQFbx7z3ZD9sLLanmbnBTAJcAkbv/4s9a4kc G23WAxZn3NCmd/Tx/hO+SOQPRh3VmKkzybvGd11JySoAT34Iy5u4Qo5knEMIi0+GbpNx pL8Q==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@sipsolutions.net header.s=mail header.b=vNZMwDs0; arc=pass (i=1 spf=pass spfdomain=sipsolutions.net dkim=pass dkdomain=sipsolutions.net dmarc=pass fromdomain=sipsolutions.net); spf=pass (google.com: domain of linux-wireless+bounces-7442-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-wireless+bounces-7442-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=REJECT dis=NONE) header.from=sipsolutions.net Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id 41be03b00d2f7-634103f5bd3si3561039a12.416.2024.05.10.02.32.54 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 10 May 2024 02:32:54 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless+bounces-7442-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@sipsolutions.net header.s=mail header.b=vNZMwDs0; arc=pass (i=1 spf=pass spfdomain=sipsolutions.net dkim=pass dkdomain=sipsolutions.net dmarc=pass fromdomain=sipsolutions.net); spf=pass (google.com: domain of linux-wireless+bounces-7442-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-wireless+bounces-7442-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=REJECT dis=NONE) header.from=sipsolutions.net Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 524C5281362 for ; Fri, 10 May 2024 09:32:54 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 591FE29405; Fri, 10 May 2024 09:32:52 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=sipsolutions.net header.i=@sipsolutions.net header.b="vNZMwDs0" X-Original-To: linux-wireless@vger.kernel.org Received: from sipsolutions.net (s3.sipsolutions.net [168.119.38.16]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 78F1015FA7B for ; Fri, 10 May 2024 09:32:49 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=168.119.38.16 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715333572; cv=none; b=itiiw6/QGo5QkL+5IH6Xxz8Iy8TeWztF68gRZKORdNxgSVqsKSbaX6FmNF2ecR4Evp7LoGKdeOlr32VeKGXRdEnyAaFjmBzK2VgpVNeewqRoHlKBW+8qBMk/tNFrdn1+tsbnTpKAlZk++BWBqPKEJaslJoAUit0zUAFUSHcI1iU= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715333572; c=relaxed/simple; bh=xslTn6WeWGndQhyrsb3Veoas+AEYYjVlI0BzhSWi5qw=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=ZOEDl5g8mSjccXyeuWPafkRrqIF0gGviDtEUpVw6KAQrFbUTq9wlBZuRGR3ODtCysTky2U7JTGJaHly7DV0K37ZQ7D9+JHDMwUD9OJvh+pnQLKkUTn3qe4utJlwd7jAneQf/273PNN7s/mEnMu/Kyu1q6z18Ey998tRt/UEGZpc= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=sipsolutions.net; spf=pass smtp.mailfrom=sipsolutions.net; dkim=pass (2048-bit key) header.d=sipsolutions.net header.i=@sipsolutions.net header.b=vNZMwDs0; arc=none smtp.client-ip=168.119.38.16 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=sipsolutions.net Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=sipsolutions.net DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=sipsolutions.net; s=mail; h=Content-Transfer-Encoding:MIME-Version: Message-ID:Date:Subject:Cc:To:From:Content-Type:Sender:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-To:Resent-Cc: Resent-Message-ID:In-Reply-To:References; bh=/ouwYcx5LwcRnlw9YQcs5oI/xIme3lYSJKLo4Qt3eYs=; t=1715333569; x=1716543169; b=vNZMwDs0iy0H1WpNhqqFG38xdpXRVmju/jpwcORDhEVTBJbcM9cKeTXwaDaz62zhe73PqSMcofm izNgAdKd74mG1XoUUVl8JHsqwk7WSTuP6iZ9r9Xvn1RQq5WMpB1EtjF2dPotUf0u3l1Mtv0j3YOqj n1u5VtvIreYKLMQeBXaFRqMzqnHybNZgDSSQpH8TcCjdjU/FPh6KZpG+vAbS41xgNmHPYCFPNXCAa UGnOjz+zLzPx1mNRawSNA9GZ6hwDEPTDR9c1uG/05lcQujdv6eDKP5Bla2rczbY4BmAY1vIzH+lfS IDgktnXXVZrEVo2Z8ARWG445VfbWaN+Ep/9w==; Received: by sipsolutions.net with esmtpsa (TLS1.3:ECDHE_X25519__RSA_PSS_RSAE_SHA256__AES_256_GCM:256) (Exim 4.97) (envelope-from ) id 1s5McQ-0000000Ekfk-151P; Fri, 10 May 2024 11:32:46 +0200 From: Johannes Berg To: linux-wireless@vger.kernel.org Cc: Miri Korenblit , Ilan Peer Subject: [PATCH] wifi: cfg80211: fix 6 GHz scan request building Date: Fri, 10 May 2024 11:32:43 +0200 Message-ID: <20240510113244.b5f4ef741cc6.I0cb19188be17a8abd029805e3373c0a7777c214c@changeid> X-Mailer: git-send-email 2.45.0 Precedence: bulk X-Mailing-List: linux-wireless@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit From: Miri Korenblit The 6 GHz scan request struct allocated by cfg80211_scan_6ghz() is meant to be formed this way: [base struct][channels][ssids][6ghz_params] It is allocated with [channels] as the maximum number of channels supported by the driver in the 6 GHz band, since allocation is before knowing how many there will be. However, the inner pointers are set incorrectly: initially, the 6 GHz scan parameters pointer is set: [base struct][channels] ^ scan_6ghz_params and later the SSID pointer is set to the end of the actually _used_ channels. [base struct][channels] ^ ssids If many APs were to be discovered, and many channels used, and there were many SSIDs, then the SSIDs could overlap the 6 GHz parameters. Additionally, the request->ssids for most of the function points to the original request still (given the struct copy) but is used normally, which is confusing. Clear this up, by actually using the allocated space for 6 GHz parameters _after_ the SSIDs, and set up the SSIDs initially so they are used more clearly. Just like in nl80211.c, set them only if there actually are SSIDs though. Finally, also copy the elements (ie/ie_len) so they're part of the same request, not pointing to the old request. Co-developed-by: Miri Korenblit Signed-off-by: Miri Korenblit Reviewed-by: Ilan Peer Signed-off-by: Johannes Berg --- net/wireless/rdev-ops.h | 6 +++++- net/wireless/scan.c | 47 +++++++++++++++++++++++++++-------------- 2 files changed, 36 insertions(+), 17 deletions(-) diff --git a/net/wireless/rdev-ops.h b/net/wireless/rdev-ops.h index 43897a5269b6..755af47b88b9 100644 --- a/net/wireless/rdev-ops.h +++ b/net/wireless/rdev-ops.h @@ -2,7 +2,7 @@ /* * Portions of this file * Copyright(c) 2016-2017 Intel Deutschland GmbH - * Copyright (C) 2018, 2021-2023 Intel Corporation + * Copyright (C) 2018, 2021-2024 Intel Corporation */ #ifndef __CFG80211_RDEV_OPS #define __CFG80211_RDEV_OPS @@ -458,6 +458,10 @@ static inline int rdev_scan(struct cfg80211_registered_device *rdev, struct cfg80211_scan_request *request) { int ret; + + if (WARN_ON_ONCE(!request->n_ssids && request->ssids)) + return -EINVAL; + trace_rdev_scan(&rdev->wiphy, request); ret = rdev->ops->scan(&rdev->wiphy, request); trace_rdev_return_int(&rdev->wiphy, ret); diff --git a/net/wireless/scan.c b/net/wireless/scan.c index 127853877a0a..e0cbeb34074d 100644 --- a/net/wireless/scan.c +++ b/net/wireless/scan.c @@ -812,6 +812,7 @@ static int cfg80211_scan_6ghz(struct cfg80211_registered_device *rdev) LIST_HEAD(coloc_ap_list); bool need_scan_psc = true; const struct ieee80211_sband_iftype_data *iftd; + size_t size, offs_ssids, offs_6ghz_params, offs_ies; rdev_req->scan_6ghz = true; @@ -877,10 +878,15 @@ static int cfg80211_scan_6ghz(struct cfg80211_registered_device *rdev) spin_unlock_bh(&rdev->bss_lock); } - request = kzalloc(struct_size(request, channels, n_channels) + - sizeof(*request->scan_6ghz_params) * count + - sizeof(*request->ssids) * rdev_req->n_ssids, - GFP_KERNEL); + size = struct_size(request, channels, n_channels); + offs_ssids = size; + size += sizeof(*request->ssids) * rdev_req->n_ssids; + offs_6ghz_params = size; + size += sizeof(*request->scan_6ghz_params) * count; + offs_ies = size; + size += rdev_req->ie_len; + + request = kzalloc(size, GFP_KERNEL); if (!request) { cfg80211_free_coloc_ap_list(&coloc_ap_list); return -ENOMEM; @@ -888,8 +894,26 @@ static int cfg80211_scan_6ghz(struct cfg80211_registered_device *rdev) *request = *rdev_req; request->n_channels = 0; - request->scan_6ghz_params = - (void *)&request->channels[n_channels]; + request->n_6ghz_params = 0; + if (rdev_req->n_ssids) { + /* + * Add the ssids from the parent scan request to the new + * scan request, so the driver would be able to use them + * in its probe requests to discover hidden APs on PSC + * channels. + */ + request->ssids = (void *)request + offs_ssids; + memcpy(request->ssids, rdev_req->ssids, + sizeof(*request->ssids) * request->n_ssids); + } + request->scan_6ghz_params = (void *)request + offs_6ghz_params; + + if (rdev_req->ie_len) { + void *ie = (void *)request + offs_ies; + + memcpy(ie, rdev_req->ie, rdev_req->ie_len); + request->ie = ie; + } /* * PSC channels should not be scanned in case of direct scan with 1 SSID @@ -978,18 +1002,9 @@ static int cfg80211_scan_6ghz(struct cfg80211_registered_device *rdev) if (request->n_channels) { struct cfg80211_scan_request *old = rdev->int_scan_req; + rdev->int_scan_req = request; - /* - * Add the ssids from the parent scan request to the new scan - * request, so the driver would be able to use them in its - * probe requests to discover hidden APs on PSC channels. - */ - request->ssids = (void *)&request->channels[request->n_channels]; - request->n_ssids = rdev_req->n_ssids; - memcpy(request->ssids, rdev_req->ssids, sizeof(*request->ssids) * - request->n_ssids); - /* * If this scan follows a previous scan, save the scan start * info from the first part of the scan -- 2.45.0