Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2997758AbdD1WjJ (ORCPT ); Fri, 28 Apr 2017 18:39:09 -0400 Received: from mail-oi0-f54.google.com ([209.85.218.54]:33929 "EHLO mail-oi0-f54.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1034262AbdD1WjE (ORCPT ); Fri, 28 Apr 2017 18:39:04 -0400 MIME-Version: 1.0 In-Reply-To: <1493418523.30303.6.camel@hpe.com> References: <20170427225706.26791-1-toshi.kani@hpe.com> <1493418523.30303.6.camel@hpe.com> From: Dan Williams Date: Fri, 28 Apr 2017 15:39:03 -0700 Message-ID: Subject: Re: [PATCH 1/2] libnvdimm: fix clear length of nvdimm_forget_poison() To: "Kani, Toshimitsu" Cc: "linux-kernel@vger.kernel.org" , "Jiang, Dave" , "linux-nvdimm@lists.01.org" , "Verma, Vishal L" Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1916 Lines: 49 On Fri, Apr 28, 2017 at 3:29 PM, Kani, Toshimitsu wrote: > On Fri, 2017-04-28 at 14:48 -0700, Dan Williams wrote: >> On Thu, Apr 27, 2017 at 3:57 PM, Toshi Kani >> wrote: >> > ND_CMD_CLEAR_ERROR command returns 'clear_err.cleared', the length >> > of error actually cleared, which may be smaller than its requested >> > 'len'. >> > >> > Change nvdimm_clear_poison() to call nvdimm_forget_poison() with >> > 'clear_err.cleared' when this value is valid. >> > >> > Signed-off-by: Toshi Kani >> > Cc: Dan Williams >> > Cc: Dave Jiang >> > Cc: Vishal Verma >> > --- >> > Based on 'libnvdimm-for-next'. >> > --- >> > drivers/nvdimm/bus.c | 4 +++- >> > 1 file changed, 3 insertions(+), 1 deletion(-) >> > >> > diff --git a/drivers/nvdimm/bus.c b/drivers/nvdimm/bus.c >> > index d214ac44..43ddfd4 100644 >> > --- a/drivers/nvdimm/bus.c >> > +++ b/drivers/nvdimm/bus.c >> > @@ -219,7 +219,9 @@ long nvdimm_clear_poison(struct device *dev, >> > phys_addr_t phys, >> > if (cmd_rc < 0) >> > return cmd_rc; >> > >> > - nvdimm_forget_poison(nvdimm_bus, phys, len); >> > + if (clear_err.cleared > 0) >> > + nvdimm_forget_poison(nvdimm_bus, phys, >> > clear_err.cleared); >> > + >> > return clear_err.cleared; >> >> Looks, good we need to mark this for -stable since the bug is also >> present in current mainline. >> >> Fixes: e046114af5fc ("libnvdimm: clear the internal poison_list when >> clearing badblocks") > > Shall I send a patch based on the current mainline with cc to -stable? > The func name is nvdimm_clear_from_poison_list() in the mainline. I thinks it's too late to get a fix into 4.11, especially when this went in broken and not a regression. I'll just tag this for -stable and handle the backport manually.