Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3071524imu; Sun, 27 Jan 2019 21:03:21 -0800 (PST) X-Google-Smtp-Source: ALg8bN6gmjuTpwqVGGXspW08W1L0otW5ro9I06WAScso/1hCJwkU8j7SBegZQAqXRdYA3IeuaJW7 X-Received: by 2002:a17:902:930b:: with SMTP id bc11mr20889692plb.17.1548651801561; Sun, 27 Jan 2019 21:03:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548651801; cv=none; d=google.com; s=arc-20160816; b=OBosgLGUPCxL/7p+S9q/C+wk4yvVo7cSGd9R0FGkcbaTFCL752TmJf2LL6cgNRrAUG RN3haQOX3w7YxSEzbbtXCBVsxp4Xs9pm8elAtF4aU2zEPTLXacw3z5/SIVqlCn0Oqzuj EYe4odYE8dGKgl4HFAVYchMRqFXYMG0c89LJvb3Tn6glafOLajcDcGaNkeCwjgbUteOW q4w8yufvuIHwkhykm0IzLnRZ+86OOOeCioChFADRNX4UIgQ781vuBeM5b3sd14sX1JDB x4s4heualmpTO419QkF1ocrukWN8CiDh1wHGhN3Yt7cTLLGcX7uQl/rRQlKRsHfcOHpE DyJw== 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=irrGKhQ1b5LeyInUBAuch6g8q54djEm4Xx9v6vgh0ps=; b=zpUpAuis7JJN80wHRTMGpATlWSZzxnaB6JhdKwWPg/bUcib4548V3ZWzbAN/N7hB6w JkDeY43OxjERpT8aXOMHwQihiA9DVAicXj4WoAOuU67eQd5gIGouNzgH0pH7amZyPtzp TjtTCTNLF8+hKukHQ3TgMZK+Xo/PXzTz128URwQimL7FVhLor1jkigd35/X9zlhluGfP oXWrDFYB1ZVCdRBdpbCsPM5MUdVw6vbWyRoLIkdKZzEMuG9DdyMBFFQyphULxH9dsN3U IbcAc8s+O+s7Eeb5e5Sq4SqZwwSCNkgIGLypEDDDTjylGlVETmimiALrK0YGw+fsfVB4 b7Cg== 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 w16si8877166plk.192.2019.01.27.21.03.06; Sun, 27 Jan 2019 21:03:21 -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 S1726779AbfA1FCd (ORCPT + 99 others); Mon, 28 Jan 2019 00:02:33 -0500 Received: from mga03.intel.com ([134.134.136.65]:45144 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726661AbfA1FCd (ORCPT ); Mon, 28 Jan 2019 00:02:33 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by orsmga103.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 27 Jan 2019 21:02:32 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.56,532,1539673200"; d="scan'208";a="141880827" Received: from unknown (HELO dev03.ndswc.sj.intel.com) ([10.233.132.114]) by fmsmga001.fm.intel.com with ESMTP; 27 Jan 2019 21:02:32 -0800 From: Purna Chandra Mandal To: Fred Bloggs , Boris Brezillon , Tudor Ambarus 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: Sun, 27 Jan 2019 21:02:29 -0800 Message-Id: <20190128050229.44965-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 written 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 | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/drivers/mtd/spi-nor/cadence-quadspi.c b/drivers/mtd/spi-nor/cadence-quadspi.c index 04cedd3a2bf6..7f78f9409ddd 100644 --- a/drivers/mtd/spi-nor/cadence-quadspi.c +++ b/drivers/mtd/spi-nor/cadence-quadspi.c @@ -418,9 +418,10 @@ static int cqspi_command_write(struct spi_nor *nor, const u8 opcode, void __iomem *reg_base = cqspi->iobase; unsigned int reg; unsigned int data; + u32 write_len; 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); @@ -433,10 +434,18 @@ static int cqspi_command_write(struct spi_nor *nor, const u8 opcode, reg |= ((n_tx - 1) & CQSPI_REG_CMDCTRL_WR_BYTES_MASK) << CQSPI_REG_CMDCTRL_WR_BYTES_LSB; data = 0; - memcpy(&data, txbuf, n_tx); + write_len = (n_tx > 4) ? 4 : n_tx; + memcpy(&data, txbuf, write_len); + txbuf += write_len; writel(data, reg_base + CQSPI_REG_CMDWRITEDATALOWER); - } + if (n_tx > 4) { + data = 0; + write_len = n_tx - 4; + memcpy(&data, txbuf, write_len); + writel(data, reg_base + CQSPI_REG_CMDWRITEDATAUPPER); + } + } ret = cqspi_exec_flash_cmd(cqspi, reg); return ret; } -- 2.13.0