From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mga03.intel.com (mga03.intel.com [134.134.136.65]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ml01.01.org (Postfix) with ESMTPS id 63BD2211B85C5 for ; Thu, 17 Jan 2019 21:03:58 -0800 (PST) Date: Fri, 18 Jan 2019 13:03:33 +0800 From: Wei Yang Subject: Re: [PATCH] libnvdimm, pfn: not allocate nd_pfn->pfn_sb if already allocated Message-ID: <20190118050333.GA4233@richard> References: <20190118033544.3980-1-richardw.yang@linux.intel.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: Wei Yang Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: linux-nvdimm-bounces@lists.01.org Sender: "Linux-nvdimm" To: Dan Williams Cc: Ross Zwisler , linux-nvdimm List-ID: On Thu, Jan 17, 2019 at 08:31:56PM -0800, Dan Williams wrote: >On Thu, Jan 17, 2019 at 7:36 PM Wei Yang wrote: >> >> In current implementation, we might re-allocate nd_pfn->pfn_sb. >> >> For example: >> >> nd_dax_probe() >> nd_pfn->pfn_sb = devm_kzalloc() >> >> dax_pmem_probe() >> nvdimm_setup_pfn() >> nd_pfn_init() >> nd_pfn->pfn_sb = devm_kzalloc() >> >> This patch checks nd_pfn->pfn_sb before allocating it in nd_pfn_init(). > >Ugh, this patch is unfortunately uncovering a deeper problem. >nvdimm_setup_pfn() should not be calling nd_pfn_init(). This >effectively is always re-initializing the info-block, benign but >unnecessary. Instead it needs to be using nd_pfn_validate() followed >by an __nvdimm_setup_pfn() in the dax_pmem_probe() path. > >Good find! So we should fix this like: dax_pmem_probe() nd_pfn_validate() __nvdimm_setup_pfn() Is my understanding correct? -- Wei Yang Help you, Help me _______________________________________________ Linux-nvdimm mailing list Linux-nvdimm@lists.01.org https://lists.01.org/mailman/listinfo/linux-nvdimm