Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp718427ybi; Wed, 19 Jun 2019 06:46:40 -0700 (PDT) X-Google-Smtp-Source: APXvYqyXd9Fb/JLzmUnUJWK3xtHXaXvd9cg+CCgJzzhNpIzLil7/MNg9CQ+RrjWort3AxLokBKrH X-Received: by 2002:a63:a46:: with SMTP id z6mr7876194pgk.76.1560952000323; Wed, 19 Jun 2019 06:46:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560952000; cv=none; d=google.com; s=arc-20160816; b=gPVid+u8/zMcJrPgYVXvSoeCiH2WRMR5tCPAPztvMtnrP0m8+XNq2z9H3GIDm0lETY 2xOPlIbmHqqjaK6qSPUkXbU+W23bZqsbMxEYwwCBh/CjxoAq/+Zp9BzIyVBn5ir2YwXH mTlt67PiEWoUqHLNwcwBa++cE6HRAiL/oLpmv0aAo7OlYqtnbgnL0XOIZSb7SubCzDnp BbUgebMeKbgDhSnE6Bwm5q2WdjN+ZyYJwYi2QtPXWv/SPuBmCRRMwCTemBDIXnP6zIk3 TYPL/elf9nax618v5EAlyzNcjZ9Qg4K4racbh+3YRSLGE/ng+oexmqlNjHj88PZoxOL4 cpxA== 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 :organization:references:in-reply-to:message-id:subject:cc:to:from :date; bh=oh4spRj7vpovbMBVgWDQyJLLBgcHekFsuzdHa1wOoZY=; b=Ild4ZoaJ093xIW5LEwjAH/cjGKACeuulAmfG1lkZIvCh+ynbNMZikqBE3R55LqZeO/ p1qPAiqV1b9F06oTqOcVj04bKCAgG3YnNn8Fn14pln1Hc2dJNFjmtBpRKq4eDoWe8qVK KK0PcJDyNUhKK7vZmfPLQPj1x5qns6qOswWldbeeieAaDQEjMKxy5vJ4t7WTB85KK8UM ZRLIh6laPlaif7JZcZmTvMLex6WxxgkEccEVhdNzMATL9ykRpwMmIELZN1/UAxh5vfpx 5fk5oZqIVF/OnraItPAl0ec2NMRnSpwh+npaWVBkrJh7ivZQWm3OXSryJA7/nTRJngIK aiYQ== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e4si1319154pjs.104.2019.06.19.06.46.23; Wed, 19 Jun 2019 06:46:40 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727069AbfFSNqQ (ORCPT + 99 others); Wed, 19 Jun 2019 09:46:16 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:41458 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726047AbfFSNqQ (ORCPT ); Wed, 19 Jun 2019 09:46:16 -0400 Received: from localhost (unknown [IPv6:2a01:e0a:2c:6930:5cf4:84a1:2763:fe0d]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) (Authenticated sender: bbrezillon) by bhuna.collabora.co.uk (Postfix) with ESMTPSA id 5CA0C260D87; Wed, 19 Jun 2019 14:46:14 +0100 (BST) Date: Wed, 19 Jun 2019 15:46:11 +0200 From: Boris Brezillon To: liaoweixiong Cc: Miquel Raynal , Richard Weinberger , David Woodhouse , Brian Norris , Marek Vasut , Vignesh Raghavendra , Boris Brezillon , Frieder Schrempf , Peter Pan , =?UTF-8?B?Q2zDqW1lbnQgUMOpcm9u?= , Chuanhong Guo , linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mtd: spinand: fix error read return value Message-ID: <20190619154611.3bfc007b@collabora.com> In-Reply-To: <1560950005-8868-1-git-send-email-liaoweixiong@allwinnertech.com> References: <1560950005-8868-1-git-send-email-liaoweixiong@allwinnertech.com> Organization: Collabora X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; x86_64-redhat-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 Hi liaoweixiong, On Wed, 19 Jun 2019 21:13:24 +0800 liaoweixiong wrote: > In function spinand_mtd_read, if the last page to read occurs bitflip, > this function will return error value because veriable ret not equal to 0. Actually, that's exactly what the MTD core expects (see [1]), so you're the one introducing a regression here. Regards, Boris > > Signed-off-by: liaoweixiong > --- > drivers/mtd/nand/spi/core.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/mtd/nand/spi/core.c b/drivers/mtd/nand/spi/core.c > index 556bfdb..6b9388d 100644 > --- a/drivers/mtd/nand/spi/core.c > +++ b/drivers/mtd/nand/spi/core.c > @@ -511,12 +511,12 @@ static int spinand_mtd_read(struct mtd_info *mtd, loff_t from, > if (ret == -EBADMSG) { > ecc_failed = true; > mtd->ecc_stats.failed++; > - ret = 0; > } else { > mtd->ecc_stats.corrected += ret; > max_bitflips = max_t(unsigned int, max_bitflips, ret); > } > > + ret = 0; > ops->retlen += iter.req.datalen; > ops->oobretlen += iter.req.ooblen; > } [1]https://elixir.bootlin.com/linux/latest/source/drivers/mtd/mtdcore.c#L1209