From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-oo1-f42.google.com (mail-oo1-f42.google.com [209.85.161.42]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id A8E4E4CE12; Mon, 12 Feb 2024 22:03:45 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.161.42 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707775427; cv=none; b=asog5OkANs9T1cy54BcvsFRjZRH+7ajuKuPy7IoVmNsNFM1JotE8Dt/lsYxGWgsGR1KbL5BqF2k6Uqx3Z8J6ZqwXFKtcyWaThbH6iDw0NWhvpM2wkyv12praDLcoo4xwE0xvaNqnWVxzV2xAiPGDfmI2pcPJ2kvidqMrttWoYTM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707775427; c=relaxed/simple; bh=W/bpF4fDyBYCxuho4baujxfsMHNkNNXJSkVJNKjpCzs=; h=From:Date:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=P9z51ZsJwg9T2VktXqCMntst91C/Wn2Va3y2KWtXn9IU3AiARr2PEioj3H7lxgdTKwkZmH6bGk+4fP7TdVn+/OenamEhU8QFwXNfcGuEq5KP8TZ3qHATg+JsO363wOgAvBWWQa8othZtUbHRbdq9Zdd+3svx4H4W/n3jC8QHI+A= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=Ol5cDm0Z; arc=none smtp.client-ip=209.85.161.42 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="Ol5cDm0Z" Received: by mail-oo1-f42.google.com with SMTP id 006d021491bc7-59a94c0fb55so175770eaf.0; Mon, 12 Feb 2024 14:03:45 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1707775424; x=1708380224; darn=vger.kernel.org; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:date:from:from:to:cc:subject:date:message-id:reply-to; bh=93VuehxW8IiZjqg3cy8gX+Dj6JAjR6qHpJt8+OJ38pE=; b=Ol5cDm0ZaoRcnMscYemjlZUGsRllvsyHNvki2ldzAwXTYubOc1PELbHIbhucYB/0Xn bFmJppFfWViJi8aubQXsYOGYy/f+avY+uyaguok0BOJEaPOt+6VdCPJZQYSsu1BwxhE+ CG6sjhm7PWbM1JKaXx6WGIx1AABclOolLrsagc2vXQ0H6fVpDlQxeLtkJiqifq/JUcKS LnTSBgvnmJvsdTSUCMi5R4pJVbETweRnwjwKMYsvD+KYV2N0PheIro0hXr7C98vyVnjE fPkVSmsXlLu+R4DkppTJAF+jhulYwoPT56fO5/3rQf1hqIg0lFOCCoxMhrAQbjrF7G4k ZIDw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1707775424; x=1708380224; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:date:from:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=93VuehxW8IiZjqg3cy8gX+Dj6JAjR6qHpJt8+OJ38pE=; b=o2Rc+EVNDs7hZiEK2aXma/UOfqjCSoJ19JhhQw8XILGq8K8hHxXcMIJZp23VhSJPrw xu6w1r12QnaWBVo+iDM31YbBboR6j6IpmEGP/MEGlSf7NfcBzFot6a8F8cj80RYo2QEU 596i2k5lYnkKE9H7dDq1F5jVHIbLcgdU40pPjmaXxBc2D38/sJ2yqcWKfOMhg3BxJZXu Agjjmm+4L8QfpRBQw0StzXjRwKRtNiqsGyhh3/pPlIQpZnaEdZESSFiTu0zUMi894n9I W+nvZe5vFrkBDpgLMtv1jje0zOeeEJON/JlelrpPQUrFPkagAOy0c3TjTK4sDDTzYPkm umjA== X-Forwarded-Encrypted: i=1; AJvYcCXIB/5clU5q86e7wWTez4O+IP+p9sTfNVV6PGQ1cGOHJl21u0DPItfRGJXi4J+vktWOa5RsQ1PHzspgxc4L38x1GRxFKWOGohzjZ0rKHd5rMqwahLy87gbkrYu6IhwXwmOIC+Os4f00taYJOlnOUSflS2uoUyC23gQoJ+wi0LXefmjuA61LrVL6N9908Vz6Z9PoBIDQw7gvhANs8ThI3C8= X-Gm-Message-State: AOJu0YzwdryA2pPL/86+tJjObqqB64JlblkLuBUNKuSJpMbMCMDBk2OP phOvx7zDqiY96cKjJJgRJBsBr9OPMwvnH1iYdbTYHPJeRtEjI+8M X-Google-Smtp-Source: AGHT+IE5OBKx1zbmYznUgitfUIrZdUAxmS+Eas2NAO7RGcO4j6U6ISP+C6U15Hc5IQBn0IfaRdlLPw== X-Received: by 2002:a05:6358:d093:b0:178:67dc:aba8 with SMTP id jc19-20020a056358d09300b0017867dcaba8mr9820912rwb.17.1707775424575; Mon, 12 Feb 2024 14:03:44 -0800 (PST) X-Forwarded-Encrypted: i=1; AJvYcCXsq3wUY11a+L7NuGj3BsmexGP6eZMiamdWyBsuJhiWpvO+ZarhxYNh9jN84eNMeJYhoOciFuWzz1ZnHmXsGB1m36yXHC0X6Bvd9KjpNp2fx7VJj0MQPEsh3nsPhRZtad4FDyh1OEF5Sl6qvAdFW4vKJm4/bHT+gbZ3oTrxYFPUKWoaXCU5A2ztB/oOmEw9ipe0214tr1qPrrqu1jsbviotxTqCJoI+OwAKtjNxF//RL0E6DEsDwDfSwF9RXH5EZkhrN3NnBKB8JaxLEB15EJZ4s9CN4fU7ebDUQxUsrv6wIn9BfRO+1c8jZ6oAvubgeK4EOyp07xU2RteUIcVjpr9wRJuXYhpDE83B7le4oDDm3DgtWGzYJcRDGoGD0kcBYSLEQL/C5dNkiJq8bdSCq4mRA3hixJM8UqLw8YsrXx6+qTzJ5QU+i6xDEbeZdz19lsh1rjhdIC0ch55qG4OdAFBwJ3zbYmTinLp2J+1HCDD0D7jt4v3+XiYQwrtu5r7UxNtDUNdE/xZbr6vFtQozelocRvVVtl3CUicsCQ6IAHDrEAdS49M9HFhDKZm+OLaHLGH6GA5d6ktp7067c5t1JpQ8JNUR Received: from debian ([2601:641:300:14de:7353:5102:82c6:956f]) by smtp.gmail.com with ESMTPSA id x23-20020aa79197000000b006e05c801748sm5994884pfa.199.2024.02.12.14.03.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 12 Feb 2024 14:03:44 -0800 (PST) From: fan X-Google-Original-From: fan Date: Mon, 12 Feb 2024 14:03:24 -0800 To: Mathieu Desnoyers Cc: Dan Williams , Alasdair Kergon , Mike Snitzer , Mikulas Patocka , Andrew Morton , Linus Torvalds , Vishal Verma , Dave Jiang , Matthew Wilcox , Arnd Bergmann , Russell King , linux-arch@vger.kernel.org, linux-cxl@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-xfs@vger.kernel.org, dm-devel@lists.linux.dev, nvdimm@lists.linux.dev Subject: Re: [PATCH] nvdimm/pmem: Fix leak on dax_add_host() failure Message-ID: References: <20240212162722.19080-1-mathieu.desnoyers@efficios.com> Precedence: bulk X-Mailing-List: linux-xfs@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20240212162722.19080-1-mathieu.desnoyers@efficios.com> On Mon, Feb 12, 2024 at 11:27:22AM -0500, Mathieu Desnoyers wrote: > Fix a leak on dax_add_host() error, where "goto out_cleanup_dax" is done > before setting pmem->dax_dev, which therefore issues the two following > calls on NULL pointers: > > out_cleanup_dax: > kill_dax(pmem->dax_dev); > put_dax(pmem->dax_dev); > > Signed-off-by: Mathieu Desnoyers > Reviewed-by: Dan Williams > Cc: Alasdair Kergon > Cc: Mike Snitzer > Cc: Mikulas Patocka > Cc: Andrew Morton > Cc: Linus Torvalds > Cc: Dan Williams > Cc: Vishal Verma > Cc: Dave Jiang > Cc: Matthew Wilcox > Cc: Arnd Bergmann > Cc: Russell King > Cc: linux-arch@vger.kernel.org > Cc: linux-cxl@vger.kernel.org > Cc: linux-fsdevel@vger.kernel.org > Cc: linux-mm@kvack.org > Cc: linux-xfs@vger.kernel.org > Cc: dm-devel@lists.linux.dev > Cc: nvdimm@lists.linux.dev Reviewed-by: Fan Ni > --- > drivers/nvdimm/pmem.c | 3 +-- > 1 file changed, 1 insertion(+), 2 deletions(-) > > diff --git a/drivers/nvdimm/pmem.c b/drivers/nvdimm/pmem.c > index 4e8fdcb3f1c8..9fe358090720 100644 > --- a/drivers/nvdimm/pmem.c > +++ b/drivers/nvdimm/pmem.c > @@ -566,12 +566,11 @@ static int pmem_attach_disk(struct device *dev, > set_dax_nomc(dax_dev); > if (is_nvdimm_sync(nd_region)) > set_dax_synchronous(dax_dev); > + pmem->dax_dev = dax_dev; > rc = dax_add_host(dax_dev, disk); > if (rc) > goto out_cleanup_dax; > dax_write_cache(dax_dev, nvdimm_has_cache(nd_region)); > - pmem->dax_dev = dax_dev; > - > rc = device_add_disk(dev, disk, pmem_attribute_groups); > if (rc) > goto out_remove_host; > -- > 2.39.2 >