Received: by 2002:ab2:6857:0:b0:1ef:ffd0:ce49 with SMTP id l23csp2505230lqp; Mon, 25 Mar 2024 00:08:16 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUYBThdroGHQp7KV5JoQFEPCBHWcEjv3nCLxFpOLI99MJI16HKR+SiXjGLoK83AboGFLPMlb75/xED74NN0HMyMSX7t2UqRGRCFRLMIng== X-Google-Smtp-Source: AGHT+IFiTZOfSbu7mSWVVB/k3Xk9WjEWybhxwRKJMs9vI5nLs1R8r3afCHbsj7fFtGllYfRvHV6m X-Received: by 2002:a05:6a20:7da1:b0:1a3:c616:bc07 with SMTP id v33-20020a056a207da100b001a3c616bc07mr2256508pzj.2.1711350495871; Mon, 25 Mar 2024 00:08:15 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711350495; cv=pass; d=google.com; s=arc-20160816; b=Z0J2Cl6zHnjPldQEybbeOOAZnDY6yWd1ugrzQEUEfllAIyOX7Zpf9B7R0XfpNeNNNl mzChcxIRYrOUOaio3XTFMUh4wb4CNKV7ABbu5oz7DMvIUfHFPwiviL+Yskwf1kVMEnHm cXCSTF3vUbFlPXq8qe7XdQE6g7Hv7HYtK8pCEBicC7SleTHltF+irUsmISvSXfq61h2I LmUpXtbO1VSd63EvMKDslYvgFZAWFanzVMHm56s8d4mZgFNv1pEToPjbMKuvgc/97yd7 n1SJs0iKvP9cl5eO7ZcWPuS3nwtma+9XlHgMPPCJJg0P7pgUJ5eOk1cGlZBUReM9P3jf AMLg== 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:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=B/DCTSBXJwS8Tt0iNkHMlqKkR+Rhtq3V3VoY1fcBmqU=; fh=7g2heFpHPlBcrJ9ppJDSY7dK2JXlGEp0LizCUyQbAaE=; b=XS5iJLTwZMQlcBHG1G/PFOy1jqlvvLkkLsrpg76/XjRd6kUxonh/9GKNn1gsqz0yPC yrVtFG3/62Cs+OoWhOmSXYztvV8Htl77ULLdE3n4EQTcRgf2NGbYgzr6EEsbM6Snz3+p oook4xjDKy7dmI3snqy4h0bBnurNEGZO4lUGZSupCu58DEPJIjWYvj3l7l9RxxmX8EiA 6ganFGyX4g8mMjX33p5c1fVdncr3TO9w4VeNbtoLC4gZFbaLZCDqjf6meyycHuL6IKXj bnSYmmVXZjU2xhxBEpPnO+aMi1NirdcSnTiTbT2rIlRQgOnNkifjdKWB4qhR/NNox189 ogHg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Gj5b2fuK; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-114774-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-114774-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [2604:1380:45e3:2400::1]) by mx.google.com with ESMTPS id j18-20020aa78d12000000b006ea872d1b12si4538508pfe.390.2024.03.25.00.08.15 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Mar 2024 00:08:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-114774-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) client-ip=2604:1380:45e3:2400::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Gj5b2fuK; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-114774-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-114774-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org 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 DA8E129730D for ; Mon, 25 Mar 2024 07:02:40 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 7312B1B8849; Mon, 25 Mar 2024 00:50:42 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="Gj5b2fuK" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (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 AAA4F21A85E; Sun, 24 Mar 2024 23:36:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711323377; cv=none; b=EBNUbnix5NO3ZzvqhyO/8u/6owMV5Tu4li3MFAu429+JF016fg+EyaUlL43rx4GCEy10QCxPMdSna9jEerHSrESWC7ZR6P6VtMT0iGM1dCnvoG7NvZMVzyRvUUQziqma3dy6mV+AjD9j40lm4zpZxW5Yg3TaNzKEvAAanmubOGU= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711323377; c=relaxed/simple; bh=WCMElm0FEksMpnIVlx+GauY2XrT0KIduJ3+8VE2+36Y=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=cVuhNYwAjAaG4Vsda/3q/7YqQr34U9WIjrH/jdJQcombTYXBVW7Qch0f3bZBdeDps1ELnbY+pGT9dFFmFgXYPSbh5M5uo5FcCjTFAwNelB5nOmjQhh5DIxRNQB8u1/LBVq5H12sfVRhbPBkOWm0Ezcw/1YQx5GN0HBNXFxPydHM= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=Gj5b2fuK; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id D1E2EC43394; Sun, 24 Mar 2024 23:36:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1711323376; bh=WCMElm0FEksMpnIVlx+GauY2XrT0KIduJ3+8VE2+36Y=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Gj5b2fuKqYx1H1ZsVtih9isQsVIVxyfTmc5tcKf4mWzlV50zQ0yJBeRUC593+X4V/ 9JwW1zSN5fUkvgIlcJU+983Pa+rkh8zY8jM9mygrEZ/RqF4c+qBXtriLxH3/WnjSj2 Lhc9l2DPWC1vSmJ+XlHErjDWqcgPTB0yWqZUvjACGME7LCkss7JwTs+D6gnecwboaK OKqBiyEU2IrkZRd1B0DK/Jq8kIGJQY0Lq7pL0U/czfcomX3D661O7rBGmcrY7PpOvd upfBnLas6fVvqU1yEV9WMc02Zix4+0ARKkjFDnIorz03xv5EP8sSWPoyyie7wmcVXh 0wNpvckDGABng== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: =?UTF-8?q?Toke=20H=C3=B8iland-J=C3=B8rgensen?= , Ubisectech Sirius , Kalle Valo , Sasha Levin Subject: [PATCH 5.15 076/317] wifi: ath9k: delay all of ath9k_wmi_event_tasklet() until init is complete Date: Sun, 24 Mar 2024 19:30:56 -0400 Message-ID: <20240324233458.1352854-77-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240324233458.1352854-1-sashal@kernel.org> References: <20240324233458.1352854-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit From: Toke Høiland-Jørgensen [ Upstream commit 24355fcb0d4cbcb6ddda262596558e8cfba70f11 ] The ath9k_wmi_event_tasklet() used in ath9k_htc assumes that all the data structures have been fully initialised by the time it runs. However, because of the order in which things are initialised, this is not guaranteed to be the case, because the device is exposed to the USB subsystem before the ath9k driver initialisation is completed. We already committed a partial fix for this in commit: 8b3046abc99e ("ath9k_htc: fix NULL pointer dereference at ath9k_htc_tx_get_packet()") However, that commit only aborted the WMI_TXSTATUS_EVENTID command in the event tasklet, pairing it with an "initialisation complete" bit in the TX struct. It seems syzbot managed to trigger the race for one of the other commands as well, so let's just move the existing synchronisation bit to cover the whole tasklet (setting it at the end of ath9k_htc_probe_device() instead of inside ath9k_tx_init()). Link: https://lore.kernel.org/r/ed1d2c66-1193-4c81-9542-d514c29ba8b8.bugreport@ubisectech.com Fixes: 8b3046abc99e ("ath9k_htc: fix NULL pointer dereference at ath9k_htc_tx_get_packet()") Reported-by: Ubisectech Sirius Signed-off-by: Toke Høiland-Jørgensen Signed-off-by: Kalle Valo Link: https://msgid.link/20240126140218.1033443-1-toke@toke.dk Signed-off-by: Sasha Levin --- drivers/net/wireless/ath/ath9k/htc.h | 2 +- drivers/net/wireless/ath/ath9k/htc_drv_init.c | 4 ++++ drivers/net/wireless/ath/ath9k/htc_drv_txrx.c | 4 ---- drivers/net/wireless/ath/ath9k/wmi.c | 10 ++++++---- 4 files changed, 11 insertions(+), 9 deletions(-) diff --git a/drivers/net/wireless/ath/ath9k/htc.h b/drivers/net/wireless/ath/ath9k/htc.h index 237f4ec2cffd7..6c33e898b3000 100644 --- a/drivers/net/wireless/ath/ath9k/htc.h +++ b/drivers/net/wireless/ath/ath9k/htc.h @@ -306,7 +306,6 @@ struct ath9k_htc_tx { DECLARE_BITMAP(tx_slot, MAX_TX_BUF_NUM); struct timer_list cleanup_timer; spinlock_t tx_lock; - bool initialized; }; struct ath9k_htc_tx_ctl { @@ -515,6 +514,7 @@ struct ath9k_htc_priv { unsigned long ps_usecount; bool ps_enabled; bool ps_idle; + bool initialized; #ifdef CONFIG_MAC80211_LEDS enum led_brightness brightness; diff --git a/drivers/net/wireless/ath/ath9k/htc_drv_init.c b/drivers/net/wireless/ath/ath9k/htc_drv_init.c index 96a3185a96d75..b014185373f34 100644 --- a/drivers/net/wireless/ath/ath9k/htc_drv_init.c +++ b/drivers/net/wireless/ath/ath9k/htc_drv_init.c @@ -966,6 +966,10 @@ int ath9k_htc_probe_device(struct htc_target *htc_handle, struct device *dev, htc_handle->drv_priv = priv; + /* Allow ath9k_wmi_event_tasklet() to operate. */ + smp_wmb(); + priv->initialized = true; + return 0; err_init: diff --git a/drivers/net/wireless/ath/ath9k/htc_drv_txrx.c b/drivers/net/wireless/ath/ath9k/htc_drv_txrx.c index d6a3f001dacb9..2fdd27885f543 100644 --- a/drivers/net/wireless/ath/ath9k/htc_drv_txrx.c +++ b/drivers/net/wireless/ath/ath9k/htc_drv_txrx.c @@ -815,10 +815,6 @@ int ath9k_tx_init(struct ath9k_htc_priv *priv) skb_queue_head_init(&priv->tx.data_vo_queue); skb_queue_head_init(&priv->tx.tx_failed); - /* Allow ath9k_wmi_event_tasklet(WMI_TXSTATUS_EVENTID) to operate. */ - smp_wmb(); - priv->tx.initialized = true; - return 0; } diff --git a/drivers/net/wireless/ath/ath9k/wmi.c b/drivers/net/wireless/ath/ath9k/wmi.c index 1476b42b52a91..805ad31edba2b 100644 --- a/drivers/net/wireless/ath/ath9k/wmi.c +++ b/drivers/net/wireless/ath/ath9k/wmi.c @@ -155,6 +155,12 @@ void ath9k_wmi_event_tasklet(struct tasklet_struct *t) } spin_unlock_irqrestore(&wmi->wmi_lock, flags); + /* Check if ath9k_htc_probe_device() completed. */ + if (!data_race(priv->initialized)) { + kfree_skb(skb); + continue; + } + hdr = (struct wmi_cmd_hdr *) skb->data; cmd_id = be16_to_cpu(hdr->command_id); wmi_event = skb_pull(skb, sizeof(struct wmi_cmd_hdr)); @@ -169,10 +175,6 @@ void ath9k_wmi_event_tasklet(struct tasklet_struct *t) &wmi->drv_priv->fatal_work); break; case WMI_TXSTATUS_EVENTID: - /* Check if ath9k_tx_init() completed. */ - if (!data_race(priv->tx.initialized)) - break; - spin_lock_bh(&priv->tx.tx_lock); if (priv->tx.flags & ATH9K_HTC_OP_TX_DRAIN) { spin_unlock_bh(&priv->tx.tx_lock); -- 2.43.0