From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932248AbbHNKIn (ORCPT ); Fri, 14 Aug 2015 06:08:43 -0400 Received: from mail-lb0-f182.google.com ([209.85.217.182]:36442 "EHLO mail-lb0-f182.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752744AbbHNKIm (ORCPT ); Fri, 14 Aug 2015 06:08:42 -0400 MIME-Version: 1.0 In-Reply-To: References: <1592668a061137b33c9a6392dfccc67c69fc1fe6.1439543572.git.hramrach@gmail.com> From: Michal Suchanek Date: Fri, 14 Aug 2015 12:08:00 +0200 Message-ID: Subject: Re: [PATCH v4 7/7] mtd: spi-nor: add read loop To: Andrew Murray Cc: Hou Zhiqiang , Huang Shijie , David Woodhouse , Brian Norris , Han Xu , =?UTF-8?B?UmFmYcWCIE1pxYJlY2tp?= , Huang Shijie , Ben Hutchings , Marek Vasut , Gabor Juhos , =?UTF-8?B?QmVhbiBIdW8g6ZyN5paM5paMLA==?= , MTD Maling List , LKML Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 14 August 2015 at 12:02, Andrew Murray wrote: > On 14 August 2015 at 10:23, Michal Suchanek wrote: >> mtdblock and ubi do not handle the situation when read returns less data >> than requested. Loop in spi-nor until buffer is filled or an error is >> returned. >> >> Signed-off-by: Michal Suchanek >> --- >> drivers/mtd/spi-nor/spi-nor.c | 20 ++++++++++++++------ >> 1 file changed, 14 insertions(+), 6 deletions(-) >> >> diff --git a/drivers/mtd/spi-nor/spi-nor.c b/drivers/mtd/spi-nor/spi-nor.c >> index e0ae9cf..246fac7 100644 >> --- a/drivers/mtd/spi-nor/spi-nor.c >> +++ b/drivers/mtd/spi-nor/spi-nor.c >> @@ -738,14 +738,22 @@ static int spi_nor_read(struct mtd_info *mtd, loff_t from, size_t len, >> if (ret) >> return ret; >> >> - ret = nor->read(nor, from, len, buf); >> + while (len) { >> + ret = nor->read(nor, from, len, buf); >> + if (ret <= 0) >> + goto read_err; >> + >> + BUG_ON(ret > len); >> + *retlen += ret; > > Is *retlen initialized to 0 anywhere? It's initialized in mtdcore and passed into mtd->_read. Yes, the interface is really awkward. int mtd_read(struct mtd_info *mtd, loff_t from, size_t len, size_t *retlen, u_char *buf) { int ret_code; *retlen = 0; Thanks Michal