Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp4581363pxv; Tue, 6 Jul 2021 04:34:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw8dG7bqoOt588pfsNEmIc2Pr0mkk3HaZ0wf9E6IfPO0o2EraxrwCFY2PomFQlCS3TOQqbY X-Received: by 2002:a05:6402:348b:: with SMTP id v11mr22609327edc.231.1625571292969; Tue, 06 Jul 2021 04:34:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625571292; cv=none; d=google.com; s=arc-20160816; b=gVQwyj9QJCGE868eh5WJZmGLbTqd7O8oXwSHi1uEHvb8OyALGIz8NxziHnUC+86eGB qzW0F85c/gP+TvGVzsp433WsjuqQetsOJpNYrt9J7daqm+qIkTV3ZSMwGGxXt0uwm71+ tXdlcpKCo3MFrF589s3X3nYdd86qKjkKwpEcwITKTMqIrByTlLFyTnAIeA/HZUmun82Y gNH7ZjUXVAbYgw+xFoeqDQFrhLE6NfSFwKj0j3YX2BSJie0XxyJIgaDmPyKikHYT0z+/ t/0XMnJI9jiGlAmni5cS2ze6hUoTdFltv2hY7KZ77/fckuCJfUKKWAixqw+nTljDmwEM 8DFA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=yffpBEGIvQSKsy3utx0c+YNw7TXTYNjpJGjPyWqI19c=; b=kja2ods+SaAxQl17X8V8bVtol/z4LSRvmoEVVnY7mj1B4r+hvlRm7TlJdhucP+i9qu /2fJW4svfyw3/bndOCcMLp2ViS5I12JxhDqasjJVffAPb/nzrDhj27nNPZZdruBuv4NY iUhXyIqquV5Ueh7S7yNr17s7gtFNjA9SlDUxuiMuHnAFSnFd3Isne4ILURKpjhBmG3UR GNiuj1lGEMByXOSpCwJfc1rHhM3stSJ2XMB2iIri3cuPy8VR+tffvuWxbGPPT64ZTaOI XT1zmkwC8EQ7hGmwMzRqWLg+2mN26L2WgfeDt9A2hI2h+G4q5bv4iwmxJL20Kw2oPVmo z/Qw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=CMfhmf3h; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cd8si14545843ejb.430.2021.07.06.04.34.29; Tue, 06 Jul 2021 04:34:52 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=CMfhmf3h; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235701AbhGFLeZ (ORCPT + 99 others); Tue, 6 Jul 2021 07:34:25 -0400 Received: from mail.kernel.org ([198.145.29.99]:42402 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235654AbhGFLaR (ORCPT ); Tue, 6 Jul 2021 07:30:17 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 3147F61DCA; Tue, 6 Jul 2021 11:21:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1625570489; bh=i9LbO88BQlRz9UewtnHD4ToRZXkZ1jIba8GKpBuY0pk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=CMfhmf3hyheNyBMalAWHPOQ71uzZ2nMMIEeNbf/AKjkiDJrlglW+LkQNHjHaIxB7/ C7zZE+VG82+9Y9WWcElBg/H6Nbvk563y0/uHe7DEYREjDgAL9noOWdXE4YzaNLc1hz XWSehGflOAyEyg5/K9r7+THkx28ySD638JXiSduOhPC3N7syxGf0AHWzF0z/lzsMsw dlk6m9wdu1/UBnJlJva0Hoi3ksO0huCUGmRhjnYq5Bf+BwyUpz2U5OlGFIH6lgAnuj O6uBkKkCNszqgvNkOZ7R3E6MnmdsLASbYwlIC23RWPWEURbZfVpri5PW7nrunfZXz1 MB9+5yvIXSFyA== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Ilan Peer , Luca Coelho , Johannes Berg , Sasha Levin , linux-wireless@vger.kernel.org, netdev@vger.kernel.org Subject: [PATCH AUTOSEL 5.12 136/160] mac80211: Properly WARN on HW scan before restart Date: Tue, 6 Jul 2021 07:18:02 -0400 Message-Id: <20210706111827.2060499-136-sashal@kernel.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210706111827.2060499-1-sashal@kernel.org> References: <20210706111827.2060499-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Ilan Peer [ Upstream commit 45daaa1318410794de956fb8e9d06aed2dbb23d0 ] The following race was possible: 1. The device driver requests HW restart. 2. A scan is requested from user space and is propagated to the driver. During this flow HW_SCANNING flag is set. 3. The thread that handles the HW restart is scheduled, and before starting the actual reconfiguration it checks that HW_SCANNING is not set. The flow does so without acquiring any lock, and thus the WARN fires. Fix this by checking that HW_SCANNING is on only after RTNL is acquired, i.e., user space scan request handling is no longer in transit. Signed-off-by: Ilan Peer Signed-off-by: Luca Coelho Link: https://lore.kernel.org/r/iwlwifi.20210618133832.8238ab3e19ab.I2693c581c70251472b4f9089e37e06fb2c18268f@changeid Signed-off-by: Johannes Berg Signed-off-by: Sasha Levin --- net/mac80211/main.c | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/net/mac80211/main.c b/net/mac80211/main.c index 9dd741b68f26..937a024a13e2 100644 --- a/net/mac80211/main.c +++ b/net/mac80211/main.c @@ -257,14 +257,13 @@ static void ieee80211_restart_work(struct work_struct *work) /* wait for scan work complete */ flush_workqueue(local->workqueue); flush_work(&local->sched_scan_stopped_work); + flush_work(&local->radar_detected_work); + + rtnl_lock(); WARN(test_bit(SCAN_HW_SCANNING, &local->scanning), "%s called with hardware scan in progress\n", __func__); - flush_work(&local->radar_detected_work); - /* we might do interface manipulations, so need both */ - rtnl_lock(); - wiphy_lock(local->hw.wiphy); list_for_each_entry(sdata, &local->interfaces, list) { /* * XXX: there may be more work for other vif types and even -- 2.30.2