Received: by 2002:a05:7412:b130:b0:e2:908c:2ebd with SMTP id az48csp30961rdb; Thu, 16 Nov 2023 11:02:26 -0800 (PST) X-Google-Smtp-Source: AGHT+IFP3gRx3U6ChMxl92qNy01QOThuG9BJ3Nbzgoj1uGKesxp6lfZfue2oEvFiIFDfaFhUjpzb X-Received: by 2002:a17:903:181:b0:1cc:2526:1e4 with SMTP id z1-20020a170903018100b001cc252601e4mr9521055plg.52.1700161345760; Thu, 16 Nov 2023 11:02:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700161345; cv=none; d=google.com; s=arc-20160816; b=oVQCkUCQu2kSu2tWC6nz9JRxgyPZmPyv336k67pCkypfNtPvru7Vj3pSZazqlhh9Fv vHtloCQDe7zbLuymoeapK5U6TnJWVJRCGiYoJe4p6FGCUgnsoWnjweVA93lWfk3aPDfR 0wHI+P1ZvdD9Jaat03txfS38CHC3GazckPfEQY8L4kPSO12DNtqmb0j14Q6EUJQ7EYlu CTMD1cbzlwUmU/4k7vuyLyvbZTFmbPvtbHJbjwb25QLd3Z0MXIG7KN+WkOY6k49u2m7k +VMdMmnJ4uYlo30G5Za5sg/zk8UEgvElI15IndjVwOrEBw/fixQNiGVEpRrjecPgYxKL +3vQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:subject:user-agent:references :in-reply-to:message-id:date:cc:to:from:dkim-signature; bh=11BMCj7afmbLlDRVGduOtQenNKM47rgeWaRh0Uen/Jk=; fh=7gEBZGjfB5W+s9WbHy7nmkk2DbkRuIZnGojx7LP6FvY=; b=fc3qw6H2LaGPbleKLEPRyg2MA2v08KbDFIg1E0NbNcRCTr9mjZTaJZY/fhgPg6a1+h UVvT/CS0zv1auYx0V/OFez4NaFZviuvo1Zb7xolr8xV/QRJqp7azSsS/7lOxrCpJpXP5 J3kt8NJJgu+f0ZytklxJHSuGqkDq+kl9MV9g9NfE45bQRO1OJ/IOKh/Hd+Jmkero33MB LSM8pfYIRMVRGnnTFK00AG3CJYD4qFJYfHEJUc76POnF921WGAxvm9Zs74MpJPgFmHcB 1uiiIyrSJt4GLJAw6AAZXpukYEmWobiDQwYf/YX0J9P7alFEQm2E7lAPiWN3MF2b363B pmjw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@broadcom.com header.s=google header.b=A5b7H62a; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Return-Path: Received: from snail.vger.email (snail.vger.email. [23.128.96.37]) by mx.google.com with ESMTPS id w5-20020a170902e88500b001ca33ce21fesi30254plg.58.2023.11.16.11.02.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 16 Nov 2023 11:02:25 -0800 (PST) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) client-ip=23.128.96.37; Authentication-Results: mx.google.com; dkim=pass header.i=@broadcom.com header.s=google header.b=A5b7H62a; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id 0110A81DD7F1; Thu, 16 Nov 2023 11:02:23 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229593AbjKPTCU (ORCPT + 53 others); Thu, 16 Nov 2023 14:02:20 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58214 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229552AbjKPTCT (ORCPT ); Thu, 16 Nov 2023 14:02:19 -0500 Received: from mail-qt1-x835.google.com (mail-qt1-x835.google.com [IPv6:2607:f8b0:4864:20::835]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 48698D4A for ; Thu, 16 Nov 2023 11:02:14 -0800 (PST) Received: by mail-qt1-x835.google.com with SMTP id d75a77b69052e-421ae930545so6716521cf.0 for ; Thu, 16 Nov 2023 11:02:14 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; t=1700161333; x=1700766133; darn=vger.kernel.org; h=mime-version:subject:user-agent:references:in-reply-to:message-id :date:cc:to:from:from:to:cc:subject:date:message-id:reply-to; bh=11BMCj7afmbLlDRVGduOtQenNKM47rgeWaRh0Uen/Jk=; b=A5b7H62aMGUyJgcXDN2i7ib1ws2yznEX1tHgQZu6oPIVN00CEKomnsUaQ62/bOTQwl B6ZydagyrVitKXUSFcnrHDKSQvcFjLTjnEanq3itcI65Eg7NutS7+7Nyj9KlmDNOtqnl /YLXIQiFc7eI//oqnFnIPjmB+flSomiEykeoE= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1700161333; x=1700766133; h=mime-version:subject:user-agent:references:in-reply-to:message-id :date:cc:to:from:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=11BMCj7afmbLlDRVGduOtQenNKM47rgeWaRh0Uen/Jk=; b=exgAW3lw2fBmvBkTTtSQVmMrpNiGWWeEb3PsH7YlnWEQXqMkt4B06hPWkQalhGGk0b WNYKPk5Ui3wnYGs+nxrlL+vhqKxEX4cFDkDwVPtmAyJcB2BFYY4HnmXeCVz5oKf4ljZB 3hIumjYbTtFADAzO7KtMrywpb/KsVYSPNz6yp+2kcGXd8uASFccDo7XWbdvGtb1K8L01 lCB6OkpV5wcekyqEo7ijWGYa3rdWxdbwHyrCjNMVvie5za0D54XxqAdeXpA8V3x2TdNF z43JJFl7/aalp8leifvhyEuIYuUcVyTsaLcDcdyKlO6YQ84d8E+mLpgEUhnrf6T+31i3 C6qQ== X-Gm-Message-State: AOJu0Yy+P6wh6CXn6yAMr3g80qEATqYLcP2yjLGZ+hvyOo0VpYTFbnKZ xfwyXxi8pVfMQ5LOtVWWR8+CmA== X-Received: by 2002:a05:622a:1647:b0:421:c3a9:1e50 with SMTP id y7-20020a05622a164700b00421c3a91e50mr11428568qtj.65.1700161333172; Thu, 16 Nov 2023 11:02:13 -0800 (PST) Received: from [192.168.178.38] (f215227.upc-f.chello.nl. [80.56.215.227]) by smtp.gmail.com with ESMTPSA id m13-20020ac807cd000000b0041b7f89ad19sm4353468qth.53.2023.11.16.11.02.07 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Thu, 16 Nov 2023 11:02:12 -0800 (PST) From: Arend Van Spriel To: Takashi Iwai CC: Zheng Hacker , Kalle Valo , Zheng Wang , , , , , , , , , , , , , , , Date: Thu, 16 Nov 2023 20:02:06 +0100 Message-ID: <18bd9830bb0.279b.9b12b7fc0a3841636cfb5e919b41b954@broadcom.com> In-Reply-To: <87h6llmu7t.wl-tiwai@suse.de> References: <20231106141704.866455-1-zyytlz.wz@163.com> <87o7g7ueom.fsf@kernel.org> <18ba5520da0.279b.9b12b7fc0a3841636cfb5e919b41b954@broadcom.com> <18bd95c97f0.279b.9b12b7fc0a3841636cfb5e919b41b954@broadcom.com> <87h6llmu7t.wl-tiwai@suse.de> User-Agent: AquaMail/1.48.0 (build: 104800386) Subject: Re: [PATCH v5] wifi: brcmfmac: Fix use-after-free bug in brcmf_cfg80211_detach MIME-Version: 1.0 Content-Type: multipart/signed; protocol="application/pkcs7-signature"; micalg=sha-256; boundary="0000000000005a7496060a49a8e8" X-Spam-Status: No, score=-2.2 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE, URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Thu, 16 Nov 2023 11:02:23 -0800 (PST) --0000000000005a7496060a49a8e8 Content-Type: text/plain; format=flowed; charset="UTF-8" Content-Transfer-Encoding: 8bit On November 16, 2023 7:25:16 PM Takashi Iwai wrote: > On Thu, 16 Nov 2023 19:20:06 +0100, > Arend Van Spriel wrote: >> >> On November 15, 2023 4:00:46 PM Zheng Hacker wrote: >> >>> Arend van Spriel 于2023年11月13日周一 17:18写道: >>>> >>>> On November 8, 2023 4:03:26 AM Zheng Hacker >>>> wrote: >>>> >>>>> Arend Van Spriel 于2023年11月6日周一 23:48写道: >>>>>> >>>>>> On November 6, 2023 3:44:53 PM Zheng Hacker wrote: >>>>>> >>>>>>> Thanks! I didn't test it for I don't have a device. Very appreciated >>>>>>> if anyone could help with that. >>>>>> >>>>>> I would volunteer, but it made me dig deep and not sure if there is a >>>>>> problem to solve here. >>>>>> >>>>>> brcmf_cfg80211_detach() calls wl_deinit_priv() -> brcmf_abort_scanning() -> >>>>>> brcmf_notify_escan_complete() which does delete the timer. >>>>>> >>>>>> What am I missing here? >>>>> >>>>> Thanks four your detailed review. I did see the code and not sure if >>>>> brcmf_notify_escan_complete >>>>> would be triggered for sure. So in the first version I want to delete >>>>> the pending timer ahead of time. >>>> >>>> Why requesting a CVE when you are not sure? Seems a bit hasty to put it >>>> mildly. >>> >>> I'm sure the issue exists because there's only cancler of timer but not woker. >>> As there's similar CVEs before like : https://github.com/V4bel/CVE-2022-41218, >>> I submit it as soon as I found it. >> >> Ah, yes. The cancel_work_sync() can also be done in >> brcmf_notify_escan_complete(). > > AFAIUC, brcmf_notify_scan_complete() is called from the work itself, > too, hence you can't issue cancel_work_sync() there (unless you make > it conditional). Hi Takashi, You are obviously right. Let's wait and see what v6 will look like ;-) Regards, Arend --0000000000005a7496060a49a8e8 Content-Type: application/pkcs7-signature; name="smime.p7s" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="smime.p7s" Content-Description: S/MIME Cryptographic Signature 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 2Gzj3QNJRLsZu1TLyOyBBIr/BE7UiY3RabgRzknBGAPmzhS+fmyM8OtM5BYBsFBrSUFtZZO2p/tf Nbc24J2zf2peoZ8MK+7WQqummYlOnz+FyDkA9EybeNMcS5C+xi/PAgMBAAGjggHdMIIB2TAOBgNV HQ8BAf8EBAMCBaAwgaMGCCsGAQUFBwEBBIGWMIGTME4GCCsGAQUFBzAChkJodHRwOi8vc2VjdXJl Lmdsb2JhbHNpZ24uY29tL2NhY2VydC9nc2djY3IzcGVyc29uYWxzaWduMmNhMjAyMC5jcnQwQQYI KwYBBQUHMAGGNWh0dHA6Ly9vY3NwLmdsb2JhbHNpZ24uY29tL2dzZ2NjcjNwZXJzb25hbHNpZ24y Y2EyMDIwME0GA1UdIARGMEQwQgYKKwYBBAGgMgEoCjA0MDIGCCsGAQUFBwIBFiZodHRwczovL3d3 dy5nbG9iYWxzaWduLmNvbS9yZXBvc2l0b3J5LzAJBgNVHRMEAjAAMEkGA1UdHwRCMEAwPqA8oDqG OGh0dHA6Ly9jcmwuZ2xvYmFsc2lnbi5jb20vZ3NnY2NyM3BlcnNvbmFsc2lnbjJjYTIwMjAuY3Js MCcGA1UdEQQgMB6BHGFyZW5kLnZhbnNwcmllbEBicm9hZGNvbS5jb20wEwYDVR0lBAwwCgYIKwYB BQUHAwQwHwYDVR0jBBgwFoAUljPR5lgXWzR1ioFWZNW+SN6hj88wHQYDVR0OBBYEFIikAXd8CEtv ZbDflDRnf3tuStPuMA0GCSqGSIb3DQEBCwUAA4IBAQCdS5XCYx6k2GGZui9DlFsFm75khkqAU7rT zBX04sJU1+B1wtgmWTVIzW7ugdtDZ4gzaV0S9xRhpDErjJaltxPbCylb1DEsLj+AIvBR34caW6ZG sQk444t0HPb29HnWYj+OllIGMbdJWr0/P95ZrKk2bP24ub3ZP/8SyzrohfIba9WZKMq6g2nTLZE3 BtkeSGJx/8dy0h8YmRn+adOrxKXHxhSL8BNn8wsmIZyYWe6fRcBtO3Ks2DOLyHCdkoFlN8x9VUQF N2ulEgqCbRKkx+qNirW86eF138lr1gRxzclu/38ko//MmkAYR/+hP3WnBll7zbpIt0jc9wyFkSqH p8a1MYICbTCCAmkCAQEwazBbMQswCQYDVQQGEwJCRTEZMBcGA1UEChMQR2xvYmFsU2lnbiBudi1z YTExMC8GA1UEAxMoR2xvYmFsU2lnbiBHQ0MgUjMgUGVyc29uYWxTaWduIDIgQ0EgMjAyMAIMTv1t bpIzNUky46LXMA0GCWCGSAFlAwQCAQUAoIHUMC8GCSqGSIb3DQEJBDEiBCCNDP153oM3vCC3pua8 9AWNirCVUAQEOkhPVyt21DwVQTAYBgkqhkiG9w0BCQMxCwYJKoZIhvcNAQcBMBwGCSqGSIb3DQEJ BTEPFw0yMzExMTYxOTAyMTNaMGkGCSqGSIb3DQEJDzFcMFowCwYJYIZIAWUDBAEqMAsGCWCGSAFl AwQBFjALBglghkgBZQMEAQIwCgYIKoZIhvcNAwcwCwYJKoZIhvcNAQEKMAsGCSqGSIb3DQEBBzAL BglghkgBZQMEAgEwDQYJKoZIhvcNAQEBBQAEggEAwEMheTLeUWkv9XDuNz9JYUdufRMMll6kvIDT BKWJJUnw8U+C8a2myciPH6oBTEk3wLP+8ipccNgx6riLOvjOQfaXk6HD8mjdv5p1P0LH2C84e2Dy 7LaRpx/wSMRMrd41o5sB9gfQ4xiaTmsS6miSwm9/hEfhKJap9nsB7/k+VLWA/cs9yVDbk3Yom2yR MEsyYSlvcNd5ZP9+Jg6wDOa/NVdHRlo6TxBIQv2DsPHMrxAV1qoo0UOKvVpIA2EZhQrE2ap5a+XB 1goQgYCpTAzsIHjCAucufpO8PS8p1FIYNg13k8SUdkZt10osZkK+5iPBvg2YMRpi6BKnce+uv/Aq Lw== --0000000000005a7496060a49a8e8--