@@ -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);
Add Octal DTR mode support Signed-off-by: JaimeLiao <jaimeliao.tw@gmail.com> --- drivers/spi/spi-rpc-if.c | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-)