mirror of
git://git.openwrt.org/openwrt/openwrt.git
synced 2024-12-13 18:34:53 +00:00
ath79: fix ar934x spi driver delays
Backport spi driver delay fixes from the 5.17-rc1 kernel. Signed-off-by: Oskari Lemmela <oskari@lemmela.net> [port also to kernel 5.15] Signed-off-by: Koen Vandeputte <koen.vandeputte@ncentric.com>
This commit is contained in:
parent
80f79beb95
commit
f8e65fecee
@ -0,0 +1,27 @@
|
|||||||
|
From c70282457c380db7deb57c81a6894debc8f88efa Mon Sep 17 00:00:00 2001
|
||||||
|
From: Oskari Lemmela <oskari@lemmela.net>
|
||||||
|
Date: Wed, 22 Dec 2021 07:59:58 +0200
|
||||||
|
Subject: [PATCH] spi: ar934x: fix transfer and word delays
|
||||||
|
|
||||||
|
Add missing delay between transferred messages and words.
|
||||||
|
|
||||||
|
Signed-off-by: Oskari Lemmela <oskari@lemmela.net>
|
||||||
|
Link: https://lore.kernel.org/r/20211222055958.1383233-3-oskari@lemmela.net
|
||||||
|
Signed-off-by: Mark Brown <broonie@kernel.org>
|
||||||
|
---
|
||||||
|
drivers/spi/spi-ar934x.c | 2 ++
|
||||||
|
1 file changed, 2 insertions(+)
|
||||||
|
|
||||||
|
--- a/drivers/spi/spi-ar934x.c
|
||||||
|
+++ b/drivers/spi/spi-ar934x.c
|
||||||
|
@@ -137,8 +137,10 @@ static int ar934x_spi_transfer_one_messa
|
||||||
|
reg >>= 8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
+ spi_delay_exec(&t->word_delay, t);
|
||||||
|
}
|
||||||
|
m->actual_length += t->len;
|
||||||
|
+ spi_transfer_delay_exec(t);
|
||||||
|
}
|
||||||
|
|
||||||
|
msg_done:
|
@ -0,0 +1,62 @@
|
|||||||
|
From ebe33e5a98dcf14a9630845f3f10c193584ac054 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Oskari Lemmela <oskari@lemmela.net>
|
||||||
|
Date: Wed, 22 Dec 2021 07:59:57 +0200
|
||||||
|
Subject: [PATCH] spi: ar934x: fix transfer size
|
||||||
|
|
||||||
|
If bits_per_word is configured, transfer only word amount
|
||||||
|
of data per iteration.
|
||||||
|
|
||||||
|
Signed-off-by: Oskari Lemmela <oskari@lemmela.net>
|
||||||
|
Link: https://lore.kernel.org/r/20211222055958.1383233-2-oskari@lemmela.net
|
||||||
|
Signed-off-by: Mark Brown <broonie@kernel.org>
|
||||||
|
---
|
||||||
|
drivers/spi/spi-ar934x.c | 16 +++++++++++-----
|
||||||
|
1 file changed, 11 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
|
--- a/drivers/spi/spi-ar934x.c
|
||||||
|
+++ b/drivers/spi/spi-ar934x.c
|
||||||
|
@@ -82,7 +82,7 @@ static int ar934x_spi_transfer_one_messa
|
||||||
|
struct spi_device *spi = m->spi;
|
||||||
|
unsigned long trx_done, trx_cur;
|
||||||
|
int stat = 0;
|
||||||
|
- u8 term = 0;
|
||||||
|
+ u8 bpw, term = 0;
|
||||||
|
int div, i;
|
||||||
|
u32 reg;
|
||||||
|
const u8 *tx_buf;
|
||||||
|
@@ -90,6 +90,11 @@ static int ar934x_spi_transfer_one_messa
|
||||||
|
|
||||||
|
m->actual_length = 0;
|
||||||
|
list_for_each_entry(t, &m->transfers, transfer_list) {
|
||||||
|
+ if (t->bits_per_word >= 8 && t->bits_per_word < 32)
|
||||||
|
+ bpw = t->bits_per_word >> 3;
|
||||||
|
+ else
|
||||||
|
+ bpw = 4;
|
||||||
|
+
|
||||||
|
if (t->speed_hz)
|
||||||
|
div = ar934x_spi_clk_div(sp, t->speed_hz);
|
||||||
|
else
|
||||||
|
@@ -105,10 +110,10 @@ static int ar934x_spi_transfer_one_messa
|
||||||
|
iowrite32(reg, sp->base + AR934X_SPI_REG_CTRL);
|
||||||
|
iowrite32(0, sp->base + AR934X_SPI_DATAOUT);
|
||||||
|
|
||||||
|
- for (trx_done = 0; trx_done < t->len; trx_done += 4) {
|
||||||
|
+ for (trx_done = 0; trx_done < t->len; trx_done += bpw) {
|
||||||
|
trx_cur = t->len - trx_done;
|
||||||
|
- if (trx_cur > 4)
|
||||||
|
- trx_cur = 4;
|
||||||
|
+ if (trx_cur > bpw)
|
||||||
|
+ trx_cur = bpw;
|
||||||
|
else if (list_is_last(&t->transfer_list, &m->transfers))
|
||||||
|
term = 1;
|
||||||
|
|
||||||
|
@@ -193,7 +198,8 @@ static int ar934x_spi_probe(struct platf
|
||||||
|
ctlr->mode_bits = SPI_LSB_FIRST;
|
||||||
|
ctlr->setup = ar934x_spi_setup;
|
||||||
|
ctlr->transfer_one_message = ar934x_spi_transfer_one_message;
|
||||||
|
- ctlr->bits_per_word_mask = SPI_BPW_MASK(8);
|
||||||
|
+ ctlr->bits_per_word_mask = SPI_BPW_MASK(32) | SPI_BPW_MASK(24) |
|
||||||
|
+ SPI_BPW_MASK(16) | SPI_BPW_MASK(8);
|
||||||
|
ctlr->dev.of_node = pdev->dev.of_node;
|
||||||
|
ctlr->num_chipselect = 3;
|
||||||
|
|
@ -0,0 +1,27 @@
|
|||||||
|
From c70282457c380db7deb57c81a6894debc8f88efa Mon Sep 17 00:00:00 2001
|
||||||
|
From: Oskari Lemmela <oskari@lemmela.net>
|
||||||
|
Date: Wed, 22 Dec 2021 07:59:58 +0200
|
||||||
|
Subject: [PATCH] spi: ar934x: fix transfer and word delays
|
||||||
|
|
||||||
|
Add missing delay between transferred messages and words.
|
||||||
|
|
||||||
|
Signed-off-by: Oskari Lemmela <oskari@lemmela.net>
|
||||||
|
Link: https://lore.kernel.org/r/20211222055958.1383233-3-oskari@lemmela.net
|
||||||
|
Signed-off-by: Mark Brown <broonie@kernel.org>
|
||||||
|
---
|
||||||
|
drivers/spi/spi-ar934x.c | 2 ++
|
||||||
|
1 file changed, 2 insertions(+)
|
||||||
|
|
||||||
|
--- a/drivers/spi/spi-ar934x.c
|
||||||
|
+++ b/drivers/spi/spi-ar934x.c
|
||||||
|
@@ -137,8 +137,10 @@ static int ar934x_spi_transfer_one_messa
|
||||||
|
reg >>= 8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
+ spi_delay_exec(&t->word_delay, t);
|
||||||
|
}
|
||||||
|
m->actual_length += t->len;
|
||||||
|
+ spi_transfer_delay_exec(t);
|
||||||
|
}
|
||||||
|
|
||||||
|
msg_done:
|
@ -0,0 +1,62 @@
|
|||||||
|
From ebe33e5a98dcf14a9630845f3f10c193584ac054 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Oskari Lemmela <oskari@lemmela.net>
|
||||||
|
Date: Wed, 22 Dec 2021 07:59:57 +0200
|
||||||
|
Subject: [PATCH] spi: ar934x: fix transfer size
|
||||||
|
|
||||||
|
If bits_per_word is configured, transfer only word amount
|
||||||
|
of data per iteration.
|
||||||
|
|
||||||
|
Signed-off-by: Oskari Lemmela <oskari@lemmela.net>
|
||||||
|
Link: https://lore.kernel.org/r/20211222055958.1383233-2-oskari@lemmela.net
|
||||||
|
Signed-off-by: Mark Brown <broonie@kernel.org>
|
||||||
|
---
|
||||||
|
drivers/spi/spi-ar934x.c | 16 +++++++++++-----
|
||||||
|
1 file changed, 11 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
|
--- a/drivers/spi/spi-ar934x.c
|
||||||
|
+++ b/drivers/spi/spi-ar934x.c
|
||||||
|
@@ -82,7 +82,7 @@ static int ar934x_spi_transfer_one_messa
|
||||||
|
struct spi_device *spi = m->spi;
|
||||||
|
unsigned long trx_done, trx_cur;
|
||||||
|
int stat = 0;
|
||||||
|
- u8 term = 0;
|
||||||
|
+ u8 bpw, term = 0;
|
||||||
|
int div, i;
|
||||||
|
u32 reg;
|
||||||
|
const u8 *tx_buf;
|
||||||
|
@@ -90,6 +90,11 @@ static int ar934x_spi_transfer_one_messa
|
||||||
|
|
||||||
|
m->actual_length = 0;
|
||||||
|
list_for_each_entry(t, &m->transfers, transfer_list) {
|
||||||
|
+ if (t->bits_per_word >= 8 && t->bits_per_word < 32)
|
||||||
|
+ bpw = t->bits_per_word >> 3;
|
||||||
|
+ else
|
||||||
|
+ bpw = 4;
|
||||||
|
+
|
||||||
|
if (t->speed_hz)
|
||||||
|
div = ar934x_spi_clk_div(sp, t->speed_hz);
|
||||||
|
else
|
||||||
|
@@ -105,10 +110,10 @@ static int ar934x_spi_transfer_one_messa
|
||||||
|
iowrite32(reg, sp->base + AR934X_SPI_REG_CTRL);
|
||||||
|
iowrite32(0, sp->base + AR934X_SPI_DATAOUT);
|
||||||
|
|
||||||
|
- for (trx_done = 0; trx_done < t->len; trx_done += 4) {
|
||||||
|
+ for (trx_done = 0; trx_done < t->len; trx_done += bpw) {
|
||||||
|
trx_cur = t->len - trx_done;
|
||||||
|
- if (trx_cur > 4)
|
||||||
|
- trx_cur = 4;
|
||||||
|
+ if (trx_cur > bpw)
|
||||||
|
+ trx_cur = bpw;
|
||||||
|
else if (list_is_last(&t->transfer_list, &m->transfers))
|
||||||
|
term = 1;
|
||||||
|
|
||||||
|
@@ -193,7 +198,8 @@ static int ar934x_spi_probe(struct platf
|
||||||
|
ctlr->mode_bits = SPI_LSB_FIRST;
|
||||||
|
ctlr->setup = ar934x_spi_setup;
|
||||||
|
ctlr->transfer_one_message = ar934x_spi_transfer_one_message;
|
||||||
|
- ctlr->bits_per_word_mask = SPI_BPW_MASK(8);
|
||||||
|
+ ctlr->bits_per_word_mask = SPI_BPW_MASK(32) | SPI_BPW_MASK(24) |
|
||||||
|
+ SPI_BPW_MASK(16) | SPI_BPW_MASK(8);
|
||||||
|
ctlr->dev.of_node = pdev->dev.of_node;
|
||||||
|
ctlr->num_chipselect = 3;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user