Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp875638ybi; Wed, 19 Jun 2019 09:18:58 -0700 (PDT) X-Google-Smtp-Source: APXvYqyZ3i0tRa32yEA7aTZq6h2Xxi0nzybx/x9LTTs5lhTzTwDdKStiUqKEk4CNAOOVRwoLLBzA X-Received: by 2002:a17:90a:ad89:: with SMTP id s9mr12168521pjq.41.1560961137929; Wed, 19 Jun 2019 09:18:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560961137; cv=none; d=google.com; s=arc-20160816; b=pThIh0RDmd+J8K7O/uf2HOnjpk5qfvhPx8qGYwR4dIfqolfp7KkYsVvsO9ZTlMCFz2 nLHZTszzLMEboyBjsQKhCs8/DtXDNt6wHO9eOb2dVXJ2Q8foRrhokTbRjYZgfYiB+Pf4 R5mrW5dPqXYQNZw4RniK3k65WxGMoYao6gKh8AOwjgulKBToWdxlVopjEBapVJ6csU0x U2qWZdBL5ZNppBM0c5Il7v3pSkDX3rTOG6aR/Gh/EcE0uwpXzhqW5icK8VU+jgxGK6Q5 1GCSvzeLks6oZVGZIL3Iz2gwIvWWXXmlbAT1Y8uiTY5WIbsIHFgaAH4FVZag+Z69jXO6 p/Dw== 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=lCQCJEjZ2r7Vh2atCQKodleIG24IppNubCiEYANYyEQ=; b=fYD1rj9CyAKYtGpPDP5tpEJ6U0CoHdvvq01SV14sNivJelU3KpxNy5T7hrktr2A0+u +0IfzxoMj5D9OJBKWsOB/tCDMGYtJwtUe1EXJ4tv9TUVBWAhLOMgtIqOIKnd/pe7G+NC 2JmEP51FlcdyOZmLDVKeQdYcJYMNBCHFmU0rmub3HagmakNY9w2wAfwtcIkLK91LEnnR DqNPMeVczNcXkiRlb8cFMi96BeYnTn+QwRqa5kOhMn34tPKYqxOv5b9BmAz9bY/Rn15Z ElgnSEmBlDVAI/Z5pQlpw113yjApWyHWpsSAKuLIeeQwlCGH1Ezl4fIwEPTj7324hUEY +V2Q== 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 d7si16177547plj.74.2019.06.19.09.18.41; Wed, 19 Jun 2019 09:18:57 -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 S1727198AbfFSQSh (ORCPT + 99 others); Wed, 19 Jun 2019 12:18:37 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:42220 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726091AbfFSQSh (ORCPT ); Wed, 19 Jun 2019 12:18:37 -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 840CE28A302; Wed, 19 Jun 2019 17:18:35 +0100 (BST) Date: Wed, 19 Jun 2019 18:18:32 +0200 From: Boris Brezillon To: Schrempf Frieder Cc: liaoweixiong , Vignesh Raghavendra , Boris Brezillon , Richard Weinberger , "linux-kernel@vger.kernel.org" , Chuanhong Guo , Marek Vasut , Frieder Schrempf , =?UTF-8?B?Q2zDqW1lbnQgUMOpcm9u?= , Miquel Raynal , "linux-mtd@lists.infradead.org" , Brian Norris , David Woodhouse , "Peter Pan" Subject: Re: [PATCH] mtd: spinand: fix error read return value Message-ID: <20190619181832.6f467279@collabora.com> In-Reply-To: <99279437-54a6-c81d-aad2-231009f18cfc@kontron.de> References: <1560950005-8868-1-git-send-email-liaoweixiong@allwinnertech.com> <20190619154611.3bfc007b@collabora.com> <99279437-54a6-c81d-aad2-231009f18cfc@kontron.de> 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 On Wed, 19 Jun 2019 14:02:14 +0000 Schrempf Frieder wrote: > On 19.06.19 15:46, Boris Brezillon wrote: > > 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. > > To me it looks like the patch description is somewhat incorrect, but the > fix itself looks okay, unless I'm getting it wrong. > > In case of the last page containing bitflips (ret > 0), > spinand_mtd_read() will return that number of bitflips for the last > page. But to me it looks like it should instead return max_bitflips like > it does when the last page read returns with 0. Oh, you're right. liaoweixiong, can you adjust the commit message accordingly? > > >> > >> 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 > > > > ______________________________________________________ > > Linux MTD discussion mailing list > > http://lists.infradead.org/mailman/listinfo/linux-mtd/ > >