lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20221124073957.22471-2-jaimeliao.tw@gmail.com>
Date:   Thu, 24 Nov 2022 15:39:56 +0800
From:   JaimeLiao <jaimeliao.tw@...il.com>
To:     broonie@...nel.org, krzysztof.kozlowski@...aro.org,
        linux-spi@...r.kernel.org, linux-kernel@...r.kernel.org
Cc:     jaimeliao@...c.com.tw, JaimeLiao <jaimeliao.tw@...il.com>
Subject: [PATCH v1 1/2] spi: spi-rpc-if: Add support for Octal DTR mode

Add Octal DTR mode support

Signed-off-by: JaimeLiao <jaimeliao.tw@...il.com>
---
 drivers/spi/spi-rpc-if.c | 19 ++++++++++++++++---
 1 file changed, 16 insertions(+), 3 deletions(-)

diff --git a/drivers/spi/spi-rpc-if.c b/drivers/spi/spi-rpc-if.c
index 24ec1c83f379..f2c365c10610 100644
--- a/drivers/spi/spi-rpc-if.c
+++ b/drivers/spi/spi-rpc-if.c
@@ -26,10 +26,20 @@ static void rpcif_spi_mem_prepare(struct spi_device *spi_dev,
 	rpc_op.cmd.opcode = spi_op->cmd.opcode;
 	rpc_op.cmd.buswidth = spi_op->cmd.buswidth;
 
+	if (spi_op->cmd.dtr) {
+		rpc_op.cmd.opcode = spi_op->cmd.opcode >> 8;
+		rpc_op.ocmd.opcode = spi_op->cmd.opcode;
+		rpc_op.ocmd.buswidth = spi_op->cmd.buswidth;
+		rpc_op.cmd.ddr = spi_op->cmd.dtr;
+		rpc_op.ocmd.ddr = spi_op->cmd.dtr;
+	}
+
 	if (spi_op->addr.nbytes) {
 		rpc_op.addr.buswidth = spi_op->addr.buswidth;
 		rpc_op.addr.nbytes = spi_op->addr.nbytes;
 		rpc_op.addr.val = spi_op->addr.val;
+		if (spi_op->addr.dtr)
+			rpc_op.addr.ddr = spi_op->addr.dtr;
 	}
 
 	if (spi_op->dummy.nbytes) {
@@ -41,6 +51,8 @@ static void rpcif_spi_mem_prepare(struct spi_device *spi_dev,
 	if (spi_op->data.nbytes || (offs && len)) {
 		rpc_op.data.buswidth = spi_op->data.buswidth;
 		rpc_op.data.nbytes = spi_op->data.nbytes;
+		if (spi_op->data.dtr)
+			rpc_op.data.ddr = spi_op->data.dtr;
 		switch (spi_op->data.dir) {
 		case SPI_MEM_DATA_IN:
 			rpc_op.data.dir = RPCIF_DATA_IN;
@@ -67,8 +79,8 @@ static bool rpcif_spi_mem_supports_op(struct spi_mem *mem,
 	if (!spi_mem_default_supports_op(mem, op))
 		return false;
 
-	if (op->data.buswidth > 4 || op->addr.buswidth > 4 ||
-	    op->dummy.buswidth > 4 || op->cmd.buswidth > 4 ||
+	if (op->data.buswidth > 8 || op->addr.buswidth > 8 ||
+	    op->dummy.buswidth > 8 || op->cmd.buswidth > 8 ||
 	    op->addr.nbytes > 4)
 		return false;
 
@@ -153,7 +165,8 @@ static int rpcif_spi_probe(struct platform_device *pdev)
 	ctlr->mem_ops = &rpcif_spi_mem_ops;
 
 	ctlr->bits_per_word_mask = SPI_BPW_MASK(8);
-	ctlr->mode_bits = SPI_CPOL | SPI_CPHA | SPI_TX_QUAD | SPI_RX_QUAD;
+	ctlr->mode_bits = SPI_CPOL | SPI_CPHA | SPI_TX_QUAD | SPI_RX_QUAD |
+			  SPI_TX_OCTAL | SPI_RX_OCTAL;
 	ctlr->flags = SPI_CONTROLLER_HALF_DUPLEX;
 
 	error = rpcif_hw_init(rpc, false);
-- 
2.17.1

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ