From patchwork Fri Jan 10 14:45:02 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Miquel Raynal X-Patchwork-Id: 13934813 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 99DEAE77188 for ; Fri, 10 Jan 2025 14:46:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Cc:To: Content-Transfer-Encoding:Content-Type:MIME-Version:Message-Id:Date:Subject: From:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References: List-Owner; bh=92ekDe6YlWlBHOonFzgwaJbR0e0/LxWiiD0ijm0l4WQ=; b=p2SgeTgOLoppJA +U3xY8Fpkncd8i9SUMClv3HSYaMpu5xV97DkbgmqyQ+kweeioQ+wHSwqNuw5jKEauLtgTCnzJq5nK +pNkVTrXCjUT/lWqWBBJSU7fGeZu9ANBzJ0XpahxLDbDZsrDb9HooFcmMq281AuNvhF/z4V4rfYVC 5a2Qz/W1nMy9CbrPVwnpvPnI+VszYENvJjAUYQyQtwNNNdozD2/TqKIWkH3VhmuFnnRPfzvEeiO5h SEW//V9Q5dGoim867Os9HxnqoRdRsnKsgiRNYyYdnx1jkB3Cxz/odlWDxPUqj745C1gcxoap4/GzM kI/prH0g+hdryGPY7UMQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1tWGHW-0000000FgYy-0u6B; Fri, 10 Jan 2025 14:46:38 +0000 Received: from relay9-d.mail.gandi.net ([2001:4b98:dc4:8::229]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1tWGGH-0000000Fg64-2Zhv; Fri, 10 Jan 2025 14:45:23 +0000 Received: by mail.gandi.net (Postfix) with ESMTPSA id 98DE2FF804; Fri, 10 Jan 2025 14:45:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bootlin.com; s=gm1; t=1736520318; 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; bh=92ekDe6YlWlBHOonFzgwaJbR0e0/LxWiiD0ijm0l4WQ=; b=XlRf/I10DZbtPg4A7/Jls+BPFugoYIXc/IrtMbvEfXyPaWNu7rCsr0b8HD3PM92ydbnSa3 1FlAHdO67vwBDyzrbxpFD1newvRW3Abj7tQjx0X2cPylM5c43Sg0sWeBqnY2rjQlT6Naj3 PRnxLGZSuIYtWb0Ib0Pd1KWvHooAdwREykoWwqB0ZJybUe0QCSvpnlZ7QYiT38ZKTrQjsx 4IWeOojq0I2O4YMOa1qnd+bj0OLEQDBpTmIq3ihzcMMUJizZWIJvfqzwXhID9PrdKWVtnT htviikclW52dGrQMAoW6GBPtfkEwAFFWI2eMNc1yQeMJu17EtC1JKeJfod9W9g== From: Miquel Raynal Subject: [PATCH v3 00/27] spi-nand/spi-mem DTR support Date: Fri, 10 Jan 2025 15:45:02 +0100 Message-Id: <20250110-winbond-6-11-rc1-quad-support-v3-0-7ab4bd56cf6e@bootlin.com> MIME-Version: 1.0 X-B4-Tracking: v=1; b=H4sIAG4ygWcC/4XOwQ6CMAyA4VcxO1uy1kGIJ9/DeBhsSBPcYAOUE N5dwIPx5PFv0q+dRbSBbRTnwyyCHTmyd2ucjgdR1trdLbBZW5AkhYQSnuwK7wxkgAihROgGbSA ObetDDxJVTjLVhJrEarTBVvza/ett7Zpj78O0nxtxm35kSSlmmEpMVJ5muQKEB3eDbZKgJ6ebS +F937BLSv8QGzTSd5lI/XlrJJCgDWFuilLJrPr1lmV5A58VhqsJAQAA X-Change-ID: 20241210-winbond-6-11-rc1-quad-support-0148205a21a2 To: Mark Brown , Sanjay R Mehta , Serge Semin , Han Xu , Conor Dooley , Daire McNamara , Matthias Brugger , AngeloGioacchino Del Regno , Haibo Chen , Yogesh Gaur , Heiko Stuebner , Michal Simek , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra , Jacky Huang , Shan-Chun Hung , Chin-Ting Kuo , =?utf-8?q?C=C3=A9dric_Le_Goa?= =?utf-8?q?ter?= , Joel Stanley , Andrew Jeffery , Avi Fishman , Tomer Maimon , Tali Perry , Patrick Venture , Nancy Yuen , Benjamin Fair , Maxime Coquelin , Alexandre Torgue , Raju Rangoju Cc: Thomas Petazzoni , Steam Lin , linux-spi@vger.kernel.org, linux-kernel@vger.kernel.org, imx@lists.linux.dev, linux-riscv@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-mtd@lists.infradead.org, linux-aspeed@lists.ozlabs.org, openbmc@lists.ozlabs.org, linux-stm32@st-md-mailman.stormreply.com, Pratyush Yadav , Tudor Ambarus , stable+noautosel@kernel.org X-Mailer: b4 0.15-dev X-GND-Sasl: miquel.raynal@bootlin.com X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250110_064521_932109_811EF34B X-CRM114-Status: GOOD ( 21.79 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Hello Mark, hello MTD folks, Here is a (big) series supposed to bring DTR support in SPI-NAND. I could have split this into two but I eventually preferred showing the big picture. Once v1 will be over, I can make it two. However when we'll discuss merging, we'll have to share an immutable tag among the two subsystems. Here is the logic: * patches 1 & 2 add support for spi-mem operations with a specific frequency limitation. This is not only related to DTR support, because as you can see I could use this to support basic features in the Winbond driver. * patches 3-17 are going through all the easy controller drivers, where effectively supporting these per-operation limitation was easy to do. In practice, I believe all controllers can, but software is sometimes the limiting factor. All controllers without spi-mem support will gracefully handle the request (provided that they already care about the maximum speed of course), and all the updated controllers in this series will also handle the situation correctly. For the others, it's an opt-in parameter, so they will simply refuse the operation during the checks_op/supports_op() phase. * patches 18-20 add DTR support in spi-mem. * patches 21-24 add DTR support in SPI-NAND. * patches 25-27 add DTR support to Winbon chips. --- Changes in v3: - Fixed a compilation issue at patch 20 (wrong fixup! sha). - Link to v2: https://lore.kernel.org/r/20241224-winbond-6-11-rc1-quad-support-v2-0-ad218dbc406f@bootlin.com Changes in v2: - Fixed breakage reported by Mark. - Created an "adjust_op_freq" helper in the core and used it from spi_mem_exec_op(). This way it is called only once. The main parameter must still be casted otherwise we would need to do the call outside of spi_mem_exec_op() which would imply about 40 different changes in the core and drivers and also the assurance that we would get it wrong again later. - Reworked the logic for picking the best variant to include all subtleties due to maximum/supported frequencies. The choice takes slightly longer now but should return the truly fastest variant for each case. - Removed unique parenthesis in some kdoc comment. - Fixed the inconsistency when handling the maximum per operation frequencies between spi-mem and non spi-mem controllers. - Fixed many typos. - Added a core check to validate the per op frequency against the minimum supported frequencies by controller drivers. - Removed a useless check from the amd driver and turned a function void. Also used the controller parameters in this driver rather than the top-level definitions. - Clarified some of the commit logs. - Collected tags. - Prevented a patch from being picked-up automatically by the stable team. - Reordered some terms in macros in the spi-mem core. - Rebased on top of v6.13-rc1. - Link to v1: https://lore.kernel.org/r/20241025161501.485684-1-miquel.raynal@bootlin.com --- Miquel Raynal (27): spi: spi-mem: Extend spi-mem operations with a per-operation maximum frequency spi: spi-mem: Add a new controller capability spi: amd: Support per spi-mem operation frequency switches spi: amd: Drop redundant check spi: amlogic-spifc-a1: Support per spi-mem operation frequency switches spi: cadence-qspi: Support per spi-mem operation frequency switches spi: dw: Support per spi-mem operation frequency switches spi: fsl-qspi: Support per spi-mem operation frequency switches spi: microchip-core-qspi: Support per spi-mem operation frequency switches spi: mt65xx: Support per spi-mem operation frequency switches spi: mxic: Support per spi-mem operation frequency switches spi: nxp-fspi: Support per spi-mem operation frequency switches spi: rockchip-sfc: Support per spi-mem operation frequency switches spi: spi-sn-f-ospi: Support per spi-mem operation frequency switches spi: spi-ti-qspi: Support per spi-mem operation frequency switches spi: zynq-qspi: Support per spi-mem operation frequency switches spi: zynqmp-gqspi: Support per spi-mem operation frequency switches spi: spi-mem: Reorder spi-mem macro assignments spi: spi-mem: Create macros for DTR operation spi: spi-mem: Estimate the time taken by operations mtd: spinand: Create distinct fast and slow read from cache variants mtd: spinand: Add an optional frequency to read from cache macros mtd: spinand: Enhance the logic when picking a variant mtd: spinand: Add support for read DTR operations mtd: spinand: winbond: Update the *JW chip definitions mtd: spinand: winbond: Add comment about naming mtd: spinand: winbond: Add support for DTR operations drivers/mtd/nand/spi/alliancememory.c | 4 +-- drivers/mtd/nand/spi/ato.c | 4 +-- drivers/mtd/nand/spi/core.c | 15 ++++++-- drivers/mtd/nand/spi/esmt.c | 4 +-- drivers/mtd/nand/spi/foresee.c | 4 +-- drivers/mtd/nand/spi/gigadevice.c | 16 ++++----- drivers/mtd/nand/spi/macronix.c | 4 +-- drivers/mtd/nand/spi/micron.c | 8 ++--- drivers/mtd/nand/spi/paragon.c | 4 +-- drivers/mtd/nand/spi/toshiba.c | 4 +-- drivers/mtd/nand/spi/winbond.c | 27 ++++++++++++--- drivers/mtd/nand/spi/xtx.c | 4 +-- drivers/spi/spi-amd.c | 21 ++++++------ drivers/spi/spi-amlogic-spifc-a1.c | 7 +++- drivers/spi/spi-cadence-quadspi.c | 3 +- drivers/spi/spi-dw-core.c | 10 ++++-- drivers/spi/spi-fsl-qspi.c | 12 +++++-- drivers/spi/spi-mem.c | 64 +++++++++++++++++++++++++++++++++++ drivers/spi/spi-microchip-core-qspi.c | 26 +++++++++++--- drivers/spi/spi-mt65xx.c | 7 +++- drivers/spi/spi-mxic.c | 3 +- drivers/spi/spi-nxp-fspi.c | 12 +++++-- drivers/spi/spi-rockchip-sfc.c | 11 ++++-- drivers/spi/spi-sn-f-ospi.c | 8 +++-- drivers/spi/spi-ti-qspi.c | 7 +++- drivers/spi/spi-zynq-qspi.c | 13 +++++-- drivers/spi/spi-zynqmp-gqspi.c | 13 ++++--- include/linux/mtd/spinand.h | 58 ++++++++++++++++++++++++++++--- include/linux/spi/spi-mem.h | 56 +++++++++++++++++++++++++++++- 29 files changed, 349 insertions(+), 80 deletions(-) --- base-commit: 9100187b36091e5cc046d1f415f50a04ec31c25f change-id: 20241210-winbond-6-11-rc1-quad-support-0148205a21a2 Best regards,