From patchwork Fri Apr 10 13:32:21 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?b?SsOpcsO0bWUgUG91aWxsZXI=?= X-Patchwork-Id: 216042 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-9.7 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, MSGID_FROM_MTA_HEADER, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 66FB4C2BA2B for ; Fri, 10 Apr 2020 13:35:12 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 2FF70212CC for ; Fri, 10 Apr 2020 13:35:12 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=silabs.onmicrosoft.com header.i=@silabs.onmicrosoft.com header.b="ZP34UKRK" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726679AbgDJNdE (ORCPT ); Fri, 10 Apr 2020 09:33:04 -0400 Received: from mail-dm6nam12on2082.outbound.protection.outlook.com ([40.107.243.82]:31903 "EHLO NAM12-DM6-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726181AbgDJNdC (ORCPT ); Fri, 10 Apr 2020 09:33:02 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=C+qR9/kFx9PiB1bvI6ufuB7MLlxITyIK0I6BK1QwoO2LfozWcvMygKuCTgIQgXE5qUY5OahgE5x0ZlsKjMn61K5kXZ57QzRVKHit8rMAvF3T6boa3/RzVKUY0pq37BtpyK8auYdqVFSoFDQ9SBkED7yN1XE6sI6VO73msC9RAXDpFfx1dpIMf77GGhegXsV3Ph3tTcVwmm0CCdKybF5JxtceM7yDYGlxINJZEjzua0mujFjw1I7i1PXHgfMD1tLJGSG3Ib5h2QabRTiNZ53II1655DSsGCf1/XaDyTEuQCVh57vJkpYidjAVhaH+CnbuH0Uav66ugraDYkwa+Z5pfw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=ReanvtT/cyTujwHvDghjxXROX8i/R50wqYa1At2zGA8=; b=JaUIwTDBmPhL49f9jALR8HUr5Zpx1vTrKw68TBUev47Gg+mYCr4D6eG61O9niOX3o+you8a28167MJHtC3QGE+CG1vI//L3osi+DNFbs1E9oG27HfoV3wudGsgr8LcJAQzQz10xWJZVowXdyuo0v8nyVK1m3o5sKqlYRId8MchmaJvo5aokpNYq7TAbFyBqxLAWdcS5mgPVn3YX/8zTEeSJ4GUq8zf0P0o3UZxLFSZopoRKtfXVqxrj50JBHl/2K+givTH9/sDXTGUQoxHsnrcRzJyA7UMbg65GRdhhGgC65GauRAWd73SclvdPKUMrFr46H2qyEmhNr1cylht28gQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=silabs.com; dmarc=pass action=none header.from=silabs.com; dkim=pass header.d=silabs.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=silabs.onmicrosoft.com; s=selector2-silabs-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=ReanvtT/cyTujwHvDghjxXROX8i/R50wqYa1At2zGA8=; b=ZP34UKRK7IpoRxhQNBINdGyk4jaL72rciCR+t3GeDDzeXejGwOF302U5RoF6e9RdTFz7l36CXCUi/vqr7ggz6pjcnBJh0uswsJ5okcRv1ybkjLTZ1sIJHYmx6Vea0pstCSKKU4JeWf1O8hwEOL3e1QDGzkJWdIZYbAZxY7LLNu0= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Jerome.Pouiller@silabs.com; Received: from MN2PR11MB4063.namprd11.prod.outlook.com (2603:10b6:208:13f::22) by MN2PR11MB4398.namprd11.prod.outlook.com (2603:10b6:208:18b::31) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2878.20; Fri, 10 Apr 2020 13:33:00 +0000 Received: from MN2PR11MB4063.namprd11.prod.outlook.com ([fe80::3d0a:d9ac:3df4:8b1]) by MN2PR11MB4063.namprd11.prod.outlook.com ([fe80::3d0a:d9ac:3df4:8b1%6]) with mapi id 15.20.2878.021; Fri, 10 Apr 2020 13:33:00 +0000 From: Jerome Pouiller To: devel@driverdev.osuosl.org, linux-wireless@vger.kernel.org Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Greg Kroah-Hartman , Kalle Valo , "David S . Miller" , =?utf-8?b?SsOpcsO0bWUgUG91aWxsZXI=?= Subject: [PATCH 01/19] staging: wfx: fix race between configure_filter and remove_interface Date: Fri, 10 Apr 2020 15:32:21 +0200 Message-Id: <20200410133239.438347-2-Jerome.Pouiller@silabs.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200410133239.438347-1-Jerome.Pouiller@silabs.com> References: <20200410133239.438347-1-Jerome.Pouiller@silabs.com> X-ClientProxiedBy: DM5PR15CA0056.namprd15.prod.outlook.com (2603:10b6:3:ae::18) To MN2PR11MB4063.namprd11.prod.outlook.com (2603:10b6:208:13f::22) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from pc-42.silabs.com (2a01:e35:2435:66a0:1265:30ff:fefd:6e7f) by DM5PR15CA0056.namprd15.prod.outlook.com (2603:10b6:3:ae::18) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2900.15 via Frontend Transport; Fri, 10 Apr 2020 13:32:58 +0000 X-Mailer: git-send-email 2.25.1 X-Originating-IP: [2a01:e35:2435:66a0:1265:30ff:fefd:6e7f] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: a4dcfdaf-15c9-4f30-d679-08d7dd53b025 X-MS-TrafficTypeDiagnostic: MN2PR11MB4398: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:8273; X-Forefront-PRVS: 0369E8196C X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:MN2PR11MB4063.namprd11.prod.outlook.com; PTR:; CAT:NONE; SFTY:; SFS:(10009020)(366004)(346002)(396003)(136003)(39850400004)(376002)(107886003)(81156014)(54906003)(8676002)(86362001)(1076003)(6666004)(8936002)(4326008)(52116002)(66574012)(7696005)(316002)(66556008)(66946007)(186003)(478600001)(2906002)(6486002)(2616005)(66476007)(16526019)(5660300002)(36756003); DIR:OUT; SFP:1101; Received-SPF: None (protection.outlook.com: silabs.com does not designate permitted sender hosts) X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: v0Wn3IGW6eZ4aNivT+cWGTppfUhEojxQyhVH7xhCU73v202QuuIb4XaZXf+MfwxUzxB13+63o/5LohZ7wotmjgDnRzjqUQ7DF4v6Mld1mfP96E7tUwIhLcTvp5qOl7gqvvqcHsubO77vKaUMWY51Ddxoyuh4yh5gSWi8qFJIgSJEQ4cHElucCH2Avvs2evOsiW4XwcPlAgz/pNJbprobLXmF8rxl+BLrvdZNr7ZFQxLbDezRN/LJBeAi3bib0YdggWtYotEb8+C9Nqmx+XjWcBhk+EUXcNdjCvNDnzQDdhtVZDWBA4vVDLm+XZInFvOqmm9nYeOWwvjAN22e9OaFE6aXiZmyhHUbVA+MLw4hQIkmpVsDlr50KaTakRfCZhmJBXnXKrFbVm1JCtYBJ2N02KYvSziQ5q7TmCtxrGn63f8pPosJi25FVZ+Lzfto5PPi X-MS-Exchange-AntiSpam-MessageData: BV7TAgthZtvpA8E4WnEqdvki/WQfPY7xz5HRgwvRo9EHJlpTaJZZ8gfdg2TRFpJCx13D3eTZQkztOmdMExA54pnl8hPq4SoF8IYMOFINZ4g6O8f1jT+irQrpTypr8rGEuM01wueuy1XVXDnb6ySv+SvYG9tpgncIIMbZsIbu+jaryFQR3eF3+Y5pVXTSGzljg0lb6vfAStlIbxDc0nhYjA== X-OriginatorOrg: silabs.com X-MS-Exchange-CrossTenant-Network-Message-Id: a4dcfdaf-15c9-4f30-d679-08d7dd53b025 X-MS-Exchange-CrossTenant-OriginalArrivalTime: 10 Apr 2020 13:33:00.6406 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 54dbd822-5231-4b20-944d-6f4abcd541fb X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: ztRYh3Vn6oKwxleerpzGG332KQQQy45A/u8XbkLH5RappaCNLxx/klDndRl1S26e9JlD9qT/0QPL86zJT87XwQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: MN2PR11MB4398 Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Jérôme Pouiller wfx_remove_interface() and wfx_configure_filter() can be run concurrently. Therefore, this patch protect access to the list of interfaces from wfx_configure_filter(). Notice that wfx_configure_filter() now lock "conf_lock" and "scan_lock". Beside that, wfx_hw_scan_work() also access to the same locks. So we have to lock them in same order to avoid any deadlock. Signed-off-by: Jérôme Pouiller --- drivers/staging/wfx/scan.c | 4 ++-- drivers/staging/wfx/sta.c | 2 ++ 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/drivers/staging/wfx/scan.c b/drivers/staging/wfx/scan.c index 6e1e50048651..0c7f4eef045c 100644 --- a/drivers/staging/wfx/scan.c +++ b/drivers/staging/wfx/scan.c @@ -86,8 +86,8 @@ void wfx_hw_scan_work(struct work_struct *work) struct ieee80211_scan_request *hw_req = wvif->scan_req; int chan_cur, ret; - mutex_lock(&wvif->scan_lock); mutex_lock(&wvif->wdev->conf_mutex); + mutex_lock(&wvif->scan_lock); update_probe_tmpl(wvif, &hw_req->req); wfx_fwd_probe_req(wvif, true); chan_cur = 0; @@ -96,8 +96,8 @@ void wfx_hw_scan_work(struct work_struct *work) if (ret > 0) chan_cur += ret; } while (ret > 0 && chan_cur < hw_req->req.n_channels); - mutex_unlock(&wvif->wdev->conf_mutex); mutex_unlock(&wvif->scan_lock); + mutex_unlock(&wvif->wdev->conf_mutex); __ieee80211_scan_completed_compat(wvif->wdev->hw, ret < 0); } diff --git a/drivers/staging/wfx/sta.c b/drivers/staging/wfx/sta.c index 4d5dbfc24f52..380e5319472a 100644 --- a/drivers/staging/wfx/sta.c +++ b/drivers/staging/wfx/sta.c @@ -242,6 +242,7 @@ void wfx_configure_filter(struct ieee80211_hw *hw, *total_flags &= FIF_OTHER_BSS | FIF_FCSFAIL | FIF_PROBE_REQ; + mutex_lock(&wdev->conf_mutex); while ((wvif = wvif_iterate(wdev, wvif)) != NULL) { mutex_lock(&wvif->scan_lock); wvif->filter_bssid = (*total_flags & @@ -251,6 +252,7 @@ void wfx_configure_filter(struct ieee80211_hw *hw, wfx_update_filtering(wvif); mutex_unlock(&wvif->scan_lock); } + mutex_unlock(&wdev->conf_mutex); } static int wfx_update_pm(struct wfx_vif *wvif)