Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp514234pxb; Thu, 31 Mar 2022 10:25:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxKygVJsMHI3eTSMW4wPGoyZjRWF3BSvWq2RvJRVW+fZ5lBDUSjH60LrhYe3l2pp1DzKxzo X-Received: by 2002:a05:6402:2216:b0:419:25d2:3652 with SMTP id cq22-20020a056402221600b0041925d23652mr17213514edb.277.1648747530662; Thu, 31 Mar 2022 10:25:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1648747530; cv=none; d=google.com; s=arc-20160816; b=s/+X4AIbQwZWrx04sDDNg/vjzLKWClxunOfBEMf8kacUtqIvWxnjQHc+AbQ+WySSt0 S+/06ocPob7kKg9zYP+0T13Hg7y7t05yac8Er0JUvtgfH6tHnKxHdXJrHbMgpioy13GU iFtoluwGCMsEfaCTvspgx+uKUkNXYy+BQjWHg/MBiMqJI2qj8zicZyZvaL6Ql+yk+DT4 zW4UcWJtWpzpiB5wrZVuM0UVQf9uRpmRuRmaVvf9esNiPvD0hu6MSek4yIYKBbVp0b4c bkGE8quvkRsxFV3x9E3QkFO0x6vfyqn/gXOOkqKWmqIcIcoH6ZZtMwIK8KeCMAEPQktu rmtg== 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 :message-id:date:subject:cc:to:from:dkim-signature:dkim-signature; bh=02Kh2G2tw1qOTPyK+LDa8jdNbMtL/fx3qG1NfJSeKik=; b=PQ7J31kvEyoetMN87iacM4lhimswx0vjPKqAZrAWENEAFa23pZUU/CWLCQPJXrN3ry abdpPysTbGcTXpjhC1WcQne5smSK8J7L2inHVJ5k85XDFA/dWjXytPems1liBJyhSGZP fwFjgJy3WQFTf6WFYfTBDB3RyanitgLyfXXNd8UcltvtOOhwG94asLU8N/2bI6vzvor1 Qsv5rGgCfovnFo2GBKKJ6htlKMlYhCd3Pd7VPor57/fNdjsJs+ymjN1r1fyU80D3JQPS WoluXFyH7I+osbgx5HSpTo3MOmO1uN9jCGk5OFEFEtnMq3CTU6YlUR6TgNnEHak/0i2D YvPw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@tq-group.com header.s=key1 header.b=C+MSWkbD; dkim=pass header.i=@tq-group.com header.s=key1 header.b=fmGDfhDW; 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=NONE sp=NONE dis=NONE) header.from=tq-group.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id c11-20020a17090603cb00b006dfe60916bcsi88417eja.663.2022.03.31.10.25.02; Thu, 31 Mar 2022 10:25:30 -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=@tq-group.com header.s=key1 header.b=C+MSWkbD; dkim=pass header.i=@tq-group.com header.s=key1 header.b=fmGDfhDW; 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=NONE sp=NONE dis=NONE) header.from=tq-group.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234003AbiCaLKl (ORCPT + 99 others); Thu, 31 Mar 2022 07:10:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58146 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234928AbiCaLKk (ORCPT ); Thu, 31 Mar 2022 07:10:40 -0400 Received: from mx1.tq-group.com (mx1.tq-group.com [93.104.207.81]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 526711CFE3; Thu, 31 Mar 2022 04:08:50 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=tq-group.com; i=@tq-group.com; q=dns/txt; s=key1; t=1648724932; x=1680260932; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=02Kh2G2tw1qOTPyK+LDa8jdNbMtL/fx3qG1NfJSeKik=; b=C+MSWkbDRQIFHYsHi8HHf7bWZ/W2J+R/cZCGJ1udCzC5P3D+gduqlzcl rhs0ExPfmz/Kn2D7R7T8diu556l4AadhI7TJNzCcnS0iHudKPhQjoDAu2 ZbVdo2yj/Lbdo70Mam/nRJA482EjBAGfvFkfZCarUXSFvtN15vMau2C8/ 488g/cvNtQCAiuFHaaTwecZupsO9oxVnt5/ehY2UofGqWi0LV+WkO9082 EdrITuD49/zIH35mmGsoIUdMtdkEF8zGkl951gG/0Fad1ewalOSwu4PiU KphoPxzCgQ+laM6HEkFsYp4tafGj8bYSUHeQyvxWpS5PjOlB7o6VsJaLA Q==; X-IronPort-AV: E=Sophos;i="5.90,225,1643670000"; d="scan'208";a="23014419" Received: from unknown (HELO tq-pgp-pr1.tq-net.de) ([192.168.6.15]) by mx1-pgp.tq-group.com with ESMTP; 31 Mar 2022 13:08:49 +0200 Received: from mx1.tq-group.com ([192.168.6.7]) by tq-pgp-pr1.tq-net.de (PGP Universal service); Thu, 31 Mar 2022 13:08:49 +0200 X-PGP-Universal: processed; by tq-pgp-pr1.tq-net.de on Thu, 31 Mar 2022 13:08:49 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=tq-group.com; i=@tq-group.com; q=dns/txt; s=key1; t=1648724929; x=1680260929; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=02Kh2G2tw1qOTPyK+LDa8jdNbMtL/fx3qG1NfJSeKik=; b=fmGDfhDW0ykWnC7EMETyE0ONjdB22ZxXonzMJubQHsqbMHpk/5+KGEjs ias1KCg4lel6V2JyEFjjBQo8zp6J2d6un/gCav8QR3thg0wszxYikDcit ikBSk2liQSWDtfqfX7C+gHycepq0aigDXduiGPGxv13LMl/lpsEZjSUCA 2mi+QnzG77wBXsU0aDsUn+ULyJX2RwJeepBgf22tvjtoBNaKlY9R5ktK3 qpFEBL4PtM2/W7OVFNL52QmUXQvoBYQYIW2Ulm9PrXICwCc5vzoNffHkt 0ip+ZITy+AW3/CsllFW6MH3zkw833S4oS6iWaDVrZCsXy50gS7dqpQLsL A==; X-IronPort-AV: E=Sophos;i="5.90,225,1643670000"; d="scan'208";a="23014418" Received: from vtuxmail01.tq-net.de ([10.115.0.20]) by mx1.tq-group.com with ESMTP; 31 Mar 2022 13:08:49 +0200 Received: from localhost.localdomain (SCHIFFERM-M2.tq-net.de [10.121.49.14]) by vtuxmail01.tq-net.de (Postfix) with ESMTPA id 0D494280065; Thu, 31 Mar 2022 13:08:49 +0200 (CEST) From: Matthias Schiffer To: Mark Brown Cc: Tudor Ambarus , Vignesh Raghavendra , Ramuthevar Vadivel Murugan , linux-spi@vger.kernel.org, linux-kernel@vger.kernel.org, Matthias Schiffer Subject: [PATCH] spi: cadence-quadspi: fix protocol setup for non-1-1-X operations Date: Thu, 31 Mar 2022 13:08:19 +0200 Message-Id: <20220331110819.133392-1-matthias.schiffer@ew.tq-group.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 cqspi_set_protocol() only set the data width, but ignored the command and address width (except for 8-8-8 DTR ops), leading to corruption of all transfers using 1-X-X or X-X-X ops. Fix by setting the other two widths as well. While we're at it, simplify the code a bit by replacing the CQSPI_INST_TYPE_* constants with ilog2(). Tested on a TI AM64x with a Macronix MX25U51245G QSPI flash with 1-4-4 read and write operations. Fixes: a314f6367787 ("mtd: spi-nor: Convert cadence-quadspi to use spi-mem framework") Signed-off-by: Matthias Schiffer --- drivers/spi/spi-cadence-quadspi.c | 46 ++++++++----------------------- 1 file changed, 12 insertions(+), 34 deletions(-) diff --git a/drivers/spi/spi-cadence-quadspi.c b/drivers/spi/spi-cadence-quadspi.c index b0c9f62ccefb..616ada891974 100644 --- a/drivers/spi/spi-cadence-quadspi.c +++ b/drivers/spi/spi-cadence-quadspi.c @@ -19,6 +19,7 @@ #include #include #include +#include #include #include #include @@ -102,12 +103,6 @@ struct cqspi_driver_platdata { #define CQSPI_TIMEOUT_MS 500 #define CQSPI_READ_TIMEOUT_MS 10 -/* Instruction type */ -#define CQSPI_INST_TYPE_SINGLE 0 -#define CQSPI_INST_TYPE_DUAL 1 -#define CQSPI_INST_TYPE_QUAD 2 -#define CQSPI_INST_TYPE_OCTAL 3 - #define CQSPI_DUMMY_CLKS_PER_BYTE 8 #define CQSPI_DUMMY_BYTES_MAX 4 #define CQSPI_DUMMY_CLKS_MAX 31 @@ -376,10 +371,6 @@ static unsigned int cqspi_calc_dummy(const struct spi_mem_op *op, bool dtr) static int cqspi_set_protocol(struct cqspi_flash_pdata *f_pdata, const struct spi_mem_op *op) { - f_pdata->inst_width = CQSPI_INST_TYPE_SINGLE; - f_pdata->addr_width = CQSPI_INST_TYPE_SINGLE; - f_pdata->data_width = CQSPI_INST_TYPE_SINGLE; - /* * For an op to be DTR, cmd phase along with every other non-empty * phase should have dtr field set to 1. If an op phase has zero @@ -389,32 +380,23 @@ static int cqspi_set_protocol(struct cqspi_flash_pdata *f_pdata, (!op->addr.nbytes || op->addr.dtr) && (!op->data.nbytes || op->data.dtr); - switch (op->data.buswidth) { - case 0: - break; - case 1: - f_pdata->data_width = CQSPI_INST_TYPE_SINGLE; - break; - case 2: - f_pdata->data_width = CQSPI_INST_TYPE_DUAL; - break; - case 4: - f_pdata->data_width = CQSPI_INST_TYPE_QUAD; - break; - case 8: - f_pdata->data_width = CQSPI_INST_TYPE_OCTAL; - break; - default: - return -EINVAL; - } + f_pdata->inst_width = 0; + if (op->cmd.buswidth) + f_pdata->inst_width = ilog2(op->cmd.buswidth); + + f_pdata->addr_width = 0; + if (op->addr.buswidth) + f_pdata->addr_width = ilog2(op->addr.buswidth); + + f_pdata->data_width = 0; + if (op->data.buswidth) + f_pdata->data_width = ilog2(op->data.buswidth); /* Right now we only support 8-8-8 DTR mode. */ if (f_pdata->dtr) { switch (op->cmd.buswidth) { case 0: - break; case 8: - f_pdata->inst_width = CQSPI_INST_TYPE_OCTAL; break; default: return -EINVAL; @@ -422,9 +404,7 @@ static int cqspi_set_protocol(struct cqspi_flash_pdata *f_pdata, switch (op->addr.buswidth) { case 0: - break; case 8: - f_pdata->addr_width = CQSPI_INST_TYPE_OCTAL; break; default: return -EINVAL; @@ -432,9 +412,7 @@ static int cqspi_set_protocol(struct cqspi_flash_pdata *f_pdata, switch (op->data.buswidth) { case 0: - break; case 8: - f_pdata->data_width = CQSPI_INST_TYPE_OCTAL; break; default: return -EINVAL; -- 2.25.1