Received: by 10.213.65.68 with SMTP id h4csp1031398imn; Wed, 14 Mar 2018 07:38:03 -0700 (PDT) X-Google-Smtp-Source: AG47ELtygACWytR/WjPQI3LcV2mFTn8uQLF9o9DQZHh09cZclRNPmehiCy1/HsnBYQZxSqp8Ljhb X-Received: by 10.101.97.139 with SMTP id c11mr3881877pgv.433.1521038283460; Wed, 14 Mar 2018 07:38:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521038283; cv=none; d=google.com; s=arc-20160816; b=QmGR9FwL8Nzi8pU1g0OogsJF9ZurfxSW5wcoVPZ4YtPfGfhnrBi3nOyR76tjqnvVd8 M3Y1qJQg82zAfPCXRPTPnvkhgfwDvIJSDfQuqbp/LHGGqwAJku1WiKxh05xDwcF6scXJ ZFRuA63jGKU89OXaVvFp+yrym9o7pldWJQRbcinr5boNyPK50AW8UShs8Jc/1ziey148 4Yw5+BiNxRznxK3b/LcP75i72jSKuh1YV0ZdLDXWS9QC8etfSWOS8SzllzngICidQuzd qH8ReG6J34DYfMVhYUkUlpKiwaT9aXY/1ja7rkvjz3qGtz4P3ei2kQlQuXBf/ESMqLsY YZ0Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :arc-authentication-results; bh=0arM6yVhnEpvl7lIeLb0jlKiEU5qo/TQu1W/qJX5CX0=; b=f3tEnPcT675HaYTIsiQSt/sy7xNhzYZyvNb2Zo3n2gE3IBj3o+g1FmT0w/zH1IsMIt w/9eNbP6K3HQzgrZ0sn++cRGOBX0SzZPs/ugAjoSp4iRoGuNEty5ICJzwc6qw7HOJNpy KlzMjIJjMrqNOBr3BXuvaIt08NBPfXWARQQmN9JkAb1HdAgApxIFHKSqF3ZLmIhU4cOC wcSx6ANHZfmtu9/07M601fL6HgrJ0MdKHrv+nNASUhCKrjrK28YLuygClxwrweGZ8bC9 TF8sKWJEPHB3b6KeM8SWrH6jlR/B+LQNzd7loixvUmRnJ9bMLc/po3t/qWnoDtUbzdq0 9a/w== ARC-Authentication-Results: i=1; mx.google.com; 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 s11-v6si2074668plj.701.2018.03.14.07.37.48; Wed, 14 Mar 2018 07:38:03 -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; 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 S1751757AbeCNOgY (ORCPT + 99 others); Wed, 14 Mar 2018 10:36:24 -0400 Received: from mail.bootlin.com ([62.4.15.54]:55314 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751289AbeCNOgW (ORCPT ); Wed, 14 Mar 2018 10:36:22 -0400 Received: by mail.bootlin.com (Postfix, from userid 110) id C80532073C; Wed, 14 Mar 2018 15:36:20 +0100 (CET) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on mail.bootlin.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT shortcircuit=ham autolearn=disabled version=3.4.0 Received: from bbrezillon (96-65-213-252-static.hfc.comcastbusiness.net [96.65.213.252]) by mail.bootlin.com (Postfix) with ESMTPSA id CF39720846; Wed, 14 Mar 2018 15:36:03 +0100 (CET) Date: Wed, 14 Mar 2018 15:36:00 +0100 From: Boris Brezillon To: Arvind Yadav Cc: dwmw2@infradead.org, computersforpeace@gmail.com, boris.brezillon@free-electrons.com, marek.vasut@gmail.com, richard@nod.at, cyrille.pitchen@wedev4u.fr, dedekind1@gmail.com, linux-kernel@vger.kernel.org, linux-mtd@lists.infradead.org Subject: Re: [PATCH 1/2] mtd: use put_device() if device_register fail Message-ID: <20180314153600.458c0fe4@bbrezillon> In-Reply-To: <39c4af723ea37cd05976a17cb9c1fbc975496ffd.1520592440.git.arvind.yadav.cs@gmail.com> References: <39c4af723ea37cd05976a17cb9c1fbc975496ffd.1520592440.git.arvind.yadav.cs@gmail.com> X-Mailer: Claws Mail 3.15.0-dirty (GTK+ 2.24.31; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 9 Mar 2018 16:20:48 +0530 Arvind Yadav wrote: > if device_register() returned an error! Always use put_device() > to give up the reference initialized. > > Signed-off-by: Arvind Yadav > --- > drivers/mtd/mtdcore.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/drivers/mtd/mtdcore.c b/drivers/mtd/mtdcore.c > index 28553c8..4d77ca2 100644 > --- a/drivers/mtd/mtdcore.c > +++ b/drivers/mtd/mtdcore.c > @@ -586,6 +586,7 @@ int add_mtd_device(struct mtd_info *mtd) > return 0; > > fail_added: > + put_device(&mtd->dev); Not sure this is a good idea: the put_device() call will trigger an mtd_devtype->release(), which will in turn call device_destroy() on something that does not exist yet. Not sure if this is a real problem, but it does not look like the right thing to do. > of_node_put(mtd_get_of_node(mtd)); You're referencing an object that is supposed to have been freed/released by the put_device() call. Again, it's not really a problem because in our case ->release() does not free the mtd object (as is usually done in other parts of the kernel), but it still looks wrong. It's probably better to move the of_node_put() and the below idr_remove() call in the ->release() hook if you want to use put_device(). > idr_remove(&mtd_idr, i); > fail_locked: -- Boris Brezillon, Bootlin (formerly Free Electrons) Embedded Linux and Kernel engineering https://bootlin.com