Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3333558yba; Mon, 6 May 2019 22:39:53 -0700 (PDT) X-Google-Smtp-Source: APXvYqwhd1iWFJnxSWO3cuJfewV0YJgKxOkhl2n9/Z5KfwB0HPxXvYi33X54L6TH0PJfcdW5cX3m X-Received: by 2002:a65:50c2:: with SMTP id s2mr37824836pgp.112.1557207593554; Mon, 06 May 2019 22:39:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557207593; cv=none; d=google.com; s=arc-20160816; b=qiBYHpGhUvZ8m/ZAeydiYyMZGFqkjQDONgui2N+DH1ilSiArmoyOeLqO/lXrzXJAqK UbB6o/fCGKRcho1tsFBFZWMDeWfyzaQO7UC1J6EZOeL8JKonlwv6m+7BN/s8lmCT5GHb U07CxooE/E22fKsSIY03VSKAam9MBWSTedxHCkJBfRWnCeUmrM+dhv3nnRqBDaHajlWB d+2sXYsdZata52ogF2bpPbiYFZSzGMJRZHVt8Ow1PPhAUpCgDtrD5K9EGONdYyC2ekId XSfhVUVbP0v/hJA4okORIHjUSfHRIirU0utt4t+6Yfqw21je99yUR14P7jNrwKzj7zX1 GG3Q== 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:date:subject:cc:to:from :dkim-signature; bh=X4H7GXY/l1uEpwhKLGf3gjqex5zCtjA2SUIMOzU46pQ=; b=lvahlf8zgwezGwmSD4H2n94Kt/TWauN5w5zbxNV34seVB8wyOQbPGBwQNhVLTI5O54 KdGDH3pAG0QRq4JsEFe6NGux1KqPfsTccW4ONhit94+MrP5RCbbXI0N0f84TxFrwKVqY HbaBCe2zYS3pPSc8bZ3S4RKq/x69rIDATsJRLnPB69qfx9Bd1i13zbLZjItT3oBs33rr +iLwn+v9Mn8vt8K0mSF4u05ttlJbBQMvvLBjlD3Bs8WeHNc/4eGtYxWp24KgaIIAiUg7 lqtqOU5CQr7FgoCl8Zit5K930inJIKD5/5lb7x6v/CL3aHPMJxR6A0stFpPzApdGdSzs ceMg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="RrTF/GJ6"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t21si17086976plr.366.2019.05.06.22.39.38; Mon, 06 May 2019 22:39:53 -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=@kernel.org header.s=default header.b="RrTF/GJ6"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728701AbfEGFig (ORCPT + 99 others); Tue, 7 May 2019 01:38:36 -0400 Received: from mail.kernel.org ([198.145.29.99]:58346 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728681AbfEGFie (ORCPT ); Tue, 7 May 2019 01:38:34 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id B5AC0206A3; Tue, 7 May 2019 05:38:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1557207513; bh=urE+JUTXgi9HJ2ubXFyGGLoxFb/k6SX5voM/jz7q91g=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=RrTF/GJ6ha+G5SzuyOo2Cd7nJeTEkbM/uuTHlWnAfkfKq8IIW/uWcrAXcLKUG5bHu yi8d2jX21XyKg9BsekeHqfjVBwN3iLQWo+TvF/5ca3SycXyLGYlrHV+pxwQoqo+Mau BAzklKRYOsXs3oi4cBnaXlKOv1y9KqNWC/4+TE98= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Aditya Pakki , Dan Williams , Sasha Levin , linux-nvdimm@lists.01.org Subject: [PATCH AUTOSEL 4.14 06/95] libnvdimm/btt: Fix a kmemdup failure check Date: Tue, 7 May 2019 01:36:55 -0400 Message-Id: <20190507053826.31622-6-sashal@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190507053826.31622-1-sashal@kernel.org> References: <20190507053826.31622-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Aditya Pakki [ Upstream commit 486fa92df4707b5df58d6508728bdb9321a59766 ] In case kmemdup fails, the fix releases resources and returns to avoid the NULL pointer dereference. Signed-off-by: Aditya Pakki Signed-off-by: Dan Williams Signed-off-by: Sasha Levin --- drivers/nvdimm/btt_devs.c | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/drivers/nvdimm/btt_devs.c b/drivers/nvdimm/btt_devs.c index d58925295aa7..e610dd890263 100644 --- a/drivers/nvdimm/btt_devs.c +++ b/drivers/nvdimm/btt_devs.c @@ -190,14 +190,15 @@ static struct device *__nd_btt_create(struct nd_region *nd_region, return NULL; nd_btt->id = ida_simple_get(&nd_region->btt_ida, 0, 0, GFP_KERNEL); - if (nd_btt->id < 0) { - kfree(nd_btt); - return NULL; - } + if (nd_btt->id < 0) + goto out_nd_btt; nd_btt->lbasize = lbasize; - if (uuid) + if (uuid) { uuid = kmemdup(uuid, 16, GFP_KERNEL); + if (!uuid) + goto out_put_id; + } nd_btt->uuid = uuid; dev = &nd_btt->dev; dev_set_name(dev, "btt%d.%d", nd_region->id, nd_btt->id); @@ -212,6 +213,13 @@ static struct device *__nd_btt_create(struct nd_region *nd_region, return NULL; } return dev; + +out_put_id: + ida_simple_remove(&nd_region->btt_ida, nd_btt->id); + +out_nd_btt: + kfree(nd_btt); + return NULL; } struct device *nd_btt_create(struct nd_region *nd_region) -- 2.20.1