Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion drivers/spi/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -818,7 +818,7 @@ config SPI_PHYTIUM_PCI

config SPI_PHYTIUM_QSPI
tristate "Phytium Quad SPI controller"
depends on ARCH_PHYTIUM || COMPILE_TEST
depends on ARCH_PHYTIUM && COMPILE_TEST
depends on OF
depends on SPI_MEM
help
Expand Down
12 changes: 6 additions & 6 deletions drivers/spi/spi-phytium-qspi.c
Original file line number Diff line number Diff line change
Expand Up @@ -181,8 +181,8 @@ struct phytium_qspi {
u8 fnum;
bool nodirmap;

u32 wr_cfg_reg;
u32 rd_cfg_reg;
u32 wr_cfg_reg[PHYTIUM_QSPI_MAX_NORCHIP];
u32 rd_cfg_reg[PHYTIUM_QSPI_MAX_NORCHIP];
u32 flash_cap;
};

Expand Down Expand Up @@ -538,7 +538,7 @@ static int phytium_qspi_dirmap_create(struct spi_mem_dirmap_desc *desc)
cmd |= flash->clk_div & QSPI_RD_CFG_RD_SCK_SEL_MASK;

writel_relaxed(cmd, qspi->io_base + QSPI_RD_CFG_REG);
qspi->rd_cfg_reg = cmd;
qspi->rd_cfg_reg[spi->chip_select] = cmd;

dev_dbg(qspi->dev, "Create read dirmap and setup RD_CFG_REG [%#x].\n", cmd);
} else if (desc->info.op_tmpl.data.dir == SPI_MEM_DATA_OUT) {
Expand All @@ -555,7 +555,7 @@ static int phytium_qspi_dirmap_create(struct spi_mem_dirmap_desc *desc)

cmd |= QSPI_WR_CFG_WR_MODE_MASK;
cmd |= flash->clk_div & QSPI_WR_CFG_WR_SCK_SEL_MASK;
qspi->wr_cfg_reg = cmd;
qspi->wr_cfg_reg[spi->chip_select] = cmd;
} else {
ret = -EINVAL;
}
Expand All @@ -574,6 +574,7 @@ static ssize_t phytium_qspi_dirmap_read(struct spi_mem_dirmap_desc *desc,
void __iomem *src = flash->base + offs;
u8 *buf_rx = buf;

writel_relaxed(qspi->rd_cfg_reg[spi->chip_select], qspi->io_base + QSPI_RD_CFG_REG);
memcpy_fromio(buf_rx, src, len);

return len;
Expand All @@ -593,7 +594,7 @@ static ssize_t phytium_qspi_dirmap_write(struct spi_mem_dirmap_desc *desc,
u_char tmp[4] = {0};

/* set wr_cfg for drimap write */
writel_relaxed(qspi->wr_cfg_reg, qspi->io_base + QSPI_WR_CFG_REG);
writel_relaxed(qspi->wr_cfg_reg[spi->chip_select], qspi->io_base + QSPI_WR_CFG_REG);

if (offs & 0x03) {
dev_err(qspi->dev, "Addr not four-byte aligned!\n");
Expand Down Expand Up @@ -889,7 +890,6 @@ static int __maybe_unused phytium_qspi_resume(struct device *dev)

if (!qspi->nodirmap) {
/* set rd_cfg reg and flash_capacity reg after resume */
writel_relaxed(qspi->rd_cfg_reg, qspi->io_base + QSPI_RD_CFG_REG);
writel_relaxed(qspi->flash_cap, qspi->io_base + QSPI_FLASH_CAP_REG);
} else {
writel_relaxed(WR_CFG_NODIR_VALUE, qspi->io_base + QSPI_WR_CFG_REG);
Expand Down
Loading