Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp739142rwl; Wed, 12 Apr 2023 03:30:49 -0700 (PDT) X-Google-Smtp-Source: AKy350Zob2sdZDZWGcWDKvGQ3cYp1YDiVZsc845BVi594xCJDD9H7YqM3IUfD/ocAs/hEs7xyRDu X-Received: by 2002:a05:6a20:1b11:b0:db:4fae:ad15 with SMTP id ch17-20020a056a201b1100b000db4faead15mr17496848pzb.42.1681295449081; Wed, 12 Apr 2023 03:30:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681295449; cv=none; d=google.com; s=arc-20160816; b=ZW/LpEeW1LgN8mMmVZ2H5LcQr9+xrs4JLZVwMdhWbogDoIxszOf55zAYRvIXUM3ndR WOBr5+RXoVwYwRKROZrvEiU202SG3VZW0yJWoWs/FqJBMOKr0eOXdGke9AY/LgHmJCbQ +e7xGQpChWLa91Rgjp+Ynr9Hl2VGAOQ+0uVu/X71ZBkyASPq8iZaaN6vawTWKZXNSgM3 hGmYG+lX23+BOhV2RHpTq2t7JaezTg5Kztl/kqkxgMtrjvncDj7aSkmqq32fbjzAbp2Y DfShEFCmPk/nnIUwYiWV3V4HFmvVvJ/G+WL+B0AD1FD8jSxfvRw24/1hDsNoNcNBbPI7 F+lQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=PP2Y/Il+dezNqPtLgzxWk2KfTtgfTZFcl/FVi9Ukg8I=; b=obSvhRL2FX4qFk0B29z+eNhJ4kzMsNenDtBxyrn434wHpjXJc44sJLxQg68ICZm3vP Wydt3sJtEhOczQffi6276C4//CrIQ1cI6EX/EhVMXY2BhROxLD2n6lvGrAl6Tz4+Q/tg 00BmDshiLlgl0gtjafV3QAgD+QWy5F2EJYQuG1k69WYHbfTfuwFM3Tefd0uLKx96bijp C0i1LsBYljOBJvkoxUtDd0QfqlzI0Ktu3WmBe2YMZkgW6kD/1439S4oSaAFRhCP7E3LL A5ic56kfB/E8EWtCrenAo/G97FKoKI3GsVPWa2hvTuXEkrtmrvq6J42poqYVlj47qlNt dIHA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sberdevices.ru header.s=mail header.b=JUawYNHO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=sberdevices.ru Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id j13-20020a63cf0d000000b0051827ed9c1asi11194902pgg.483.2023.04.12.03.30.37; Wed, 12 Apr 2023 03:30:49 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@sberdevices.ru header.s=mail header.b=JUawYNHO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=sberdevices.ru Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229848AbjDLKSq (ORCPT + 99 others); Wed, 12 Apr 2023 06:18:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34044 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229508AbjDLKSo (ORCPT ); Wed, 12 Apr 2023 06:18:44 -0400 Received: from mx.sberdevices.ru (mx.sberdevices.ru [45.89.227.171]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 35856558B for ; Wed, 12 Apr 2023 03:18:42 -0700 (PDT) Received: from s-lin-edge02.sberdevices.ru (localhost [127.0.0.1]) by mx.sberdevices.ru (Postfix) with ESMTP id 8A4095FD61; Wed, 12 Apr 2023 13:18:40 +0300 (MSK) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sberdevices.ru; s=mail; t=1681294720; bh=PP2Y/Il+dezNqPtLgzxWk2KfTtgfTZFcl/FVi9Ukg8I=; h=Message-ID:Date:MIME-Version:Subject:To:From:Content-Type; b=JUawYNHO0kedtMwE4ATrHSnma36lVIFO0H414zIv4o1agtnn6VjqYcrXlLhrC31ZF AU0ra4RbFNMyGaW9Va7ofCBLYdHCSFJOF+H4SR3v2uDjqG3XtU8VMWPrGunpQx+ptl JyrD7XWF2uRHagy/0pYmOdVpG8QaPPmrHYZr9+u4VnWquyktm2eCB1JUqDlz13ZdeA n9RUcm9Y43iSbFGsWrEU8JIqiL+XWiKNPWSeiI5kPhfvogXEsBLI9bA/R24C2U/jI5 ZAsyKiUxrZLN5ehbY9GrNLMkcSc3iWHA6HOBCk6TtZE0Otylo2eAgfPOU56Mb8qyAp VPsNm0MB+xaRQ== Received: from S-MS-EXCH01.sberdevices.ru (S-MS-EXCH01.sberdevices.ru [172.16.1.4]) by mx.sberdevices.ru (Postfix) with ESMTP; Wed, 12 Apr 2023 13:18:40 +0300 (MSK) Message-ID: <4eace0a0-f6af-7d99-a52f-7913a2139330@sberdevices.ru> Date: Wed, 12 Apr 2023 13:14:52 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.7.1 Subject: Re: [PATCH v1 4/5] mtd: rawnand: meson: clear OOB buffer before read Content-Language: en-US To: Miquel Raynal CC: Liang Yang , Richard Weinberger , Vignesh Raghavendra , Neil Armstrong , Kevin Hilman , Jerome Brunet , Martin Blumenstingl , Jianxin Pan , Yixun Lan , , , , , , References: <20230412061700.1492474-1-AVKrasnov@sberdevices.ru> <20230412061700.1492474-5-AVKrasnov@sberdevices.ru> <20230412094400.3c82f631@xps-13> <20230412113654.183350d0@xps-13> From: Arseniy Krasnov In-Reply-To: <20230412113654.183350d0@xps-13> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8bit X-Originating-IP: [172.16.1.6] X-ClientProxiedBy: S-MS-EXCH02.sberdevices.ru (172.16.1.5) To S-MS-EXCH01.sberdevices.ru (172.16.1.4) X-KSMG-Rule-ID: 4 X-KSMG-Message-Action: clean X-KSMG-AntiSpam-Status: not scanned, disabled by settings X-KSMG-AntiSpam-Interceptor-Info: not scanned X-KSMG-AntiPhishing: not scanned, disabled by settings X-KSMG-AntiVirus: Kaspersky Secure Mail Gateway, version 1.1.2.30, bases: 2023/04/12 04:12:00 #21090163 X-KSMG-AntiVirus-Status: Clean, skipped X-Spam-Status: No, score=-3.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,SPF_HELO_NONE, SPF_PASS,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 12.04.2023 12:36, Miquel Raynal wrote: > Hi Arseniy, > > avkrasnov@sberdevices.ru wrote on Wed, 12 Apr 2023 12:20:55 +0300: > >> On 12.04.2023 10:44, Miquel Raynal wrote: >>> Hi Arseniy, >>> >>> AVKrasnov@sberdevices.ru wrote on Wed, 12 Apr 2023 09:16:58 +0300: >>> >>>> This NAND reads only few user's bytes in ECC mode (not full OOB), so >>> >>> "This NAND reads" does not look right, do you mean "Subpage reads do >>> not retrieve all the OOB bytes,"? >>> >>>> fill OOB buffer with zeroes to not return garbage from previous reads >>>> to user. >>>> Otherwise 'nanddump' utility prints something like this for just erased >>>> page: >>>> >>>> ... >>>> 0x000007f0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff >>>> OOB Data: ff ff ff ff 00 00 ff ff 80 cf 22 99 cb ad d3 be >>>> OOB Data: 63 27 ae 06 16 0a 2f eb bb dd 46 74 41 8e 88 6e >>>> OOB Data: 38 a1 2d e6 77 d4 05 06 f2 a5 7e 25 eb 34 7c ff >>>> OOB Data: 38 ea de 14 10 de 9b 40 33 16 6a cc 9d aa 2f 5e >>>> >>>> Signed-off-by: Arseniy Krasnov >>>> --- >>>> drivers/mtd/nand/raw/meson_nand.c | 5 +++++ >>>> 1 file changed, 5 insertions(+) >>>> >>>> diff --git a/drivers/mtd/nand/raw/meson_nand.c b/drivers/mtd/nand/raw/meson_nand.c >>>> index f84a10238e4d..f2f2472cb511 100644 >>>> --- a/drivers/mtd/nand/raw/meson_nand.c >>>> +++ b/drivers/mtd/nand/raw/meson_nand.c >>>> @@ -858,9 +858,12 @@ static int meson_nfc_read_page_sub(struct nand_chip *nand, >>>> static int meson_nfc_read_page_raw(struct nand_chip *nand, u8 *buf, >>>> int oob_required, int page) >>>> { >>>> + struct mtd_info *mtd = nand_to_mtd(nand); >>>> u8 *oob_buf = nand->oob_poi; >>>> int ret; >>>> >>>> + memset(oob_buf, 0, mtd->oobsize); >>> >>> I'm surprised raw reads do not read the entire OOB? >> >> Yes! Seems in case of raw access (what i see in this driver) number of OOB bytes read >> still depends on ECC parameters: for each portion of data covered with ECC code we can >> read it's ECC code and "user bytes" from OOB - it is what i see by dumping DMA buffer by >> printk(). For example I'm working with 2K NAND pages, each page has 2 x 1K ECC blocks. >> For each ECC block I have 16 OOB bytes which I can access by read/write. Each 16 bytes >> contains 2 bytes of user's data and 14 bytes ECC codes. So when I read page in raw mode >> controller returns 32 bytes (2 x (2 + 14)) of OOB. While OOB is reported as 64 bytes. > > In all modes, when you read OOB, you should get the full OOB. The fact > that ECC correction is enabled or disabled does not matter. If the NAND > features OOB sections of 64 bytes, you should get the 64 bytes. > > What happens sometimes, is that some of the bytes are not protected > against bitflips, but the policy is to return the full buffer. Ok, so to clarify case for this NAND controller: 1) In both ECC and raw modes i need to return the same raw OOB data (e.g. user bytes + ECC codes)? 2) If I have access to only 32 bytes of OOB (in case above), I must report that size of OOB is only 32 bytes during initialization? Thanks, Arseniy > >> >> Thanks, Arseniy >> >>> >>>> + >>>> ret = meson_nfc_read_page_sub(nand, page, 1); >>>> if (ret) >>>> return ret; >>>> @@ -881,6 +884,8 @@ static int meson_nfc_read_page_hwecc(struct nand_chip *nand, u8 *buf, >>>> u8 *oob_buf = nand->oob_poi; >>>> int ret, i; >>>> >>>> + memset(oob_buf, 0, mtd->oobsize); >>>> + >>>> ret = meson_nfc_read_page_sub(nand, page, 0); >>>> if (ret) >>>> return ret; >>> >>> >>> Thanks, >>> Miquèl > > > Thanks, > Miquèl