Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753047AbdFLWuy (ORCPT ); Mon, 12 Jun 2017 18:50:54 -0400 Received: from gateway36.websitewelcome.com ([192.185.194.2]:38859 "EHLO gateway36.websitewelcome.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752666AbdFLWux (ORCPT ); Mon, 12 Jun 2017 18:50:53 -0400 X-Greylist: delayed 1495 seconds by postgrey-1.27 at vger.kernel.org; Mon, 12 Jun 2017 18:50:52 EDT Date: Mon, 12 Jun 2017 17:25:44 -0500 Message-ID: <20170612172544.Horde.Br2grYSXmXw3bfXZefqg8tb@gator4166.hostgator.com> From: "Gustavo A. R. Silva" To: Jarkko Sakkinen Cc: Peter Huewe , Marcel Selhorst , Jason Gunthorpe , tpmdd-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org Subject: Re: [PATCH] char: tmp: fix potential null pointer dereference References: <20170530215123.GA7484@embeddedgus> <20170531121129.f3576lq7peott6gd@intel.com> In-Reply-To: <20170531121129.f3576lq7peott6gd@intel.com> User-Agent: Horde Application Framework 5 Content-Type: text/plain; charset=utf-8; format=flowed; DelSp=Yes MIME-Version: 1.0 Content-Disposition: inline X-AntiAbuse: This header was added to track abuse, please include it with any abuse report X-AntiAbuse: Primary Hostname - gator4166.hostgator.com X-AntiAbuse: Original Domain - vger.kernel.org X-AntiAbuse: Originator/Caller UID/GID - [47 12] / [47 12] X-AntiAbuse: Sender Address Domain - embeddedor.com X-BWhitelist: no X-Source-IP: 108.167.133.22 X-Exim-ID: 1dKXmK-003YuY-L1 X-Source: X-Source-Args: X-Source-Dir: X-Source-Sender: gator4166.hostgator.com [108.167.133.22]:18686 X-Source-Auth: garsilva@embeddedor.com X-Email-Count: 6 X-Source-Cap: Z3V6aWRpbmU7Z3V6aWRpbmU7Z2F0b3I0MTY2Lmhvc3RnYXRvci5jb20= Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1352 Lines: 55 Hi Jarkko, Please, see my comments below Quoting Jarkko Sakkinen : > On Tue, May 30, 2017 at 04:51:23PM -0500, Gustavo A. R. Silva wrote: >> NULL check at line 147: if (chip) {, implies chip might be NULL. >> Function dev_get_drvdata() dereference pointer chip. >> Move pointer priv assignment inside the IF block that checks >> pointer chip. >> >> Addresses-Coverity-ID: 1397646 >> Signed-off-by: Gustavo A. R. Silva > > It cannot be. > I got it. > /Jarkko > >> --- >> drivers/char/tpm/tpm_atmel.c | 3 ++- >> 1 file changed, 2 insertions(+), 1 deletion(-) >> >> diff --git a/drivers/char/tpm/tpm_atmel.c b/drivers/char/tpm/tpm_atmel.c >> index 0d322ab..0826efd 100644 >> --- a/drivers/char/tpm/tpm_atmel.c >> +++ b/drivers/char/tpm/tpm_atmel.c >> @@ -142,9 +142,10 @@ static struct platform_device *pdev; >> static void atml_plat_remove(void) >> { >> struct tpm_chip *chip = dev_get_drvdata(&pdev->dev); >> - struct tpm_atmel_priv *priv = dev_get_drvdata(&chip->dev); >> + struct tpm_atmel_priv *priv; >> >> if (chip) { So, this NULL check could be removed? >> + priv = dev_get_drvdata(&chip->dev); >> tpm_chip_unregister(chip); >> if (priv->have_region) >> atmel_release_region(priv->base, priv->region_size); >> -- >> 2.5.0 >> Thank you -- Gustavo A. R. Silva