Skip to content

Commit 4dbb5f6

Browse files
NXP-CarlosSongbroonie
authored andcommitted
spi: imx: add 16/32 bits per word support for target PIO mode
Enable 16/32 bits per word support for spi-imx target PIO mode. Signed-off-by: Carlos Song <carlos.song@nxp.com> Signed-off-by: Clark Wang <xiaoning.wang@nxp.com> Reviewed-by: Frank Li <Frank.Li@nxp.com> Link: https://patch.msgid.link/20251118065012.1418279-1-carlos.song@nxp.com Signed-off-by: Mark Brown <broonie@kernel.org>
1 parent f2fb3f7 commit 4dbb5f6

1 file changed

Lines changed: 19 additions & 2 deletions

File tree

drivers/spi/spi-imx.c

Lines changed: 19 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -425,8 +425,15 @@ static void spi_imx_buf_tx_swap(struct spi_imx_data *spi_imx)
425425

426426
static void mx53_ecspi_rx_target(struct spi_imx_data *spi_imx)
427427
{
428-
u32 val = ioread32be(spi_imx->base + MXC_CSPIRXDATA);
428+
u32 val = readl(spi_imx->base + MXC_CSPIRXDATA);
429+
#ifdef __LITTLE_ENDIAN
430+
unsigned int bytes_per_word = spi_imx_bytes_per_word(spi_imx->bits_per_word);
429431

432+
if (bytes_per_word == 1)
433+
swab32s(&val);
434+
else if (bytes_per_word == 2)
435+
swahw32s(&val);
436+
#endif
430437
if (spi_imx->rx_buf) {
431438
int n_bytes = spi_imx->target_burst % sizeof(val);
432439

@@ -447,6 +454,9 @@ static void mx53_ecspi_tx_target(struct spi_imx_data *spi_imx)
447454
{
448455
u32 val = 0;
449456
int n_bytes = spi_imx->count % sizeof(val);
457+
#ifdef __LITTLE_ENDIAN
458+
unsigned int bytes_per_word;
459+
#endif
450460

451461
if (!n_bytes)
452462
n_bytes = sizeof(val);
@@ -459,7 +469,14 @@ static void mx53_ecspi_tx_target(struct spi_imx_data *spi_imx)
459469

460470
spi_imx->count -= n_bytes;
461471

462-
iowrite32be(val, spi_imx->base + MXC_CSPITXDATA);
472+
#ifdef __LITTLE_ENDIAN
473+
bytes_per_word = spi_imx_bytes_per_word(spi_imx->bits_per_word);
474+
if (bytes_per_word == 1)
475+
swab32s(&val);
476+
else if (bytes_per_word == 2)
477+
swahw32s(&val);
478+
#endif
479+
writel(val, spi_imx->base + MXC_CSPITXDATA);
463480
}
464481

465482
/* MX51 eCSPI */

0 commit comments

Comments
 (0)