Received: by 2002:a25:d956:0:0:0:0:0 with SMTP id q83csp4152234ybg; Mon, 4 May 2020 14:47:51 -0700 (PDT) X-Google-Smtp-Source: APiQypIYIFyrrB/P5Tjmao3+8i+iK9oPQIrOpePUZhUsgmZvqTZZ1Xi61zRqT5HwIeqqu8OnOUbo X-Received: by 2002:a05:6402:120a:: with SMTP id c10mr78395edw.15.1588628871196; Mon, 04 May 2020 14:47:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588628871; cv=none; d=google.com; s=arc-20160816; b=nRIL08fUlS/TR4ooER52fOf1ck5e8ZINKIQ5FtAQdMHw7sHgGZydpL7XzNHPlKGuZp Ik5B1rk+QVB2zaJNK3RH+sv2F/2vUlwbh2d+sDgrr9FSvoao/SGcLsFfV7dZK9+1VbJQ 2mpyfjpfIltxZIrQcD8/Y4bwyipapekL6Anb1Kz/MIyZeNqT9cuAYH9uij7Dqpi2GCnm PKJlirrhInba7xBVjk8Jh78J18J0bSfH/i3YZca/wUItC1RqfqoCySBkZSeqwkdMcPl0 uFaq5kJP5chrdnyoxUSYGhR4Uih7GiLf8Oo/4B29x1q95fNVmrOfoHweAvb+XzZhmJw4 /7YQ== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:to:subject:dkim-signature; bh=bnAoXlE6naZXplH2LBElomP8n2q8fSlbfgAhYHfgt5s=; b=aO9AlwIqHaVj6ZJtxA9VaJDuBO4Ii0npdPbhkroCEQ7Ws4Ox04DRZ0DHtS/vgnereH W00DnM2Ui/fsk3G3S3pcH+tE+BIhWVXy2oYT2vP7TkaXpQlewBpLAFuXaGQjtJO6L2U9 lYWUoyI85ALjkuVjudiHVLRoVK8k4W71t32sQHaYI/QOmB+6bIeql687Vv6v8Lmojauz BDOuvpz66fol2xGYVylyIoTvVwweyTyIYC64Xf09AcquEbhGinXiCGHZac3wcJ+C8e9Y sC9La3u6pADp8jEqUvrfw/kCXN31g/PthvHwzYxwaa/ymsG204puS46+/8IbmdxR1vkH ehdQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Xvklki9I; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u11si129954edd.15.2020.05.04.14.47.26; Mon, 04 May 2020 14:47:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Xvklki9I; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728090AbgEDVnr (ORCPT + 99 others); Mon, 4 May 2020 17:43:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35494 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1726338AbgEDVnr (ORCPT ); Mon, 4 May 2020 17:43:47 -0400 Received: from mail-pl1-x641.google.com (mail-pl1-x641.google.com [IPv6:2607:f8b0:4864:20::641]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EC6B9C061A0E; Mon, 4 May 2020 14:43:45 -0700 (PDT) Received: by mail-pl1-x641.google.com with SMTP id f15so334805plr.3; Mon, 04 May 2020 14:43:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:references:from:message-id:date:user-agent:mime-version :in-reply-to:content-language:content-transfer-encoding; bh=bnAoXlE6naZXplH2LBElomP8n2q8fSlbfgAhYHfgt5s=; b=Xvklki9IQXKduwRuB61lYr5L7UeuVOeXXXrkX5wDjDsAsfcntdW37APtcUDnKjKhJQ WmOMHiPHAqFkCBadXH9VpgorfXKBgRC0zQZmDQwWEf5jjAq+8sw35TJd4O56nuC0k703 NTgDizKysiTachoo/YlCwUkehsDeXiXfNjF4M7lF3SMYeAXACAwwZDDZQDSolHZ/7d6O 79oHEf56eWYXRDOiQhteVbDsYiVu/7aMBQ8d1xe0YvOF9JKSUHXk+CT5dtJBcWQwdHPB Q+P888yZAB+7VPuN5NfWeILJtWbjJy9OZJSYmM80DQXMbQz1NklywNzhP6xiAxtWL0l/ 5ejg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=bnAoXlE6naZXplH2LBElomP8n2q8fSlbfgAhYHfgt5s=; b=ZQoN5MsBqVuf+t8jnY9aiehyD/4zuQoSk35q4qHvyB6SbWkyjIJlo8QYFvfIketMrE i6QQCKZaEV9J+i5+z+qXdL4KoPsnKnTnhTQ5UTGyQjcQ6uDGBiYRetCzWu0wLsUD6gRX u394P7Fhj8YiwleSngoqNimOAbEPo/jqn2kdj2sVhp8Cl3uR2+46j+dW3hQKmW02XCZF kEprea2oQGncfNYJPlcJ3Bw0MXsFQkdomZ9lsNmueDGg5L5/TYfAnGXiG2vw08QHOunY yV8tP4jmb5vJkk8LivNvtyXi1U0i1740lBybiwgyuwZ8VOyz6sQCGu2t5xFXZEcwyMEf 9CRg== X-Gm-Message-State: AGi0PubI5T+MQOcD14Glf41OXVKw7/HlGjdAl8JMKuTfkyufVoidSUOj /5WVQg5w8nPcofBjdkjQrTc= X-Received: by 2002:a17:90a:2b46:: with SMTP id y6mr207238pjc.154.1588628625309; Mon, 04 May 2020 14:43:45 -0700 (PDT) Received: from [10.230.188.43] ([192.19.223.252]) by smtp.gmail.com with ESMTPSA id a142sm52764pfa.6.2020.05.04.14.43.43 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 04 May 2020 14:43:44 -0700 (PDT) Subject: Re: [PATCH] nand: brcmnand: correctly verify erased pages To: =?UTF-8?Q?=c3=81lvaro_Fern=c3=a1ndez_Rojas?= , computersforpeace@gmail.com, kdasu.kdev@gmail.com, miquel.raynal@bootlin.com, richard@nod.at, vigneshr@ti.com, sumit.semwal@linaro.org, linux-mtd@lists.infradead.org, bcm-kernel-feedback-list@broadcom.com, linux-kernel@vger.kernel.org, linux-media@vger.kernel.org, dri-devel@lists.freedesktop.org, linaro-mm-sig@lists.linaro.org References: <20200504092943.2739784-1-noltari@gmail.com> From: Florian Fainelli Message-ID: <2fea8057-8b84-790e-60ba-b6848a186e18@gmail.com> Date: Mon, 4 May 2020 14:43:42 -0700 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Firefox/68.0 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <20200504092943.2739784-1-noltari@gmail.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 5/4/2020 2:29 AM, Álvaro Fernández Rojas wrote: > The current code checks that the whole OOB area is erased. > This is a problem when JFFS2 cleanmarkers are added to the OOB, since it will > fail due to the usable OOB bytes not being 0xff. > Correct this by only checking that the ECC aren't 0xff. > > Signed-off-by: Álvaro Fernández Rojas Can you provide a Fixes: tag for this change? > --- > drivers/mtd/nand/raw/brcmnand/brcmnand.c | 22 ++++++++++++++++++---- > 1 file changed, 18 insertions(+), 4 deletions(-) > > diff --git a/drivers/mtd/nand/raw/brcmnand/brcmnand.c b/drivers/mtd/nand/raw/brcmnand/brcmnand.c > index e4e3ceeac38f..546f0807b887 100644 > --- a/drivers/mtd/nand/raw/brcmnand/brcmnand.c > +++ b/drivers/mtd/nand/raw/brcmnand/brcmnand.c > @@ -2018,6 +2018,7 @@ static int brcmnand_read_by_pio(struct mtd_info *mtd, struct nand_chip *chip, > static int brcmstb_nand_verify_erased_page(struct mtd_info *mtd, > struct nand_chip *chip, void *buf, u64 addr) > { > + struct mtd_oob_region oobecc; > int i, sas; > void *oob = chip->oob_poi; > int bitflips = 0; > @@ -2035,11 +2036,24 @@ static int brcmstb_nand_verify_erased_page(struct mtd_info *mtd, > if (ret) > return ret; > > - for (i = 0; i < chip->ecc.steps; i++, oob += sas) { > + for (i = 0; i < chip->ecc.steps; i++) { > ecc_chunk = buf + chip->ecc.size * i; > - ret = nand_check_erased_ecc_chunk(ecc_chunk, > - chip->ecc.size, > - oob, sas, NULL, 0, > + > + ret = nand_check_erased_ecc_chunk(ecc_chunk, chip->ecc.size, > + NULL, 0, NULL, 0, > + chip->ecc.strength); > + if (ret < 0) > + return ret; > + > + bitflips = max(bitflips, ret); > + } > + > + for (i = 0; mtd->ooblayout->ecc(mtd, i, &oobecc) != -ERANGE; i++) > + { > + ret = nand_check_erased_ecc_chunk(NULL, 0, > + oob + oobecc.offset, > + oobecc.length, > + NULL, 0, > chip->ecc.strength); > if (ret < 0) > return ret; > -- Florian