Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp793893pxb; Tue, 12 Apr 2022 13:38:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwukRkQ33vlt40Dql6Oyoo+M9EROjlBuFuaGtHUvz0rDa6508gSdkIuhtXkOPriqs/fFVKo X-Received: by 2002:a17:903:1252:b0:154:ca85:59a0 with SMTP id u18-20020a170903125200b00154ca8559a0mr39821701plh.169.1649795900400; Tue, 12 Apr 2022 13:38:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649795900; cv=none; d=google.com; s=arc-20160816; b=JKtjNpRjp+08eH2isIGsT/1OZxmkrRkhr9qnFA8l38Ql8dC8VSAjerKyKZUTNStFcN LJAxlHtICdflAdPybdMIbjJGWrWs5g/eIDLl0oTMB96HzZKd5G5BUuiAnN2Ht85qoZ5t vC8JHx/mlFdRC8knS9oAIP9HbTH+TMKRDa/hHtPXLZsB8jOKvrjEHPxEJ19usi9wsz9O BO4wnC1ydp0Fy42AvVW9Gc7qe7tr5KYkJtsNhLS6N7s5JCWie6bH8O9Yk5Lxjbo/KHZx O7yAJy6oX0DG5H+mGBJuakYVvoZu9QlyZs+hKC4IfJ+J8+cmX2nFroY5DXkjuQ8IjtzZ tf4Q== 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 :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:dkim-signature; bh=iF6/C1RHwf7CTYQOQSnv8azPGC+3cM41Uv4y73pmXAM=; b=lqhPxUIDE10NVdDOaklIN2ZzXKC9JTeGOxpl2b3H//A6MuW0DODpkHjiL4dUEpLZWt uEX6qrmfyF2ZlxXePVwy6K1TayTd7hth891F2xG5/9fTDwJk+gFjRJ1GfbEDwM30iHsE kPSjsEGM8VGrZexGjYv/Jo+t/Anq6Po93gzG09kWfnHLaJaRMCeLxhTJy8ShM5mwdIy9 4nYQwmGjfvb6WhXuyjSWj/+kjY5erckpwv2EUEjDjsoHoWnD8DwlZkrB3uBqqQVsvNUm f0TVucXd94QIIh7y5pT3N+A0BFQj7q3asYpmGArPo06V9YLJmgZu5jy6GqTurf1UH/Qe ISrQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b="Tmevb8X/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id lp10-20020a17090b4a8a00b001cba1057b12si7067863pjb.95.2022.04.12.13.38.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 12 Apr 2022 13:38:20 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b="Tmevb8X/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id CECE2B0D01; Tue, 12 Apr 2022 13:11:57 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1387012AbiDLJFT (ORCPT + 99 others); Tue, 12 Apr 2022 05:05:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55470 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1376376AbiDLHn7 (ORCPT ); Tue, 12 Apr 2022 03:43:59 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A1C0E4616D for ; Tue, 12 Apr 2022 00:28:20 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1649748499; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=iF6/C1RHwf7CTYQOQSnv8azPGC+3cM41Uv4y73pmXAM=; b=Tmevb8X/88SfFPaIY/6VxLTKIYkMpb+1K6HqBw1b3oceNH9BkJ2XxQETbdnNQTCAAhrJyO WERd3xEmlSGi/Wwgw6ctnx2MlpEocP/DTvmEmWrjOPdNYzhoJWRxikF90owCGH6mUAPc0v 24YplLFyMfdMZJRebVgtiu1fhzi4y8I= Received: from mail-qt1-f199.google.com (mail-qt1-f199.google.com [209.85.160.199]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-652-MarEpLgGPrudXiXGS3pJWg-1; Tue, 12 Apr 2022 03:28:17 -0400 X-MC-Unique: MarEpLgGPrudXiXGS3pJWg-1 Received: by mail-qt1-f199.google.com with SMTP id z3-20020ac86b83000000b002ed0f18c23cso6104354qts.17 for ; Tue, 12 Apr 2022 00:28:17 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:subject:from:to:cc:date:in-reply-to :references:user-agent:mime-version:content-transfer-encoding; bh=iF6/C1RHwf7CTYQOQSnv8azPGC+3cM41Uv4y73pmXAM=; b=CvavYFKGGJwcmokt1I1ukao/6JBoHOViieuKn7hMcq5nObS1g6zCBZSsTdr0kF/Z1S 74cYpoBuxfJjFFRoQZX3lY9RAqDdY8GQUbzOXxxT1B1XGl1UW2KOusvLzCtaL0mlXMet 2GxPQDOLfZXjNNEhiy1lSz3fC1gYWtC8wXjRsgSBXNIbWk+hbsBO9jUuQ4zM2Y79QgmX qb9x/Av54Tj5HgdUtYyZrRc9I6kiNeblBYhfiWrElx7BK1XhArAX6Xs8efuA5xWwACci USC7Jg5+AV+LIzzQt3eBVOFJRCrGrpZhf6tfuu1i3Wwo1fEFnjiYv31TmJLNlO6Cxm17 Chzg== X-Gm-Message-State: AOAM531BSMTnwvXvmy9PON64Rzc/S7oga/+pYOlqutCNjl6V0CYpddU0 7nzNdtK1LvCeiQ5/+9WUSz4VcmykzFxmiFW3Qu+1rGtghhxA5zazHFr7LWmOqvVgkufdypl0Ce0 Cu9cRJWkAkcl4x8oznJTzGQk2 X-Received: by 2002:ad4:5d49:0:b0:444:4dda:9ac1 with SMTP id jk9-20020ad45d49000000b004444dda9ac1mr2488105qvb.108.1649748497393; Tue, 12 Apr 2022 00:28:17 -0700 (PDT) X-Received: by 2002:ad4:5d49:0:b0:444:4dda:9ac1 with SMTP id jk9-20020ad45d49000000b004444dda9ac1mr2488091qvb.108.1649748497150; Tue, 12 Apr 2022 00:28:17 -0700 (PDT) Received: from gerbillo.redhat.com (146-241-96-237.dyn.eolo.it. [146.241.96.237]) by smtp.gmail.com with ESMTPSA id y18-20020ac85f52000000b002ed08a7dc8dsm10612638qta.13.2022.04.12.00.28.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 12 Apr 2022 00:28:16 -0700 (PDT) Message-ID: <3daec73abc2f21809a8057b6a9729a70d2877231.camel@redhat.com> Subject: Re: [PATCH V2] drivers: nfc: nfcmrvl: fix double free bug in nfcmrvl_nci_unregister_dev() From: Paolo Abeni To: Duoming Zhou , krzk@kernel.org, linux-kernel@vger.kernel.org Cc: netdev@vger.kernel.org, akpm@linux-foundation.org, davem@davemloft.net, gregkh@linuxfoundation.org, alexander.deucher@amd.com, broonie@kernel.org Date: Tue, 12 Apr 2022 09:28:13 +0200 In-Reply-To: <20220410135214.74216-1-duoming@zju.edu.cn> References: <20220410135214.74216-1-duoming@zju.edu.cn> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.42.4 (3.42.4-2.fc35) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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-kernel@vger.kernel.org Hello, On Sun, 2022-04-10 at 21:52 +0800, Duoming Zhou wrote: > There is a potential double bug in nfcmrvl usb driver between > unregister and resume operation. > > The race that cause that double free bug can be shown as below: > > (FREE) | (USE) > | nfcmrvl_resume > | nfcmrvl_submit_bulk_urb > | nfcmrvl_bulk_complete > | nfcmrvl_nci_recv_frame > | nfcmrvl_fw_dnld_recv_frame > | queue_work > | fw_dnld_rx_work > | fw_dnld_over > | release_firmware > | kfree(fw); //(1) > nfcmrvl_disconnect | > nfcmrvl_nci_unregister_dev | > nfcmrvl_fw_dnld_abort | > fw_dnld_over | ... > if (priv->fw_dnld.fw) | > release_firmware | > kfree(fw); //(2) | > ... | priv->fw_dnld.fw = NULL; > > When nfcmrvl usb driver is resuming, we detach the device. > The release_firmware() will deallocate firmware in position (1), > but firmware will be deallocated again in position (2), which > leads to double free. > > This patch reorders nfcmrvl_fw_dnld_deinit() before nfcmrvl_fw_dnld_abort() > in order to prevent double free bug. Because destroy_workqueue() will > not return until all work items are finished. The priv->fw_dnld.fw will > be set to NULL after work items are finished and fw_dnld_over() called by > nfcmrvl_nci_unregister_dev() will check whether priv->fw_dnld.fw is NULL. > So the double free bug could be prevented. > > Signed-off-by: Duoming Zhou This looks like a -net candidates, could you please add a suitable fixes tag? Thanks! Paolo