Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp292761yba; Thu, 18 Apr 2019 01:07:40 -0700 (PDT) X-Google-Smtp-Source: APXvYqzYGumH4wBYUh0cEfWJUhREC8KmjpXtOXvkhan/x1h7jICZIzrP/M+EnsQ3PWZ+4o0g46/r X-Received: by 2002:a63:f115:: with SMTP id f21mr81390660pgi.65.1555574860372; Thu, 18 Apr 2019 01:07:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555574860; cv=none; d=google.com; s=arc-20160816; b=jAbr5VW+xFkh+SrMp7C8x1CSE5At7Fedop2RB5b+Wx5Ay2xbsQaVuGNDcoaTqtOSEm +P8J9ypT7nD9MCMWjp6xiIzABrPuFk+N5+oMmjDWyDmrwFPiiQxOlrrY5BADcmyi3srM H/Tbr6Ze6aUDp6Hnz3a7L6Q7YgmjrCbaaTU0cb/KphrXqA1OZwgdoO7mspSHlMzIxnU2 83bL8xetYRlVcRIO9ov9MQf0CxGrNexcRIizUA7MM4ngX6K/ygeXaBm70sqml0fJbmIn zhK1wwyvNDSXSmH7ZuwxGOtIIBoLzft2iwRf2j2/1gB+4Q9ZXkE87aeSBqHS+jHi6hn5 Qzbg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature; bh=ioQRY83xEERN2fSci98znNAlVU0ermoCtM9YHhE2XJ8=; b=wTitg/bCSfz7uBGDonnsw4yKm3FFu+9jUy5jl1CBfXZ1mKC50PO6molYlyMailt/s4 BpIvSWiyeqUM/SVH6/fQC14a+3ZCV4qTELHKAm7YyFZHYNInIbsAAwyumskSYAadiE+2 3HjLQPeHuhAWvmxxdmYWZhlOsd3Q0rm/zRoFdyJZOXAfVJ1zEOTlcgOV1389IyS/vJNm TH2hLTvD7w45RXoXgUdndQOaPQDu8sWNaOIWqZpTiTOHpDXKrBRFMsVRR6r5bivVxk5+ CaBEvjMCED0RJEOttHw0MDiGD7P+zKjzQ3PKQ+IuMauf3A0/cEvjQvJi/AEIbZc0turq 2IFA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=fz1ecdnz; dkim=pass header.i=@codeaurora.org header.s=default header.b=fz1ecdnz; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f7si1241062pgq.522.2019.04.18.01.07.25; Thu, 18 Apr 2019 01:07:40 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=fz1ecdnz; dkim=pass header.i=@codeaurora.org header.s=default header.b=fz1ecdnz; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388282AbfDRIFz (ORCPT + 99 others); Thu, 18 Apr 2019 04:05:55 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:57292 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731317AbfDRIFz (ORCPT ); Thu, 18 Apr 2019 04:05:55 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id A779260FEA; Thu, 18 Apr 2019 08:05:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1555574753; bh=p+Nj2KDJKpPYMONkjYbQYbdoYpmFBC86DMuT+yxregk=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=fz1ecdnzcao1M9OQtvNMEflW+0EzdER7JGRJ73Ec89c1KpKgSQHSluCxvN+zyvCeb RlZRkm7ObL8gA/I0jgCnDqguyMWr77GOi6vhQ5tMAZJiayS5OxL76Le2SaB6i2zE39 6BhmCibKgZV5V7XJaH23+cn7KWihXG02N7Z7i9vU= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED autolearn=no autolearn_force=no version=3.4.0 Received: from [10.204.79.15] (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: mojha@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 0A47960907; Thu, 18 Apr 2019 08:05:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1555574753; bh=p+Nj2KDJKpPYMONkjYbQYbdoYpmFBC86DMuT+yxregk=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=fz1ecdnzcao1M9OQtvNMEflW+0EzdER7JGRJ73Ec89c1KpKgSQHSluCxvN+zyvCeb RlZRkm7ObL8gA/I0jgCnDqguyMWr77GOi6vhQ5tMAZJiayS5OxL76Le2SaB6i2zE39 6BhmCibKgZV5V7XJaH23+cn7KWihXG02N7Z7i9vU= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 0A47960907 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=mojha@codeaurora.org Subject: Re: stm class: Fix possible double free To: Pan Bian , Alexander Shishkin , Maxime Coquelin , Alexandre Torgue Cc: linux-stm32@st-md-mailman.stormreply.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org References: <1555572178-73786-1-git-send-email-bianpan2016@163.com> From: Mukesh Ojha Message-ID: <6d629a30-0acb-803e-c6f3-978e2a32c12d@codeaurora.org> Date: Thu, 18 Apr 2019 13:35:48 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: <1555572178-73786-1-git-send-email-bianpan2016@163.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/18/2019 12:52 PM, Pan Bian wrote: > The function stm_register_device() calls put_device(&stm->dev) to > release allocated memory (in stm_device_release()) on error paths. > However, after that, the freed memory stm is released again, resulting > in a double free bug. There is a similar issue in the function > stm_source_register_device. This patch fixes these issues. > > Signed-off-by: Pan Bian Looks good to me. Reviewed-by: Mukesh Ojha Cheers, -Mukesh > --- > drivers/hwtracing/stm/core.c | 9 ++++----- > 1 file changed, 4 insertions(+), 5 deletions(-) > > diff --git a/drivers/hwtracing/stm/core.c b/drivers/hwtracing/stm/core.c > index c7ba8ac..cfb5c4d 100644 > --- a/drivers/hwtracing/stm/core.c > +++ b/drivers/hwtracing/stm/core.c > @@ -886,8 +886,10 @@ int stm_register_device(struct device *parent, struct stm_data *stm_data, > return -ENOMEM; > > stm->major = register_chrdev(0, stm_data->name, &stm_fops); > - if (stm->major < 0) > - goto err_free; > + if (stm->major < 0) { > + vfree(stm); > + return err; > + } > > device_initialize(&stm->dev); > stm->dev.devt = MKDEV(stm->major, 0); > @@ -933,8 +935,6 @@ int stm_register_device(struct device *parent, struct stm_data *stm_data, > > /* matches device_initialize() above */ > put_device(&stm->dev); > -err_free: > - vfree(stm); > > return err; > } > @@ -1277,7 +1277,6 @@ int stm_source_register_device(struct device *parent, > > err: > put_device(&src->dev); > - kfree(src); > > return err; > }