Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp2742649rdh; Wed, 27 Sep 2023 11:13:16 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGTzEOC8YfZ4eQw02KC3nQhQtJCYqCXymIWAiya2ucgSKfA8CcarGSSg6t7FSjDUwfGCFii X-Received: by 2002:a05:6a20:430b:b0:159:b7dc:2295 with SMTP id h11-20020a056a20430b00b00159b7dc2295mr3188530pzk.9.1695838396339; Wed, 27 Sep 2023 11:13:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695838396; cv=none; d=google.com; s=arc-20160816; b=OaEKjbmtUL8VntBrkNMPcFdM6jh6y4BkaUazbWs2njF6lFstILt/b13d0Oqjqjl/kS OwYlLzJly0iQMz7sQ5srgqJeU/jnz63TyykHiKWJt+R0HFlbv3s9W5AO51NDmrjMH5Vk G+6TMvxHfcYpmX23Jy1g65WfmaCly1zmiFRl4OjqmmDBtTCDJ9QdbM4SVnYHCcNMh+XH AyTRVXzv2tc2qPO1lJVLGsRwHIzXNYJhpPcI/M6SjhqhOu1A4d6NcJKNxJepwABAfty9 0zfDa0kIGiHCzF02XJ26zIDPg53HjemMJd9W+Qlxw/bqU63OaNgIYDxJK8f90OuzvZVR 1m3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :organization:references:in-reply-to:message-id:subject:cc:to:from :date:dkim-signature; bh=XvGJ1llNHjkHCILvhbGiSOqMABBQxPcSPXl/6R2W8Uw=; fh=/Evfvjd51D7N4wk1kLCQZV6uGRMwgnxPeU369W+vvEw=; b=G9S+PkmbajxmtrXUs7ufzRz95EQaWxM2BXGDiGSYVWc9XTtbvTdxPHXEj72P9LW2Vn ezGjQ7MDIgnNz+7rDYCEr/HWuHpLrzgjCifB1S2g8glNVtCDNG9htEAxJJBwTJuS1xG0 dJdV/oh6bhAYiWINnwOHS9zkYxjp5uLvollygfBsUMhTDvJLvAJyfZNmgjrTpQWNiuf3 YnMHVszXZbnedYxGNVr4D7wQmiP4hHvPCBQS7QdbTl3MahwSOY5xdRkCaLn6hNEO9jrd v3oSNF/eLqJUoBOVpZj7+sizgfOcWqJZEJKgJdE4xGpi/8HFQSE9pqHI0LcMyg0SGpfB tQNQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b=MdhlMbNI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Return-Path: Received: from pete.vger.email (pete.vger.email. [23.128.96.36]) by mx.google.com with ESMTPS id q26-20020a631f5a000000b005644a9be955si16513913pgm.179.2023.09.27.11.13.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 27 Sep 2023 11:13:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) client-ip=23.128.96.36; Authentication-Results: mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b=MdhlMbNI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id 3ADBB808987E; Wed, 27 Sep 2023 08:05:44 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232294AbjI0PF1 (ORCPT + 99 others); Wed, 27 Sep 2023 11:05:27 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53982 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232246AbjI0PF0 (ORCPT ); Wed, 27 Sep 2023 11:05:26 -0400 Received: from relay2-d.mail.gandi.net (relay2-d.mail.gandi.net [217.70.183.194]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8A0E8F5; Wed, 27 Sep 2023 08:05:23 -0700 (PDT) Received: by mail.gandi.net (Postfix) with ESMTPSA id A52D440002; Wed, 27 Sep 2023 15:05:18 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bootlin.com; s=gm1; t=1695827122; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=XvGJ1llNHjkHCILvhbGiSOqMABBQxPcSPXl/6R2W8Uw=; b=MdhlMbNIJPu1sSSE2pShuMwiPsReYRhd8tLNMKs+5ZfUl4ijWtPbgiP9dHwdzFYyDjbPbd /fHKTBqqqUqGiIZ+nCO5hmSQbmCVMxSwDaZs5cFwLiYWswxrc9BvPp7lvMmox/MeR2H4GR G0Z7IYFLuNiMwGuBpp0wGAqHSHRvN5eiHCEWa9S8TftuXPoTlZjzult2E5pkNUqQos5EvE eogStBIAgYm/3b/Vfdlz5NVPGOOcbktFH6LXB3FxhFnJuesbCEdDktUwzFJl4x+9SQiXnL Vu0fciKwAztEJHxVFQzZJ43EKdpiz1hvXfH2Uk+ggFgDjS6Tgf+8NntoeXqiEw== Date: Wed, 27 Sep 2023 17:05:16 +0200 From: Miquel Raynal To: Martin =?UTF-8?B?SHVuZGViw7hsbA==?= Cc: Rouven Czerwinski , =?UTF-8?B?TcOlbnMg?= =?UTF-8?B?UnVsbGfDpXJk?= , Alexander Shiyan , Richard Weinberger , Vignesh Raghavendra , JaimeLiao , kernel@pengutronix.de, stable@vger.kernel.org, linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org, Sean =?UTF-8?B?Tnlla2rDpnI=?= , Domenico Punzo , Bean Huo Subject: Re: [PATCH v2] mtd: rawnand: Ensure the nand chip supports cached reads Message-ID: <20230927170516.2604e8f2@xps-13> In-Reply-To: <20230926132725.5d570e1b@xps-13> References: <20230922141717.35977-1-r.czerwinski@pengutronix.de> <20230926132725.5d570e1b@xps-13> Organization: Bootlin X-Mailer: Claws Mail 4.0.0 (GTK+ 3.24.33; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable X-GND-Sasl: miquel.raynal@bootlin.com X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (pete.vger.email [0.0.0.0]); Wed, 27 Sep 2023 08:05:44 -0700 (PDT) Hi Martin, miquel.raynal@bootlin.com wrote on Tue, 26 Sep 2023 13:27:25 +0200: > Hi Martin, >=20 > + Bean and Domenico, there is a question for you below. >=20 > martin@geanix.com wrote on Mon, 25 Sep 2023 13:01:06 +0200: >=20 > > Hi Rouven, > >=20 > > On Fri, 2023-09-22 at 16:17 +0200, Rouven Czerwinski wrote: =20 > > > Both the JEDEC and ONFI specification say that read cache sequential > > > support is an optional command. This means that we not only need to > > > check whether the individual controller supports the command, we also > > > need to check the parameter pages for both ONFI and JEDEC NAND > > > flashes > > > before enabling sequential cache reads. > > >=20 > > > This fixes support for NAND flashes which don't support enabling > > > cache > > > reads, i.e. Samsung K9F4G08U0F or Toshiba TC58NVG0S3HTA00. > > >=20 > > > Sequential cache reads are now only available for ONFI and JEDEC > > > devices, if individual vendors implement this, it needs to be enabled > > > per vendor. > > >=20 > > > Tested on i.MX6Q with a Samsung NAND flash chip that doesn't support > > > sequential reads. > > >=20 > > > Fixes: 003fe4b9545b ("mtd: rawnand: Support for sequential cache > > > reads") > > > Cc: stable@vger.kernel.org > > > Signed-off-by: Rouven Czerwinski =20 > >=20 > > Thanks for this. It works as expected for my Toshiba chip, obviously > > because it doesn't use ONFI or JEDEC. > >=20 > > Unfortunately, my Micron chip does use ONFI, and it sets the cached- > > read-supported bit. It then fails when reading afterwords: I might have over reacted regarding my findings in Micron's datasheet, I need to know if you use the on-die ECC engine or if you use the one on the controller. In the former case the failure is expected. In the latter case, it's not. Thanks, Miqu=C3=A8l > > kernel: ONFI_OPT_CMD_READ_CACHE # debug added by me > > kernel: nand: device found, Manufacturer ID: 0x2c, Chip ID: 0xdc > > kernel: nand: Micron MT29F4G08ABAFAWP > > kernel: nand: 512 MiB, SLC, erase size: 256 KiB, page size: 4096, OOB > > size: 256 > > kernel: nand: continued read supported # debug added by me > > kernel: Bad block table found at page 131008, version 0x01 > > kernel: Bad block table found at page 130944, version 0x01 > > kernel: 2 fixed-partitions partitions found on MTD device gpmi-nand > > kernel: Creating 2 MTD partitions on "gpmi-nand": > > kernel: 0x000000000000-0x000000800000 : "boot" > > kernel: 0x000000800000-0x000020000000 : "ubi" > > kernel: gpmi-nand 1806000.nand-controller: driver registered. > >=20 > > ... > >=20 > > kernel: ubi0: default fastmap pool size: 100 > > kernel: ubi0: default fastmap WL pool size: 50 > > kernel: ubi0: attaching mtd1 > > kernel: ubi0: scanning is finished > > kernel: ubi0: attached mtd1 (name "ubi", size 504 MiB) > > kernel: ubi0: PEB size: 262144 bytes (256 KiB), LEB size: 253952 bytes > > kernel: ubi0: min./max. I/O unit sizes: 4096/4096, sub-page size 4096 > > kernel: ubi0: VID header offset: 4096 (aligned 4096), data offset: 8192 > > kernel: ubi0: good PEBs: 2012, bad PEBs: 4, corrupted PEBs: 0 > > kernel: ubi0: user volume: 9, internal volumes: 1, max. volumes count: > > 128 > > kernel: ubi0: max/mean erase counter: 4/2, WL threshold: 4096, image > > sequence number: 1431497221 > > kernel: ubi0: available PEBs: 12, total reserved PEBs: 2000, PEBs > > reserved for bad PEB handling: 36 > > kernel: block ubiblock0_4: created from ubi0:4(rootfs.a) > > kernel: ubi0: background thread "ubi_bgt0d" started, PID 36 > > kernel: block ubiblock0_6: created from ubi0:6(appfs.a) > > kernel: block ubiblock0_7: created from ubi0:7(appfs.b) > >=20 > > ... > >=20 > > kernel: SQUASHFS error: Unable to read directory block [4b6d15c:ed1] > > kernel: SQUASHFS error: Unable to read directory block [4b6f15e:125] > > kernel: SQUASHFS error: Unable to read directory block [4b6d15c:1dae] > > kernel: SQUASHFS error: Unable to read directory block [4b6d15c:ed1] > > (d-sysctl)[55]: systemd-sysctl.service: Failed to set up credentials: > > Protocol error > > kernel: SQUASHFS error: Unable to read directory block [4b73162:14f0] > > kernel: SQUASHFS error: Unable to read directory block [4b6f15e:838] > > systemd[1]: Starting Create Static Device Nodes in /dev... > > kernel: SQUASHFS error: Unable to read directory block [4b6d15c:ed1] > > kernel: SQUASHFS error: Unable to read directory block [4b6d15c:ed1] > > kernel: SQUASHFS error: Unable to read directory block [4b6f15e:838] > > kernel: SQUASHFS error: Unable to read directory block [4b6d15c:1dae] > > kernel: SQUASHFS error: Unable to read directory block [4b6f15e:125] > >=20 > > I've briefly tried adding some error info the the squashfs error > > messages, but it looks like it's getting bad data. I.e. one failure a > > sanity check of `dir_count`: > >=20 > > if (dir_count > SQUASHFS_DIR_COUNT) > > goto data_error; > >=20 > > It fails with `dir_count` being 1952803684 ... > >=20 > > So is this a case of wrong/bad timings? > >=20 > > Miquel: > > I can tell from the code, that the READCACHESEQ operations are followed > > by NAND_OP_WAIT_RDY(tR_max, tRR_min). From the Micron datasheet[0], it > > should be NAND_OP_WAIT_RDY(tRCBSY_max, tRR_min), where tRCBSY is > > defined to be between 3 and 25 =C2=B5s. =20 >=20 > I found a place in the ONFI spec states taht tRCBSY_max should be > between 3 and tR_max, so indeed we should be fine on that regard. >=20 > However, I asked myself whether we could have issues when crossing > boundaries. Block boundaries should be fine, however your device does > not support crossing plane boundaries, as bit 4 ("read cache > supported") of byte 114 ("Multi-plane operation attributes") in the > memory organization block of the parameter page is not set (the value > of the byte should be 0x0E if I get it right. >=20 > Anyway, our main issue here does not seem related to the boundaries. It > does not seem to be explicitly marked anywhere else but on the front > page: > Advanced command set > =E2=80=93 Program page cache mode (4) > =E2=80=93 Read page cache mode (4) > =E2=80=93 Two-plane commands (4) >=20 > (4) These commands supported only with ECC disabled. >=20 > Read page cache mode without ECC makes the feature pretty useless IMHO. >=20 > Bean, Domenico, how do we know which devices allow ECC correction > during sequential page reads and which don't? Is there a (vendor?) bit > somewhere in the parameter page for that? Do we have any way to know > besides a list of devices allowing that? If so, can you provide one > with a few IDs?=20 >=20 > Thanks, > Miqu=C3=A8l