Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1563393imu; Thu, 13 Dec 2018 18:17:37 -0800 (PST) X-Google-Smtp-Source: AFSGD/WrRxuhwAzkFuqPBTGbW+gsyCupejAv2ZlZSY3TmIDCeaTRmwqI5os1XJkUzZigkhIsQO92 X-Received: by 2002:a63:e302:: with SMTP id f2mr1132753pgh.320.1544753857934; Thu, 13 Dec 2018 18:17:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544753857; cv=none; d=google.com; s=arc-20160816; b=NnQJ3j5x8JgVAYdzp7ogL7a+6F0x2lsLwwB3O/0D2oxsGLcsflXVRSTHYHuIKyWMnW CwykkK5PMQjmJs5o8rK/kVtFH/p2Rscv5HPo+QLzGhU4c6YP4qxhnW8sRv8pJ8uKAT3e FfmFTG/eBhoplxWZlr4ZNqqUK4eisTuU4CkF0DUZxbUOJxIEb9Bv11b6S41qfynzFWfK 2B2VPdJNxSUilLfQrYkyU5A2DNC/1kpDHo8b/TM+jm4nCmDQ03l9k3ha78kYGaJV8Iba XTUMEaeePjYs9ocCpaLfBX1jDlpeHAmyS0bVN47rkDNu8O4vuxCWc4F2aFe7uywWsQaO kd6Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=24U5AA2NyL1qUKjDdhs5mQjQ9SctjNHuhbOWqgLOAFM=; b=TUbrVxe8V6e3DeXfED+e6KjVMx+DHACDRZQLnNcpmF66AyAtoweEFnjuTWns98EJWu kAIS+GFzMJQcUZ5aK5KwrZJtame73k8228UZOwYiRYkILHt240p5d2Fd8hrANNi6rf1V jCZ7vqvfSRuTUUcQ65C+OYgISMdAfVuRAmjT2rx/LAKJY9/fXRBryS3WWbF2nv+6PQBJ SOvG4YjWIcA0FRL5Bhv3PYpvPVnnSTqj/r5obcJi4PPB0eMjZJaXDBMbg/xI5KwrtxHk EHCjsq1ZPUhePDGnGBjCacrmfOMGlO62156v8+vEe2+dRM9KtjExXwhucTNCQ/az6o2w 4Slw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d8si3084581pln.128.2018.12.13.18.17.22; Thu, 13 Dec 2018 18:17:37 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728998AbeLNCP1 (ORCPT + 99 others); Thu, 13 Dec 2018 21:15:27 -0500 Received: from mga12.intel.com ([192.55.52.136]:22645 "EHLO mga12.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727901AbeLNCP0 (ORCPT ); Thu, 13 Dec 2018 21:15:26 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by fmsmga106.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 13 Dec 2018 18:15:26 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.56,351,1539673200"; d="scan'208";a="118451011" Received: from unknown (HELO dev03.ndswc.sj.intel.com) ([10.233.132.114]) by FMSMGA003.fm.intel.com with ESMTP; 13 Dec 2018 18:15:26 -0800 From: Purna Chandra Mandal To: Fred Bloggs , Boris Brezillon Cc: Purna Chandra Mandal , linux-kernel@vger.kernel.org, Marek Vasut , Brian Norris , Richard Weinberger , linux-mtd@lists.infradead.org, David Woodhouse Subject: [PATCH] mtd: spi-nor: cadence-quadspi: write upto 8-bytes data in STIG mode Date: Thu, 13 Dec 2018 18:15:16 -0800 Message-Id: <20181214021516.43609-1-purna.chandra.mandal@intel.com> X-Mailer: git-send-email 2.13.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org cadence-quadspi controller allows upto eight bytes of data to be transferred in software Triggered Instruction generator (STIG) mode of operation. Lower 4 bytes are written through writedatalower and upper 4 bytes by writedataupper register. This patch allows all the 8 bytes to be written. Signed-off-by: Purna Chandra Mandal --- drivers/mtd/spi-nor/cadence-quadspi.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/drivers/mtd/spi-nor/cadence-quadspi.c b/drivers/mtd/spi-nor/cadence-quadspi.c index 04cedd3a2bf6..990934387fea 100644 --- a/drivers/mtd/spi-nor/cadence-quadspi.c +++ b/drivers/mtd/spi-nor/cadence-quadspi.c @@ -420,7 +420,7 @@ static int cqspi_command_write(struct spi_nor *nor, const u8 opcode, unsigned int data; int ret; - if (n_tx > 4 || (n_tx && !txbuf)) { + if (n_tx > CQSPI_STIG_DATA_LEN_MAX || (n_tx && !txbuf)) { dev_err(nor->dev, "Invalid input argument, cmdlen %d txbuf 0x%p\n", n_tx, txbuf); @@ -435,8 +435,13 @@ static int cqspi_command_write(struct spi_nor *nor, const u8 opcode, data = 0; memcpy(&data, txbuf, n_tx); writel(data, reg_base + CQSPI_REG_CMDWRITEDATALOWER); - } + if (n_tx > 4) { + data = 0; + memcpy(&data, txbuf + 4, n_tx - 4); + writel(data, reg_base + CQSPI_REG_CMDWRITEDATAUPPER); + } + } ret = cqspi_exec_flash_cmd(cqspi, reg); return ret; } -- 2.13.0