From patchwork Thu Oct 1 20:20:30 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Pratyush Yadav X-Patchwork-Id: 1375426 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=none (no SPF record) smtp.mailfrom=lists.infradead.org (client-ip=2001:8b0:10b:1231::1; helo=merlin.infradead.org; envelope-from=linux-mtd-bounces+incoming=patchwork.ozlabs.org@lists.infradead.org; receiver=) Authentication-Results: ozlabs.org; dmarc=fail (p=quarantine dis=none) header.from=ti.com Authentication-Results: ozlabs.org; dkim=pass (2048-bit key; secure) header.d=lists.infradead.org header.i=@lists.infradead.org header.a=rsa-sha256 header.s=merlin.20170209 header.b=CqfReq7V; dkim=fail reason="signature verification failed" (1024-bit key; unprotected) header.d=ti.com header.i=@ti.com header.a=rsa-sha256 header.s=ti-com-17Q1 header.b=O4RX3MoX; dkim-atps=neutral Received: from merlin.infradead.org (merlin.infradead.org [IPv6:2001:8b0:10b:1231::1]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 4C2Pfm3Cv2z9sVN for ; Fri, 2 Oct 2020 06:21:52 +1000 (AEST) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=merlin.20170209; h=Sender:Content-Transfer-Encoding: Content-Type:Cc:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:MIME-Version:Message-ID:Date:Subject:To: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=cOYiP+cEmceT86LNpyvThAfbjkLFkPuoNVke3KAlEMw=; b=CqfReq7VoNWOmPIPEZWgEGT6Fd 07gao3ghYfcpSrr/VpcMCayRoMeKWBLr7be3vNnNi2JxzQT1OGAg36th+xggrclGBtGn1N52klsAM LizO+hl3L3JBkgvgzd5VwBsm/U4x2fUFzvEn1ahLK3PWyvY/RkQAh3mJWs++gJ+6zuxAERuno2ogS eP3ZObFVeDRmjnKMuWR0NHVSczB6IsM1Z/23YKJR6F8Jkzva9n4Qw7N/uLoVOkjm+spOobNl1iwNA 1EBmezkB7nmMZxhibuX7UTDoaEm+BGmcBMYuJIcXzO4RNnJJEnLyWZQ3iFHkmzrTck5ebhPdfK7H/ urS8nFOA==; Received: from localhost ([::1] helo=merlin.infradead.org) by merlin.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1kO54X-0008Pm-Rh; Thu, 01 Oct 2020 20:21:01 +0000 Received: from fllv0015.ext.ti.com ([198.47.19.141]) by merlin.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1kO54R-0008OS-Ii for linux-mtd@lists.infradead.org; Thu, 01 Oct 2020 20:21:00 +0000 Received: from lelv0265.itg.ti.com ([10.180.67.224]) by fllv0015.ext.ti.com (8.15.2/8.15.2) with ESMTP id 091KKoUP029403; Thu, 1 Oct 2020 15:20:50 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1601583650; bh=gRf0hR4Jo4McUBKb5fIZXRhecneqe0BvSBlQryMycls=; h=From:To:CC:Subject:Date; b=O4RX3MoXbihUTgyjV2Kc3FTfMubCAbJkMUgww+EA84VQqtQ6kNT6IxT+xgHj0jvtN 19O+coHiVMWn9UMGPVBtEClO/1R90VDZ/Kw1OEEdY8RPpvtCq9HfkCCI00tlgiAdw2 AMsi8sZJU15YrNl7iEJD1Mov0VV2j+kjKGIrJvFQ= Received: from DLEE113.ent.ti.com (dlee113.ent.ti.com [157.170.170.24]) by lelv0265.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 091KKoQe021151 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Thu, 1 Oct 2020 15:20:50 -0500 Received: from DLEE100.ent.ti.com (157.170.170.30) by DLEE113.ent.ti.com (157.170.170.24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3; Thu, 1 Oct 2020 15:20:49 -0500 Received: from lelv0326.itg.ti.com (10.180.67.84) by DLEE100.ent.ti.com (157.170.170.30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3 via Frontend Transport; Thu, 1 Oct 2020 15:20:49 -0500 Received: from pratyush-OptiPlex-790.dhcp.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by lelv0326.itg.ti.com (8.15.2/8.15.2) with ESMTP id 091KKkcF123930; Thu, 1 Oct 2020 15:20:47 -0500 From: Pratyush Yadav To: Tudor Ambarus , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra , , Subject: [PATCH v15 00/15] mtd: spi-nor: add xSPI Octal DTR support Date: Fri, 2 Oct 2020 01:50:30 +0530 Message-ID: <20201001202045.21499-1-p.yadav@ti.com> X-Mailer: git-send-email 2.28.0 MIME-Version: 1.0 X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20201001_162055_728681_73D3FA3F X-CRM114-Status: GOOD ( 39.93 ) X-Spam-Score: -2.5 (--) X-Spam-Report: SpamAssassin version 3.4.4 on merlin.infradead.org summary: Content analysis details: (-2.5 points) pts rule name description ---- ---------------------- -------------------------------------------------- -2.3 RCVD_IN_DNSWL_MED RBL: Sender listed at https://www.dnswl.org/, medium trust [198.47.19.141 listed in list.dnswl.org] 0.0 SPF_HELO_NONE SPF: HELO does not publish an SPF Record -0.0 SPF_PASS SPF: sender matches SPF record -0.1 DKIM_VALID_AU Message has a valid DKIM or DK signature from author's domain -0.1 DKIM_VALID_EF Message has a valid DKIM or DK signature from envelope-from domain -0.1 DKIM_VALID Message has at least one valid DKIM or DK signature 0.1 DKIM_SIGNED Message has a DKIM or DK signature, not necessarily valid -0.0 DKIMWL_WL_HIGH DKIMwl.org - High trust sender X-BeenThere: linux-mtd@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Linux MTD discussion mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Boris Brezillon , Sekhar Nori , Pratyush Yadav Sender: "linux-mtd" Errors-To: linux-mtd-bounces+incoming=patchwork.ozlabs.org@lists.infradead.org Hi, This series adds support for Octal DTR flashes in the SPI NOR framework, and then adds hooks for the Cypress Semper and Micron Xcella flashes to allow running them in Octal DTR mode. This series assumes that the flash is handed to the kernel in Legacy SPI mode. Tested on Micron MT35X and S28HS flashes for Octal DTR. Tested on Micron MT25Q, and Cypress S25FL for regressions. All flashes were tested by running a read/write stress test on top of UBIFS. On the Cypress S28HS flash 1-bit ECC had to be used to allow UBIFS to work since partial page writes don't work with 2-bit ECC. Changes in v15: - Give precedence to addr_width found via SFDP over forcing it to 4 for 8D. The standard knows better. - Sleep for a range of 1000 to 1500 us instead of 400 to 600. The 400 to 600 range was too close to the actual time it took to change to 8D mode (discovered by polling SR right after and observing that it freezed the controller sometimes). Bump it to 1000 - 1500 to be safe. - Do not initialize dummy to 0 in Profile 1.0 parsing. - Drop the variable io_mode_en_volatile in spi_nor_parse_sccr(). Use the FIELD_GET expression in the if statement directly. - Drop the debug message when setting dummy cycle configuration failed for S28HS flash. - Move the patches that introduce SNOR_F_IO_MODE_EN_VOLATILE to before the one that introduces spi_nor_octal_dtr_enable(). This way we can reject flashes with non-volatile configuration from day 0. Changes in v14: - Rename spi_nor_{read,write}_reg() to spi_nor_controller_ops_{read,write}_reg(). - When spi_nor_spimem_setup_op() will be called after a spi_mem_op is initialized, set buswidth of all phases to 0. This will make the reader question where the buswidth is actually set and avoid any confusions. - Only use address and dummy bytes from Profile 1.0 table for 8D-8D-8D Read SR/FSR instead of all DTR ones. - Do not make spi_nor_default_setup_op() public. It is not used anymore in latest iterations so this is not needed. - Only enable Octal DTR mode when the configuration to enable it is volatile. - Do not prevent modes other than 8D-8D-8D from enabling 4-byte addressing. All other modes don't automatically imply 4-byte addressing. - Add some blank lines in spi_nor_soft_reset(). - Drop the local variable 'dev' in spi_nor_suspend(). - Do not force 4-byte addressing on all DTR modes. Only force it for Octal DTR because only in that case 3-byte addresses are not allowed. - Drop variable addr_width from spi_nor_micron_octal_dtr_enable() and spi_nor_cypress_octal_dtr_enable(). - Remove print from spi_nor_micron_octal_dtr_enable() and spi_nor_cypress_octal_dtr_enable() when enabling/disabling Octal DTR fails. - Wait some time after enabling Octal DTR mode in spi_nor_micron_octal_dtr_enable() and spi_nor_cypress_octal_dtr_enable(). This makes sure the mode is enabled and flash is usuable. - Fix alignment of .fixups in micron_parts and spansion_parts. - s/BFPT_DWORD16_SOFT_RST/BFPT_DWORD16_SWRST_EN_RST - Fix copy-paste leftover in spi_nor_parse_profile1() documentation. - Do not assume a default dummy cycle value if none is found in Profile 1.0 parsing. Leave it to 0 and let flashes fix it up via fixup hooks. - Parse the SCCR table to discover if the Octal DTR enable bit is volatile or not. - Drop variable addr_width in s28hs512t_post_bfpt_fixup() and move op initialization to the declaration to avoid a cast and use nor->bouncebuf directly instead of declaring a local variable. Changes in v13: - Do not use multiple assignments in spi_nor_spimem_setup_op(). - Use EOPNOTSUPP instead of ENOTSUPP. - Fix unbalanced braces around else statements. - Fix whitespace alignment for spi_nor_set_read_settings() prototype. Changes in v12: - Rebase on latest master. - Set dummy and data nbytes to 1 in spi_nor_spimem_check_readop() before calling spi_nor_spimem_check_op() to make sure the buswidth for them is properly set up. Similarly, set data nbytes to 1 for spi_nor_spimem_check_pp(). This makes sure we don't send the wrong dummy and data buswidth to the controller's supports_op(). - Enable DQS for Micron MT35XU512ABA. No reason not to. - Update doc comment for spi_nor_parse_profile1() and spi_nor_cypress_octal_dtr_enable() to add missing fields. Changes in v11: - Add helpers spi_nor_{read,write}_reg() to make it easier to reject DTR ops for them. - Add helper for spi_nor_controller_ops_erase() to make it easier to reject DTR ops. - s/spi-mem/SPIMEM/ and s/spi-nor/SPI NOR/ - Avoid enabling 4-byte addressing mode for all DTR ops instead of just Octal DTR ops. This is based on the assumption that DTR ops can only use 4-byte addressing. - Use round_up() instead of defining ROUND_UP_TO(). - Rename 'table' to 'dwords' in xSPI Profile 1.0 parsing. - Re-order Profile 1.0 related defines by DWORD order. - Move rdsr parameter parsing to where opcode is parsed because it is from the same DWORD. - Drop local variables addr_width and dummy in spi_nor_read_sr() spi_nor_read_fsr(). - Allow soft reset for all protocols, not just 8D-8D-8D. - Do not set address value to 0 is spi_nor_read_sr() and spi_nor_read_fsr(). It is 0 by default when we create the op. - Do not make having command opcode extension as a reserved field fatal. - Introduce the flag SPI_NOR_OCTAL_DTR_PP to indicate 8D page program support since it can't be detected from SFDP. - Move the call to spi_nor_spimem_setup_op() in spi_nor_read_sr() to the commit which introduces it. - Convert a comment in Profile 1.0 parsing from multi-line to one line. Changes in v10: - Rebase on latest linux-next/master. Drop a couple patches that made it in the previous release. - Move the code that sets 20 dummy cycles for MT35XU512ABA to its octal enable function. This way, if the controller doesn't support 8D mode 20 dummy cycles won't be used. Changes in v9: - Do not use '& 0xff' to get the opcode LSB in spi-mxic and spi-zynq-qspi. The cast to u8 will do that anyway. - Do not use if (opcode) as a check for whether the command phase exists in spi-zynq-qspi because the opcode 0 can be valid. Use the new cmd.nbytes instead. Changes in v8: - Move controller changes in spi-mxic to the commit which introduces 2-byte opcodes to avoid problems when bisecting. - Replace usage of sizeof(op->cmd.opcode) with op->cmd.nbytes. - Extract opcode in spi-zynq-qspi instead of using &op->cmd.opcode. Changes in v7: - Reject ops with more than 1 command byte in spi_mem_default_supports_op(). - Reject ops with more than 1 command byte in atmel and mtk controllers. - Reject ops with 0 command bytes in spi_mem_check_op(). - Set cmd.nbytes to 1 when using SPI_MEM_OP_CMD(). - Avoid endianness problems in spi-mxic. Changes in v6: - Instead of hard-coding 8D-8D-8D Fast Read dummy cycles to 20, find them out from the Profile 1.0 table. Changes in v5: - Do not enable stateful X-X-X modes if the reset line is broken. - Instead of setting SNOR_READ_HWCAPS_8_8_8_DTR from Profile 1.0 table parsing, do it in spi_nor_info_init_params() instead based on the SPI_NOR_OCTAL_DTR_READ flag instead. - Set SNOR_HWCAPS_PP_8_8_8_DTR in s28hs post_sfdp hook since this capability is no longer set in Profile 1.0 parsing. - Instead of just checking for spi_nor_get_protocol_width() in spi_nor_octal_dtr_enable(), make sure the protocol is SNOR_PROTO_8_8_8_DTR since get_protocol_width() only cares about data width. - Drop flag SPI_NOR_SOFT_RESET. Instead, discover soft reset capability via BFPT. - Do not make an invalid Quad Enable BFPT field a fatal error. Silently ignore it by assuming no quad enable bit is present. - Set dummy cycles for Cypress Semper flash to 24 instead of 20. This allows for 200MHz operation in 8D mode compared to the 166MHz with 20. - Rename spi_nor_cypress_octal_enable() to spi_nor_cypress_octal_dtr_enable(). - Update spi-mtk-nor.c to reject DTR ops since it doesn't call spi_mem_default_supports_op(). Changes in v4: - Refactor the series to use the new spi-nor framework with the manufacturer-specific bits separated from the core. - Add support for Micron MT35XU512ABA. - Use cmd.nbytes as the criteria of whether the data phase exists or not instead of cmd.buf.in || cmd.buf.out in spi_nor_spimem_setup_op(). - Update Read FSR to use the same dummy cycles and address width as Read SR. - Fix BFPT parsing stopping too early for JESD216 rev B flashes. - Use 2 byte reads for Read SR and FSR commands in DTR mode. Changes in v3: - Drop the DT properties "spi-rx-dtr" and "spi-tx-dtr". Instead, if later a need is felt to disable DTR in case someone has a board with Octal DTR capable flash but does not support DTR transactions for some reason, a property like "spi-no-dtr" can be added. - Remove mode bits SPI_RX_DTR and SPI_TX_DTR. - Remove the Cadence Quadspi controller patch to un-block this series. I will submit it as a separate patch. - Rebase on latest 'master' and fix merge conflicts. - Update read and write dirmap templates to use DTR. - Rename 'is_dtr' to 'dtr'. - Make 'dtr' a bitfield. - Reject DTR ops in spi_mem_default_supports_op(). - Update atmel-quadspi to reject DTR ops. All other controller drivers call spi_mem_default_supports_op() so they will automatically reject DTR ops. - Add support for both enabling and disabling DTR modes. - Perform a Software Reset on flashes that support it when shutting down. - Disable Octal DTR mode on suspend, and re-enable it on resume. - Drop enum 'spi_mem_cmd_ext' and make command opcode u16 instead. Update spi-nor to use the 2-byte command instead of the command extension. Since we still need a "extension type", mode that enum to spi-nor and name it 'spi_nor_cmd_ext'. - Default variable address width to 3 to fix SMPT parsing. - Drop non-volatile change to uniform sector mode and rely on parsing SMPT. Changes in v2: - Add DT properties "spi-rx-dtr" and "spi-tx-dtr" to allow expressing DTR capabilities. - Set the mode bits SPI_RX_DTR and SPI_TX_DTR when we discover the DT properties "spi-rx-dtr" and spi-tx-dtr". - spi_nor_cypress_octal_enable() was updating nor->params.read[] with the intention of setting the correct number of dummy cycles. But this function is called _after_ selecting the read so setting nor->params.read[] will have no effect. So, update nor->read_dummy directly. - Fix spi_nor_spimem_check_readop() and spi_nor_spimem_check_pp() passing nor->read_proto and nor->write_proto to spi_nor_spimem_setup_op() instead of read->proto and pp->proto respectively. - Move the call to cqspi_setup_opcode_ext() inside cqspi_enable_dtr(). This avoids repeating the 'if (f_pdata->is_dtr) cqspi_setup_opcode_ext()...` snippet multiple times. - Call the default 'supports_op()' from cqspi_supports_mem_op(). This makes sure the buswidth requirements are also enforced along with the DTR requirements. - Drop the 'is_dtr' argument from spi_check_dtr_req(). We only call it when a phase is DTR so it is redundant. Pratyush Yadav (13): mtd: spi-nor: core: use EOPNOTSUPP instead of ENOTSUPP mtd: spi-nor: add spi_nor_controller_ops_{read_reg,write_reg,erase}() mtd: spi-nor: add support for DTR protocol mtd: spi-nor: sfdp: get command opcode extension type from BFPT mtd: spi-nor: sfdp: parse xSPI Profile 1.0 table mtd: spi-nor: core: use dummy cycle and address width info from SFDP mtd: spi-nor: core: do 2 byte reads for SR and FSR in DTR mode mtd: spi-nor: core: enable octal DTR mode when possible mtd: spi-nor: sfdp: detect Soft Reset sequence support from BFPT mtd: spi-nor: core: perform a Soft Reset on shutdown mtd: spi-nor: core: disable Octal DTR mode on suspend. mtd: spi-nor: spansion: add support for Cypress Semper flash mtd: spi-nor: micron-st: allow using MT35XU512ABA in Octal DTR mode Tudor Ambarus (2): mtd: spi-nor: Introduce SNOR_F_IO_MODE_EN_VOLATILE mtd: spi-nor: Parse SFDP SCCR Map drivers/mtd/spi-nor/core.c | 544 ++++++++++++++++++++++++-------- drivers/mtd/spi-nor/core.h | 26 ++ drivers/mtd/spi-nor/micron-st.c | 100 +++++- drivers/mtd/spi-nor/sfdp.c | 170 +++++++++- drivers/mtd/spi-nor/sfdp.h | 8 + drivers/mtd/spi-nor/spansion.c | 156 +++++++++ include/linux/mtd/spi-nor.h | 53 +++- 7 files changed, 918 insertions(+), 139 deletions(-) --- 2.28.0