From patchwork Tue Feb 7 06:09:22 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sai Krishna Potthuri X-Patchwork-Id: 651665 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 vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id F199AC636D4 for ; Tue, 7 Feb 2023 06:09:48 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229447AbjBGGJs (ORCPT ); Tue, 7 Feb 2023 01:09:48 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35662 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229827AbjBGGJq (ORCPT ); Tue, 7 Feb 2023 01:09:46 -0500 Received: from NAM12-MW2-obe.outbound.protection.outlook.com (mail-mw2nam12on2083.outbound.protection.outlook.com [40.107.244.83]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A87D840F7; Mon, 6 Feb 2023 22:09:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=h66DGzSByZNSQBJ7Jfn78OcuGcl8nkiKM8/G99tOxhjCvLzUC+tzCkQCaC5Hm+fX5rnHrTVepr8qMWrfKt+UtX9mrmfFX7ECESqa8XOWuymW9g4yUxdM5IIocXON17akgf0ro5+oAUHM3qdGzgh8WX2RWi1uDyYWXkdtS8zR/tQFfQGys0WEm4knoZfWdoVUCxQieygxpxt3jGwiNYsHmB6VDN9ZhW+v5CFsCOjZ2fgRUeLG58ds1wY/W6dPIJMF4t8Tdxk6Ik6DMIuBXhUpQxv0KDGkVyHDpM6r4JocAaH+Wj+rkahBRzBAJeMC7b1qK+B0QCE9Wqt/li3m/UmJcQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=s014qIdrVIxPpZVloQ7M/vCeKFR+q5a6fzI9mp/0hjY=; b=LAhhNTBnWSXIiUke5degSfDC/kPUw48f+WGmxK/UH64Uf0ZFBxv566w87gyMxEGt7p5Jtq1lDodAS6ox51BMnJUpGPdISGzcU/nUeJdsFfcp+ePMWI0NiHLwcs0RhFlVO369tPBv2JRiEhfIm8xxErzdxmrbnpyM9Ckjb9mlQPOUSaTBDrIvNsqzT8pygBa4ZZpAD1U6REwS3STj77mL+bqStgFY0Vz1sQhD8soorZQJ9ON+jC4W2yp4V1b9h+ck+onmandvUMC5CaKx1/NtCa+94y4d4p93fhGmvYX49s6FNqOk1us7AhZqrvTqFlcYPqHwwhYIivm3YbPPGL/9gQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=kernel.org smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=s014qIdrVIxPpZVloQ7M/vCeKFR+q5a6fzI9mp/0hjY=; b=mNi6ZrWTJ/yUI5quFgiKC9OpvC8fbmma3QZ+pMz7+Aa6NWo8oeAEEFYyW6ZVGCjMdCCOvnSPiId77y/HhLOq7p8ruYdCDeChI/gbvQPcNjMFwL/F8fZTUVF2zQereqVeA0xLByVawU+4dJHf7kk9RwgZ15RvxgF+tTViIx+R5D4= Received: from DM6PR02CA0123.namprd02.prod.outlook.com (2603:10b6:5:1b4::25) by CH3PR12MB8511.namprd12.prod.outlook.com (2603:10b6:610:15c::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6064.34; Tue, 7 Feb 2023 06:09:42 +0000 Received: from DM6NAM11FT109.eop-nam11.prod.protection.outlook.com (2603:10b6:5:1b4:cafe::83) by DM6PR02CA0123.outlook.office365.com (2603:10b6:5:1b4::25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6064.34 via Frontend Transport; Tue, 7 Feb 2023 06:09:42 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB03.amd.com; pr=C Received: from SATLEXMB03.amd.com (165.204.84.17) by DM6NAM11FT109.mail.protection.outlook.com (10.13.173.178) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.6064.34 via Frontend Transport; Tue, 7 Feb 2023 06:09:42 +0000 Received: from SATLEXMB06.amd.com (10.181.40.147) by SATLEXMB03.amd.com (10.181.40.144) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.34; Tue, 7 Feb 2023 00:09:41 -0600 Received: from SATLEXMB03.amd.com (10.181.40.144) by SATLEXMB06.amd.com (10.181.40.147) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.34; Tue, 7 Feb 2023 00:09:41 -0600 Received: from xhdlakshmis40.xilinx.com (10.180.168.240) by SATLEXMB03.amd.com (10.181.40.144) with Microsoft SMTP Server id 15.1.2375.34 via Frontend Transport; Tue, 7 Feb 2023 00:09:38 -0600 From: Sai Krishna Potthuri To: Mark Brown , Tudor Ambarus , Pratyush Yadav , "Michael Walle" , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra CC: , , , , , Sai Krishna Potthuri Subject: [PATCH 1/3] spi: cadence-quadspi: Add support for PHY module and DQS Date: Tue, 7 Feb 2023 11:39:22 +0530 Message-ID: <20230207060924.265789-2-sai.krishna.potthuri@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20230207060924.265789-1-sai.krishna.potthuri@amd.com> References: <20230207060924.265789-1-sai.krishna.potthuri@amd.com> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT109:EE_|CH3PR12MB8511:EE_ X-MS-Office365-Filtering-Correlation-Id: 137dce3e-ba54-47a4-de56-08db08d1e755 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 6hNLwCv6XahYBN4zJQKjil9IamUld/t2uljBcE3ppCKjo/n1zsD/oLxuUvklOJOXnVtV3sjgrq0Fe/rNozT2VMpxbcZiZ71hzzcpIFYfvwOKmUJpD7cKAZbMv+DskwM5dFm5dp0m9IuEz5/qGh/NiERH3Jk8wQMmdDm9qx1D7sIme/FSFd2fcbQS41F5Oi5BegFPurOmZ9hhR3XSSvzZOGNYcv1oY+STnhQSRLtSQtz9fumw+GyYpz3CcfI2gR0zCgeLCXFOyFHTD3wlp9P4qMNRatBzcpGYu+3D0ojr1gyqLbVp8C33prt3De5L++/WOE4uGzD5Z91AFSKZn94/KiM589D4DO4xae+ScrHhPrIhvK0TUOihPIY6LJkOYihJgasPJ9N73bPCHt375P6PEO1PC7aT4bK5p4egoQonhUuSudOKz4yihcdckET1vgHM83qVjmSkmOTWHJHs6z+0mtUJRVEfSbKqYV8IbCn0Bfu3VC88OqqCglnhZC6C4oRsO/bv+rKsSdh/rhDSnZP7XrGrj/HUkH8neJZuVCnMZjFZlJrQkU67r7zX5CSqUmhQftuLy8iuIeyBdn19cwWfj7mSVo9z8sLhWiwpmPuSU0m8nM29lzTTTH/VXYSonOqCZq7d6KjLDhrZmkhdPN+b6TJz1ZILl6BZZSYgv/pvUrChFGcr5yjrkO8uCI+BTMmnTRfI+ub4tKpanBkQvMQ9vq4WCTlPylSDFVRPqFNBXyU= X-Forefront-Antispam-Report: CIP:165.204.84.17; CTRY:US; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:SATLEXMB03.amd.com; PTR:InfoDomainNonexistent; CAT:NONE; SFS:(13230025)(4636009)(396003)(376002)(39860400002)(346002)(136003)(451199018)(40470700004)(46966006)(36840700001)(81166007)(356005)(47076005)(82740400003)(82310400005)(1076003)(6666004)(186003)(26005)(36756003)(40460700003)(86362001)(70206006)(2616005)(8676002)(336012)(426003)(4326008)(83380400001)(70586007)(54906003)(316002)(36860700001)(7416002)(103116003)(478600001)(110136005)(2906002)(5660300002)(41300700001)(8936002)(40480700001)(36900700001); DIR:OUT; SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 07 Feb 2023 06:09:42.3689 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 137dce3e-ba54-47a4-de56-08db08d1e755 X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d; Ip=[165.204.84.17]; Helo=[SATLEXMB03.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT109.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: CH3PR12MB8511 Precedence: bulk List-ID: X-Mailing-List: linux-spi@vger.kernel.org Cadence Octal SPI Flash Controller has PHY module, which is used for handling SPI transactions when there is a requirement for high performance. Also, this controller supports DQS(data strobe) used for data capturing in PHY mode rather than internally generated ref_clk. Xilinx Versal Octal SPI use PHY module and DQS signal when operating in DTR protocol. Signed-off-by: Sai Krishna Potthuri --- drivers/spi/spi-cadence-quadspi.c | 25 ++++++++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/drivers/spi/spi-cadence-quadspi.c b/drivers/spi/spi-cadence-quadspi.c index 676313e1bdad..b55b763003f0 100644 --- a/drivers/spi/spi-cadence-quadspi.c +++ b/drivers/spi/spi-cadence-quadspi.c @@ -40,6 +40,8 @@ #define CQSPI_SUPPORT_EXTERNAL_DMA BIT(2) #define CQSPI_NO_SUPPORT_WR_COMPLETION BIT(3) #define CQSPI_SLOW_SRAM BIT(4) +#define CQSPI_HAS_PHY BIT(5) +#define CQSPI_HAS_DQS BIT(6) /* Capabilities */ #define CQSPI_SUPPORTS_OCTAL BIT(0) @@ -89,6 +91,8 @@ struct cqspi_st { u32 pd_dev_id; bool wr_completion; bool slow_sram; + bool use_phy; + bool use_dqs; }; struct cqspi_driver_platdata { @@ -112,6 +116,7 @@ struct cqspi_driver_platdata { /* Register map */ #define CQSPI_REG_CONFIG 0x00 #define CQSPI_REG_CONFIG_ENABLE_MASK BIT(0) +#define CQSPI_REG_CONFIG_PHY_MODE BIT(3) #define CQSPI_REG_CONFIG_ENB_DIR_ACC_CTRL BIT(7) #define CQSPI_REG_CONFIG_DECODE_MASK BIT(9) #define CQSPI_REG_CONFIG_CHIPSELECT_LSB 10 @@ -151,6 +156,7 @@ struct cqspi_driver_platdata { #define CQSPI_REG_DELAY_TSHSL_MASK 0xFF #define CQSPI_REG_READCAPTURE 0x10 +#define CQSPI_REG_READCAPTURE_DQS BIT(8) #define CQSPI_REG_READCAPTURE_BYPASS_LSB 0 #define CQSPI_REG_READCAPTURE_DELAY_LSB 1 #define CQSPI_REG_READCAPTURE_DELAY_MASK 0xF @@ -468,6 +474,8 @@ static int cqspi_enable_dtr(struct cqspi_flash_pdata *f_pdata, if (op->cmd.dtr) { reg |= CQSPI_REG_CONFIG_DTR_PROTO; reg |= CQSPI_REG_CONFIG_DUAL_OPCODE; + if (cqspi->use_phy) + reg |= CQSPI_REG_CONFIG_PHY_MODE; /* Set up command opcode extension. */ ret = cqspi_setup_opcode_ext(f_pdata, op, shift); @@ -476,10 +484,20 @@ static int cqspi_enable_dtr(struct cqspi_flash_pdata *f_pdata, } else { reg &= ~CQSPI_REG_CONFIG_DTR_PROTO; reg &= ~CQSPI_REG_CONFIG_DUAL_OPCODE; + reg &= ~CQSPI_REG_CONFIG_PHY_MODE; } writel(reg, reg_base + CQSPI_REG_CONFIG); + reg = readl(reg_base + CQSPI_REG_READCAPTURE); + + if (op->cmd.dtr) + reg |= CQSPI_REG_READCAPTURE_DQS; + else + reg &= ~CQSPI_REG_READCAPTURE_DQS; + + writel(reg, reg_base + CQSPI_REG_READCAPTURE); + return cqspi_wait_idle(cqspi); } @@ -1700,6 +1718,10 @@ static int cqspi_probe(struct platform_device *pdev) cqspi->wr_completion = false; if (ddata->quirks & CQSPI_SLOW_SRAM) cqspi->slow_sram = true; + if (ddata->quirks & CQSPI_HAS_PHY) + cqspi->use_phy = true; + if (ddata->quirks & CQSPI_HAS_DQS) + cqspi->use_dqs = true; if (of_device_is_compatible(pdev->dev.of_node, "xlnx,versal-ospi-1.0")) @@ -1820,7 +1842,8 @@ static const struct cqspi_driver_platdata socfpga_qspi = { static const struct cqspi_driver_platdata versal_ospi = { .hwcaps_mask = CQSPI_SUPPORTS_OCTAL, - .quirks = CQSPI_DISABLE_DAC_MODE | CQSPI_SUPPORT_EXTERNAL_DMA, + .quirks = CQSPI_DISABLE_DAC_MODE | CQSPI_SUPPORT_EXTERNAL_DMA + | CQSPI_HAS_PHY | CQSPI_HAS_DQS, .indirect_read_dma = cqspi_versal_indirect_read_dma, .get_dma_status = cqspi_get_versal_dma_status, }; From patchwork Tue Feb 7 06:09:23 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sai Krishna Potthuri X-Patchwork-Id: 652328 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 vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 42E05C636CD for ; Tue, 7 Feb 2023 06:09:59 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229923AbjBGGJ5 (ORCPT ); Tue, 7 Feb 2023 01:09:57 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35802 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229878AbjBGGJx (ORCPT ); Tue, 7 Feb 2023 01:09:53 -0500 Received: from NAM11-DM6-obe.outbound.protection.outlook.com (mail-dm6nam11on2083.outbound.protection.outlook.com [40.107.223.83]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7C6E62E0F9; Mon, 6 Feb 2023 22:09:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=oYlF2ONuqAUovnJFN5E4lcpjQouT6KTR6dJwtWeHgn4jSWzWdLbAN0Ro4WCEobB/zcXVJoI8kvuF48+kGnh3Gnb0OSXlmmDwX7mLGpbsh2hbiea1kkKgHWz/NzRP7eCOGzNFABqCrUaMupeYk9ld+WI6VsK7Y2+3+dZK9hQ6TiN5OQOnH+EJVGnhBPI5s4c5U9aWHH12SAmby+S6wTAVFGzQY2mJ7Awl8jTcLoGNkcmkW+Shh4GtM2sSh6blCNHsqjQ4Ed0QwiD7mWbTRqI/Tqr3pxOcQpkrlDpcT1WhHwGiTqQ5LAmm7GklLMMXxanHT4nIFR1uKFTp4kl3rxFu3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=nPY6ZmdggQJDaY7b+MJS0Ehlu01syJw8PLd4AJejj8E=; b=jR07Etlaph1pF9Opv+PCPleABflvLD60eDzIAw4iaX8UWkTxVVrhud54kzfrrWnm41qnFKXA3kkGGiOFJ0QS42NF/CixfSDsfaMNBK86sFId7hzmitUYexBzWzNUyFcH0ZHNCOJdELTRNsmWnWPhGSAVwUv/Er6sawAhliYRahG+mefZ+RnRr9Ko6w3HSL3I5nzpkf6dM4Q3eWSd/5N8tW2A5ftWAWy+POyARBzztydGnsmGc0qERcqRKGGPD0K3RAA4vOv9VrkQqQNJLwhXvhL+2saQZmfVUPDznufu6eLKqnDv8J1uujYQzRffwFDL/SqWS7E+O1DabDqkWnfQjQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=kernel.org smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=nPY6ZmdggQJDaY7b+MJS0Ehlu01syJw8PLd4AJejj8E=; b=QFdfdE4S61bIfhQTh7yg5mepBvZPXAjTt2emrr4zI0sSIN9z142hQPLnz7EB3/TihyqgwaFblYLp39h3K7DZErWG4NI/VRTe/UIYARNgDf13s3NAwAcdvSPYlQ0VUwnhB85Si1H1NHPphMPZA8OvKzR0LHwt/61S4RzE0DbaxR8= Received: from DM6PR11CA0003.namprd11.prod.outlook.com (2603:10b6:5:190::16) by PH7PR12MB7116.namprd12.prod.outlook.com (2603:10b6:510:1ef::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6064.34; Tue, 7 Feb 2023 06:09:46 +0000 Received: from DM6NAM11FT100.eop-nam11.prod.protection.outlook.com (2603:10b6:5:190:cafe::bb) by DM6PR11CA0003.outlook.office365.com (2603:10b6:5:190::16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6064.36 via Frontend Transport; Tue, 7 Feb 2023 06:09:46 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT100.mail.protection.outlook.com (10.13.172.247) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.6064.35 via Frontend Transport; Tue, 7 Feb 2023 06:09:45 +0000 Received: from SATLEXMB06.amd.com (10.181.40.147) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.34; Tue, 7 Feb 2023 00:09:45 -0600 Received: from SATLEXMB03.amd.com (10.181.40.144) by SATLEXMB06.amd.com (10.181.40.147) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.34; Tue, 7 Feb 2023 00:09:45 -0600 Received: from xhdlakshmis40.xilinx.com (10.180.168.240) by SATLEXMB03.amd.com (10.181.40.144) with Microsoft SMTP Server id 15.1.2375.34 via Frontend Transport; Tue, 7 Feb 2023 00:09:41 -0600 From: Sai Krishna Potthuri To: Mark Brown , Tudor Ambarus , Pratyush Yadav , "Michael Walle" , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra CC: , , , , , Sai Krishna Potthuri Subject: [PATCH 2/3] mtd: spi-nor: Add and update device_id field in spi_mem structure Date: Tue, 7 Feb 2023 11:39:23 +0530 Message-ID: <20230207060924.265789-3-sai.krishna.potthuri@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20230207060924.265789-1-sai.krishna.potthuri@amd.com> References: <20230207060924.265789-1-sai.krishna.potthuri@amd.com> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT100:EE_|PH7PR12MB7116:EE_ X-MS-Office365-Filtering-Correlation-Id: c44c8167-6a1e-451a-87a4-08db08d1e969 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: /Si8CGytmSLmdo4OLRe30DyvB5yQdtqxg902QQTCQSnm369i4JAvfv09zG4iiPEk3gYa9B5zJiD8M3UYJ056UaBZkozmx9mgFwab5UULQBrTHMSzBewPBNpnUwX/wzifKTWJRzvpy05pUaN7YIchCUJFnZLrHZYwlWpuDROCa1JLYds+rhrfgOpIPo3bw/h6NmhCv3pWymdQD+fGG04Gr8izpkDMEpCYYAxesaZL4uX0ieWXlHP6zSFIc+N0zrNtTDquTiHN5R9u6WnbkuTbEUOWCStSoiBAyr6W60RArqoBclOaflmu7kSz+qUxz4D/lUsHFYaC1iN0xeazCNnzlgcaOTAcO0e2K+30CYl3Y9/aTx/6XVRGLXLifLek577v5Ont8EA548LLTFvCJEOouaOInyP7wQMCs9wT9Chem4KXiowopIeql+s0bEld+GWbiEsqmeZdatBK6UOcIEjW1/Te4wEyDMVqXj057aXtW6rfFxRsFoPGeIycxFkhcuw5uQutmXpHaDb+48NMS9rF+lCVUDt11wA5ZDC68txJyPWh52gB+H+IxD3foMdIET7zfkeubpsNYq0xnoiwaUgUNcxe6VK9c3nPLaoT0ODYSuhbGv7wVeE8W1zxGC1JcktLN6rwv2iZdlJcRp9P2WSlcDcohXm8fLmqJQSyiCdSgXxHsxLLSpdHvMgnTRcsa97hxVA8J7DeFqr8erxaIQx65UEbmUqQU3SNvRS0wnrOEGo= X-Forefront-Antispam-Report: CIP:165.204.84.17; CTRY:US; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:SATLEXMB04.amd.com; PTR:InfoDomainNonexistent; CAT:NONE; SFS:(13230025)(4636009)(396003)(376002)(346002)(39860400002)(136003)(451199018)(46966006)(40470700004)(36840700001)(356005)(8676002)(86362001)(40460700003)(103116003)(316002)(70586007)(36756003)(70206006)(4326008)(41300700001)(82310400005)(110136005)(54906003)(8936002)(7416002)(5660300002)(2906002)(15650500001)(40480700001)(83380400001)(82740400003)(26005)(1076003)(186003)(36860700001)(6666004)(47076005)(336012)(426003)(81166007)(478600001)(2616005)(36900700001); DIR:OUT; SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 07 Feb 2023 06:09:45.9470 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: c44c8167-6a1e-451a-87a4-08db08d1e969 X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d; Ip=[165.204.84.17]; Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT100.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH7PR12MB7116 Precedence: bulk List-ID: X-Mailing-List: linux-spi@vger.kernel.org Xilinx Versal Octal SPI controller drivers might require the device id information to perform the Rx tuning operation. Since there is no common Tuning Data Pattern defined across all vendors, controllers which requires Rx tuning to find out the optimal sampling point for data lines, this device id information will be used as a golden data. spi-nor core updates the device id information in device_id field while reading the id of the flash device. Signed-off-by: Sai Krishna Potthuri --- drivers/mtd/spi-nor/core.c | 1 + include/linux/spi/spi-mem.h | 4 ++++ 2 files changed, 5 insertions(+) diff --git a/drivers/mtd/spi-nor/core.c b/drivers/mtd/spi-nor/core.c index bee8fc4c9f07..9811e74ef3b6 100644 --- a/drivers/mtd/spi-nor/core.c +++ b/drivers/mtd/spi-nor/core.c @@ -1644,6 +1644,7 @@ static const struct flash_info *spi_nor_match_id(struct spi_nor *nor, if (part->id_len && !memcmp(part->id, id, part->id_len)) { nor->manufacturer = manufacturers[i]; + memcpy(nor->spimem->device_id, id, SPI_NOR_MAX_ID_LEN); return part; } } diff --git a/include/linux/spi/spi-mem.h b/include/linux/spi/spi-mem.h index 8e984d75f5b6..e9ae5c1b7391 100644 --- a/include/linux/spi/spi-mem.h +++ b/include/linux/spi/spi-mem.h @@ -181,11 +181,14 @@ struct spi_mem_dirmap_desc { void *priv; }; +#define SPI_MEM_DEV_MAX_ID_LEN 6 + /** * struct spi_mem - describes a SPI memory device * @spi: the underlying SPI device * @drvpriv: spi_mem_driver private data * @name: name of the SPI memory device + * @device_id: device id of the SPI memory device * * Extra information that describe the SPI memory device and may be needed by * the controller to properly handle this device should be placed here. @@ -197,6 +200,7 @@ struct spi_mem { struct spi_device *spi; void *drvpriv; const char *name; + u8 device_id[SPI_MEM_DEV_MAX_ID_LEN]; }; /** From patchwork Tue Feb 7 06:09:24 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sai Krishna Potthuri X-Patchwork-Id: 651664 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 vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 049C6C636CC for ; Tue, 7 Feb 2023 06:10:10 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229896AbjBGGKJ (ORCPT ); Tue, 7 Feb 2023 01:10:09 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36060 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229942AbjBGGKC (ORCPT ); Tue, 7 Feb 2023 01:10:02 -0500 Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on2055.outbound.protection.outlook.com [40.107.93.55]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4605530E9D; Mon, 6 Feb 2023 22:09:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=QxnXYO6NiCPQGgmeBY8KKTUilRsKEoh3h5Lvr5z32zppWj2eBcelMKSI15zkvh5ADyuOZseIfaT/CUn4UIGlJEsPUrQCQqFqP9i52Dqin3tGk9KIW0fYdReuLmviaO99ZkLlXcyypRc0CbETNbtjicYY6SOQyWLuRQYPME9mb4kZM1JNaH8E/mCYC5ZEGXHFr1QZZa+wR4rlRlKAOWvFu/yKqqsyG+RF7NJXKDYL5Tv9sEBnQmcqaUin+LkCJW1v//8JdBcqWm0SRmdv1sucIgZxpggVvmKOm2YbmP+G9CvONg+jIP7gOdFDiTW0EeypMZWr52O/xudzrbzwj34Bvg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=ZGiQ1T+cc3d0ZhOnWiM1lRPCy2eKoeVpTZBC5m6QBLI=; b=iFrqXZAHXvbl+MCgoE5jCeMa693KQNXBnDVzVtOUr0t/zBEqkYV85gIs0hK1xWhl95cF+8z+80/QpSh39gWNg+Birnoocnren1np4MMejOA8u4bc0MXvEPQHzcUVQSRBnXuRp7jYFGAZ3nr6JSnxNTLne7GERvgYTxuNYVuuH4cQzDjnlsvbsTTrduTwZVydHd10zBy8BHePc35mANcmIQYljkraaDOof8QhgI94wwUblsFcpWft9SzYwrcWr7OXIKfeQSKFnAhI3stOXJVNx+Vn0oxbtBqXhvVpj+YJgIe0xe3oJyj2C3ywhaf/aJozgqQtTOXvnFAeRRIrUQOUJQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=kernel.org smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=ZGiQ1T+cc3d0ZhOnWiM1lRPCy2eKoeVpTZBC5m6QBLI=; b=EQBahLWY+ZwAY8k96ck1Db8rw8CORcLXUBNq+sTmQq/aBnCAIZCD0wWOE+XUgsqdhbrQlVZ9h7yhSNB+psWkp2WucLt/BfiPSJzfaUYx+KroyGtjYPgdDrs91CjZ5vx6WeHhDd1yJeAi5BVHwjBQYcpIfYps42IaklVTOb9GZqA= Received: from DS7PR03CA0057.namprd03.prod.outlook.com (2603:10b6:5:3b5::32) by PH8PR12MB7352.namprd12.prod.outlook.com (2603:10b6:510:214::16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6064.34; Tue, 7 Feb 2023 06:09:50 +0000 Received: from DM6NAM11FT070.eop-nam11.prod.protection.outlook.com (2603:10b6:5:3b5:cafe::6c) by DS7PR03CA0057.outlook.office365.com (2603:10b6:5:3b5::32) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6064.34 via Frontend Transport; Tue, 7 Feb 2023 06:09:49 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB03.amd.com; pr=C Received: from SATLEXMB03.amd.com (165.204.84.17) by DM6NAM11FT070.mail.protection.outlook.com (10.13.173.51) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.6064.35 via Frontend Transport; Tue, 7 Feb 2023 06:09:49 +0000 Received: from SATLEXMB06.amd.com (10.181.40.147) by SATLEXMB03.amd.com (10.181.40.144) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.34; Tue, 7 Feb 2023 00:09:49 -0600 Received: from SATLEXMB03.amd.com (10.181.40.144) by SATLEXMB06.amd.com (10.181.40.147) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.34; Tue, 7 Feb 2023 00:09:48 -0600 Received: from xhdlakshmis40.xilinx.com (10.180.168.240) by SATLEXMB03.amd.com (10.181.40.144) with Microsoft SMTP Server id 15.1.2375.34 via Frontend Transport; Tue, 7 Feb 2023 00:09:45 -0600 From: Sai Krishna Potthuri To: Mark Brown , Tudor Ambarus , Pratyush Yadav , "Michael Walle" , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra CC: , , , , , Sai Krishna Potthuri Subject: [PATCH 3/3] spi: cadence-quadspi: Add Rx tuning support for Xilinx Versal OSPI Date: Tue, 7 Feb 2023 11:39:24 +0530 Message-ID: <20230207060924.265789-4-sai.krishna.potthuri@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20230207060924.265789-1-sai.krishna.potthuri@amd.com> References: <20230207060924.265789-1-sai.krishna.potthuri@amd.com> MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT070:EE_|PH8PR12MB7352:EE_ X-MS-Office365-Filtering-Correlation-Id: edf78648-911f-49dd-9db0-08db08d1ebb3 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: U1CHsZcdVRkjr9eWNmqFqx7s8VXJRZLxDTi0yFcw8CCa348s0/oRWk50EiNUa2OtZbbuUzCgimfdGSF65Kh0Q910+tUTkeM9LolBC2si1pI2UrxxLw3YjJ+jYEyESo26vRtj6IyuY1eH64DUyEl2/vmOPH0PwttH1KzKkELaNaPMBVz2L/jCJtpnlvljKI/6gWFjIzjMt1NA+ywvoaQ3SLKmW22byjXUaq9x2TRWLEF31V7HsmJ6AZgOiDHybWMdcjkfMV1UqbS4t2NlDWjcWFrlFPIJWescHWOXUe+w1k1BSwiJmVRocrnVoKAKGYlnIz53U0k+zQEJTRTTHOras2M6a4fUeALCwArcl5cNibs86Bm+0uQpOw6nfZd+RspDq73Bpa608nJkA863xCNIvrh768PJ52p1wEMK7ecRvzdsrHOY/GvcpStws+paTsgDngH6K1egKUUpE1p4hcH8m7MG1/VWnIj5hYo8c1P5sVluKYeIFoe1FeOu0al8IlgN0PtaW8uQ766sq/lrFmlFhW82gvKCeDPyFIwPC/lSxA6MPHqlqx8ko66BoFAjgHobi6be8rBQ5YpABaBZu7hhlzisuwLsyAgaO5+hzrG8GpRHuoBwt6RXPUx6P39KGCLpeTmb3CyWxmUDuNLmos7qQ7pkvLUbzwx2Sm9nQbViQtLObvjRJnxkae964xBr2aN85A+HH+K8M7FICDnCxkEdiROkzhQRd9lZm8PzdCe/1UU= X-Forefront-Antispam-Report: CIP:165.204.84.17; CTRY:US; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:SATLEXMB03.amd.com; PTR:InfoDomainNonexistent; CAT:NONE; SFS:(13230025)(4636009)(396003)(136003)(39860400002)(346002)(376002)(451199018)(36840700001)(46966006)(40470700004)(2906002)(30864003)(5660300002)(41300700001)(7416002)(8936002)(82740400003)(8676002)(4326008)(2616005)(70206006)(70586007)(356005)(54906003)(478600001)(316002)(336012)(1076003)(40460700003)(110136005)(36756003)(26005)(83380400001)(186003)(81166007)(103116003)(426003)(6666004)(86362001)(40480700001)(36860700001)(47076005)(82310400005)(36900700001); DIR:OUT; SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 07 Feb 2023 06:09:49.7880 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: edf78648-911f-49dd-9db0-08db08d1ebb3 X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d; Ip=[165.204.84.17]; Helo=[SATLEXMB03.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT070.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH8PR12MB7352 Precedence: bulk List-ID: X-Mailing-List: linux-spi@vger.kernel.org Add Rx tuning support for Xilinx Versal Octal SPI Controller(OSPI). Xilinx Versal Octal SPI controller requires Rx tuning to find out the optimal tap value when running at higher clock in DTR protocol. As there is no common Tuning Data Pattern defined across all vendors, Xilinx Versal Octal SPI uses READ_ID based tuning algorithm for which this device_id field in spi_mem will be used as a Tuning data pattern. After enabling the DTR protocol, spi-nor sends READ ID command to verify the DTR protocol switching is successfully done or not. If execute_tuning is defined(not NULL) and clk_tuned is not set then Rx tuning algorithm will be executed before it actually read the ID in DTR protocol. Xilinx Versal tuning algorithm (as suggested by IP design team): - Sweep all possible 127 taps to read the flash id for each tap. - To consider a particular tap as valid make sure to get the correct id for 10 times. - Once valid window is found(window size >= 3), stop parsing the remaining taps. - Perform the above steps with extra dummy clock 1. - Identify the maximum window size between extra dummy clock 0 and 1 and configure the median of min and max valid tap of the corresponding window. - If the maximum window size is with dummy clock 1 then all the subsequent read operations should be performed with one extra dummy clock. Signed-off-by: Sai Krishna Potthuri --- drivers/spi/spi-cadence-quadspi.c | 201 ++++++++++++++++++++++++++++++ 1 file changed, 201 insertions(+) diff --git a/drivers/spi/spi-cadence-quadspi.c b/drivers/spi/spi-cadence-quadspi.c index b55b763003f0..bc4395736def 100644 --- a/drivers/spi/spi-cadence-quadspi.c +++ b/drivers/spi/spi-cadence-quadspi.c @@ -93,6 +93,8 @@ struct cqspi_st { bool slow_sram; bool use_phy; bool use_dqs; + bool clk_tuned; + u8 extra_dummy_clks; }; struct cqspi_driver_platdata { @@ -101,6 +103,7 @@ struct cqspi_driver_platdata { int (*indirect_read_dma)(struct cqspi_flash_pdata *f_pdata, u_char *rxbuf, loff_t from_addr, size_t n_rx); u32 (*get_dma_status)(struct cqspi_st *cqspi); + int (*execute_tuning)(struct spi_mem *mem, const struct spi_mem_op *op); }; /* Operation timeout value */ @@ -192,6 +195,7 @@ struct cqspi_driver_platdata { #define CQSPI_REG_IRQSTATUS 0x40 #define CQSPI_REG_IRQMASK 0x44 +#define CQSPI_REG_VERSAL_ECO 0x48 #define CQSPI_REG_INDIRECTRD 0x60 #define CQSPI_REG_INDIRECTRD_START_MASK BIT(0) @@ -238,6 +242,19 @@ struct cqspi_driver_platdata { #define CQSPI_REG_POLLING_STATUS 0xB0 #define CQSPI_REG_POLLING_STATUS_DUMMY_LSB 16 +#define CQSPI_REG_VERSAL_PHY_CONFIG 0xB4 +#define CQSPI_REG_PHY_CONFIG_RESYNC_FLD_MASK BIT(31) +#define CQSPI_REG_PHY_CONFIG_RESET_FLD_MASK BIT(30) +#define CQSPI_REG_PHY_CONFIG_TX_DLL_DLY_LSB 16 + +#define CQSPI_REG_VERSAL_PHY_MASTER_CTRL 0xB8 +#define CQSPI_REG_DLL_LOWER 0xBC +#define CQSPI_REG_DLL_LOWER_LPBK_LOCK_MASK BIT(15) +#define CQSPI_REG_DLL_LOWER_DLL_LOCK_MASK BIT(0) + +#define CQSPI_REG_VERSAL_DLL_OBSVBLE_UPPER 0xC0 +#define CQSPI_REG_DLL_UPPER_RX_FLD_MASK 0x7F + #define CQSPI_REG_OP_EXT_LOWER 0xE0 #define CQSPI_REG_OP_EXT_READ_LSB 24 #define CQSPI_REG_OP_EXT_WRITE_LSB 16 @@ -282,6 +299,12 @@ struct cqspi_driver_platdata { #define CQSPI_DMA_UNALIGN 0x3 #define CQSPI_REG_VERSAL_DMA_VAL 0x602 +#define CQSPI_VERSAL_MAX_DLL_TAPS 127 +#define CQSPI_VERSAL_TX_TAP_MASTER 0x1E +#define CQSPI_VERSAL_ECO_MIN_FREQ 120000000 +#define CQSPI_VERSAL_INIT_DLY 4 +#define CQSPI_VERSAL_RDID_MAX_CNT 10 +#define CQSPI_VERSAL_MIN_WINDOW_SZ 3 static int cqspi_wait_for_bit(void __iomem *reg, const u32 mask, bool clr) { @@ -540,6 +563,14 @@ static int cqspi_command_read(struct cqspi_flash_pdata *f_pdata, if (dummy_clk > CQSPI_DUMMY_CLKS_MAX) return -EOPNOTSUPP; + /* + * Based on the tuning, some controllers requires extra dummy clocks due to additional + * delays in read path. For such controllers add required extra dummy clocks for all + * subsequent read operations. + */ + if (cqspi->extra_dummy_clks) + dummy_clk += cqspi->extra_dummy_clks; + if (dummy_clk) reg |= (dummy_clk & CQSPI_REG_CMDCTRL_DUMMY_MASK) << CQSPI_REG_CMDCTRL_DUMMY_LSB; @@ -662,6 +693,14 @@ static int cqspi_read_setup(struct cqspi_flash_pdata *f_pdata, if (dummy_clk > CQSPI_DUMMY_CLKS_MAX) return -EOPNOTSUPP; + /* + * Based on the tuning, some controllers requires extra dummy clocks due to additional + * delays in read path. For such controllers add required extra dummy clocks for all + * subsequent read operations. + */ + if (cqspi->extra_dummy_clks) + dummy_clk += cqspi->extra_dummy_clks; + if (dummy_clk) reg |= (dummy_clk & CQSPI_REG_RD_INSTR_DUMMY_MASK) << CQSPI_REG_RD_INSTR_DUMMY_LSB; @@ -1056,6 +1095,157 @@ static int cqspi_indirect_write_execute(struct cqspi_flash_pdata *f_pdata, return ret; } +static int cqspi_versal_execute_tuning(struct spi_mem *mem, const struct spi_mem_op *op) +{ + struct cqspi_st *cqspi = spi_master_get_devdata(mem->spi->master); + u8 dummy_incr, dummy_flag = 0, count, max_index, min_index; + u8 min_rxtap, max_rxtap, avg_index, max_tap, windowsize; + struct platform_device *pdev = cqspi->pdev; + struct cqspi_flash_pdata *f_pdata; + bool id_matched, rxtapfound; + u32 val, i, reg, txtap = 0; + s8 max_windowsize = -1; + int ret; + + f_pdata = &cqspi->f_pdata[mem->spi->chip_select]; + + reg = readl(cqspi->iobase + CQSPI_REG_CONFIG); + reg &= CQSPI_REG_CONFIG_ENABLE_MASK; + if (!reg) + return 0; + + if (cqspi->master_ref_clk_hz >= CQSPI_VERSAL_ECO_MIN_FREQ) + writel(1, cqspi->iobase + CQSPI_REG_VERSAL_ECO); + + /* Drive DLL reset bit to low */ + writel(0, cqspi->iobase + CQSPI_REG_VERSAL_PHY_CONFIG); + + /* Set initial delay value */ + writel(CQSPI_VERSAL_INIT_DLY, cqspi->iobase + CQSPI_REG_VERSAL_PHY_MASTER_CTRL); + + /* Set DLL reset bit */ + writel(CQSPI_REG_PHY_CONFIG_RESET_FLD_MASK, + cqspi->iobase + CQSPI_REG_VERSAL_PHY_CONFIG); + + /* Check for loopback lock */ + ret = cqspi_wait_for_bit(cqspi->iobase + CQSPI_REG_DLL_LOWER, + CQSPI_REG_DLL_LOWER_LPBK_LOCK_MASK, 0); + if (ret) { + dev_err(&pdev->dev, "Loopback lock bit error (%i)\n", ret); + return ret; + } + + /* Re-synchronize slave DLLs */ + writel(CQSPI_REG_PHY_CONFIG_RESET_FLD_MASK, cqspi->iobase + CQSPI_REG_VERSAL_PHY_CONFIG); + writel(CQSPI_REG_PHY_CONFIG_RESET_FLD_MASK | CQSPI_REG_PHY_CONFIG_RESYNC_FLD_MASK, + cqspi->iobase + CQSPI_REG_VERSAL_PHY_CONFIG); + + txtap = CQSPI_VERSAL_TX_TAP_MASTER << CQSPI_REG_PHY_CONFIG_TX_DLL_DLY_LSB; + max_tap = CQSPI_VERSAL_MAX_DLL_TAPS; + + for (dummy_incr = 0; dummy_incr <= 1; dummy_incr++) { + /* Update the extra dummy clocks required to read the ID */ + cqspi->extra_dummy_clks = dummy_incr; + rxtapfound = false; + min_rxtap = 0; + max_rxtap = 0; + max_index = 0; + min_index = 0; + + for (i = 0; i <= max_tap; i++) { + val = txtap | i | CQSPI_REG_PHY_CONFIG_RESET_FLD_MASK; + writel(val, cqspi->iobase + CQSPI_REG_VERSAL_PHY_CONFIG); + writel(val | CQSPI_REG_PHY_CONFIG_RESYNC_FLD_MASK, + cqspi->iobase + CQSPI_REG_VERSAL_PHY_CONFIG); + ret = cqspi_wait_for_bit(cqspi->iobase + CQSPI_REG_DLL_LOWER, + CQSPI_REG_DLL_LOWER_DLL_LOCK_MASK, 0); + if (ret) + return ret; + + /* + * To consider the tap as valid, make sure to read the Flash ID + * 10 times(recommended by IP design team). This makes the algorithm more + * robust and gives more confidence about the valid tap, this will also + * avoid getting the correct id by a fluke with a particular tap. + * In any one of the iteration if the Flash ID is not matches with the + * device_id, then that particular tap should not be considered as valid. + */ + count = 0; + do { + /* Execute the command and wait for the complete */ + ret = cqspi_command_read(f_pdata, op); + if (ret < 0) { + dev_err(&pdev->dev, + "error %d reading JEDEC ID\n", ret); + return ret; + } + + id_matched = true; + if (memcmp(mem->device_id, op->data.buf.in, op->data.nbytes)) { + id_matched = false; + break; + } + } while (id_matched && (count++ <= CQSPI_VERSAL_RDID_MAX_CNT)); + + if (id_matched) { + u8 current_rxtap = readl(cqspi->iobase + + CQSPI_REG_VERSAL_DLL_OBSVBLE_UPPER) & + CQSPI_REG_DLL_UPPER_RX_FLD_MASK; + + if (!rxtapfound) { + min_rxtap = current_rxtap; + min_index = i; + rxtapfound = true; + } + + max_rxtap = current_rxtap; + max_index = i; + } + + if (!rxtapfound) + continue; + + /* If ID doesn't match or reach the max tap, calculate the window size */ + if (!id_matched || i == max_tap) { + windowsize = max_rxtap - min_rxtap + 1; + if (windowsize > max_windowsize) { + dummy_flag = dummy_incr; + max_windowsize = windowsize; + avg_index = (max_index + min_index) / 2; + } + + rxtapfound = false; + if (windowsize >= CQSPI_VERSAL_MIN_WINDOW_SZ) + break; + } + } + } + + /* + * Look for minimum window size to ensure reliable data sampling even during drifts due + * to PVT, so that a drift either towards left or right can be well addressed. + */ + if (max_windowsize < CQSPI_VERSAL_MIN_WINDOW_SZ) + return -EINVAL; + + /* Update the extra dummy clocks based on the maximum window size */ + cqspi->extra_dummy_clks = dummy_flag; + + val = txtap | avg_index | CQSPI_REG_PHY_CONFIG_RESET_FLD_MASK; + writel(val, cqspi->iobase + CQSPI_REG_VERSAL_PHY_CONFIG); + writel((CQSPI_REG_PHY_CONFIG_RESYNC_FLD_MASK | val), + cqspi->iobase + CQSPI_REG_VERSAL_PHY_CONFIG); + + ret = cqspi_wait_for_bit(cqspi->iobase + CQSPI_REG_DLL_LOWER, + CQSPI_REG_DLL_LOWER_DLL_LOCK_MASK, 0); + if (ret) + return ret; + + cqspi->clk_tuned = true; + + return 0; +} + static void cqspi_chipselect(struct cqspi_flash_pdata *f_pdata) { struct cqspi_st *cqspi = f_pdata->cqspi; @@ -1345,11 +1535,21 @@ static ssize_t cqspi_read(struct cqspi_flash_pdata *f_pdata, static int cqspi_mem_process(struct spi_mem *mem, const struct spi_mem_op *op) { struct cqspi_st *cqspi = spi_master_get_devdata(mem->spi->master); + const struct cqspi_driver_platdata *ddata; + struct device *dev = &cqspi->pdev->dev; struct cqspi_flash_pdata *f_pdata; + ddata = of_device_get_match_data(dev); f_pdata = &cqspi->f_pdata[mem->spi->chip_select]; cqspi_configure(f_pdata, mem->spi->max_speed_hz); + if (op->cmd.dtr && ddata && ddata->execute_tuning && !cqspi->clk_tuned) { + int ret = ddata->execute_tuning(mem, op); + + if (ret) + return ret; + } + if (op->data.dir == SPI_MEM_DATA_IN && op->data.buf.in) { if (!op->addr.nbytes) return cqspi_command_read(f_pdata, op); @@ -1846,6 +2046,7 @@ static const struct cqspi_driver_platdata versal_ospi = { | CQSPI_HAS_PHY | CQSPI_HAS_DQS, .indirect_read_dma = cqspi_versal_indirect_read_dma, .get_dma_status = cqspi_get_versal_dma_status, + .execute_tuning = cqspi_versal_execute_tuning, }; static const struct of_device_id cqspi_dt_ids[] = {