Commit 43f173e7 authored by Mika Westerberg's avatar Mika Westerberg Committed by Mark Brown

spi: intel: Take possible chip address into account in intel_spi_read/write_reg()

The SPI-NOR operation can have non-zero chip address as well so take
this into account in intel_spi_read/write_reg().
Signed-off-by: default avatarMika Westerberg <mika.westerberg@linux.intel.com>
Link: https://lore.kernel.org/r/20221025064623.22808-4-mika.westerberg@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 8a9a784f
...@@ -457,11 +457,12 @@ static int intel_spi_read_reg(struct intel_spi *ispi, const struct spi_mem *mem, ...@@ -457,11 +457,12 @@ static int intel_spi_read_reg(struct intel_spi *ispi, const struct spi_mem *mem,
const struct intel_spi_mem_op *iop, const struct intel_spi_mem_op *iop,
const struct spi_mem_op *op) const struct spi_mem_op *op)
{ {
u32 addr = intel_spi_chip_addr(ispi, mem) + op->addr.val;
size_t nbytes = op->data.nbytes; size_t nbytes = op->data.nbytes;
u8 opcode = op->cmd.opcode; u8 opcode = op->cmd.opcode;
int ret; int ret;
writel(intel_spi_chip_addr(ispi, mem), ispi->base + FADDR); writel(addr, ispi->base + FADDR);
if (ispi->swseq_reg) if (ispi->swseq_reg)
ret = intel_spi_sw_cycle(ispi, opcode, nbytes, ret = intel_spi_sw_cycle(ispi, opcode, nbytes,
...@@ -479,6 +480,7 @@ static int intel_spi_write_reg(struct intel_spi *ispi, const struct spi_mem *mem ...@@ -479,6 +480,7 @@ static int intel_spi_write_reg(struct intel_spi *ispi, const struct spi_mem *mem
const struct intel_spi_mem_op *iop, const struct intel_spi_mem_op *iop,
const struct spi_mem_op *op) const struct spi_mem_op *op)
{ {
u32 addr = intel_spi_chip_addr(ispi, mem) + op->addr.val;
size_t nbytes = op->data.nbytes; size_t nbytes = op->data.nbytes;
u8 opcode = op->cmd.opcode; u8 opcode = op->cmd.opcode;
int ret; int ret;
...@@ -522,7 +524,7 @@ static int intel_spi_write_reg(struct intel_spi *ispi, const struct spi_mem *mem ...@@ -522,7 +524,7 @@ static int intel_spi_write_reg(struct intel_spi *ispi, const struct spi_mem *mem
if (opcode == SPINOR_OP_WRDI) if (opcode == SPINOR_OP_WRDI)
return 0; return 0;
writel(intel_spi_chip_addr(ispi, mem), ispi->base + FADDR); writel(addr, ispi->base + FADDR);
/* Write the value beforehand */ /* Write the value beforehand */
ret = intel_spi_write_block(ispi, op->data.buf.out, nbytes); ret = intel_spi_write_block(ispi, op->data.buf.out, nbytes);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment