]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
4.19-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 7 Aug 2021 08:21:20 +0000 (10:21 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 7 Aug 2021 08:21:20 +0000 (10:21 +0200)
added patches:
spi-mediatek-fix-fifo-transfer.patch

queue-4.19/revert-spi-mediatek-fix-fifo-rx-mode.patch [deleted file]
queue-4.19/series
queue-4.19/spi-mediatek-fix-fifo-transfer.patch [new file with mode: 0644]

diff --git a/queue-4.19/revert-spi-mediatek-fix-fifo-rx-mode.patch b/queue-4.19/revert-spi-mediatek-fix-fifo-rx-mode.patch
deleted file mode 100644 (file)
index 41acc07..0000000
+++ /dev/null
@@ -1,52 +0,0 @@
-From 568f12594bc88a1b8f9e697c9bf6a3a5b6b6d134 Mon Sep 17 00:00:00 2001
-From: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-Date: Thu, 5 Aug 2021 20:53:50 +0200
-Subject: Revert "spi: mediatek: fix fifo rx mode"
-
-From: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-
-This reverts commit bd0447f72de0963129612bf18202204d5b25e133 which is
-commit 3a70dd2d050331ee4cf5ad9d5c0a32d83ead9a43 upstream.
-
-It has been found to have problems.
-
-Reported-by: Guenter Roeck <linux@roeck-us.net>
-Cc: Peter Hess <peter.hess@ph-home.de>
-Cc: Frank Wunderlich <frank-w@public-files.de>
-Cc: Mark Brown <broonie@kernel.org>
-Cc: Sasha Levin <sashal@kernel.org>
-Link: https://lore.kernel.org/r/efee3a58-a4d2-af22-0931-e81b877ab539@roeck-us.net
-Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
----
- drivers/spi/spi-mt65xx.c |   16 +++-------------
- 1 file changed, 3 insertions(+), 13 deletions(-)
-
---- a/drivers/spi/spi-mt65xx.c
-+++ b/drivers/spi/spi-mt65xx.c
-@@ -392,23 +392,13 @@ static int mtk_spi_fifo_transfer(struct
-       mtk_spi_setup_packet(master);
-       cnt = xfer->len / 4;
--      if (xfer->tx_buf)
--              iowrite32_rep(mdata->base + SPI_TX_DATA_REG, xfer->tx_buf, cnt);
--
--      if (xfer->rx_buf)
--              ioread32_rep(mdata->base + SPI_RX_DATA_REG, xfer->rx_buf, cnt);
-+      iowrite32_rep(mdata->base + SPI_TX_DATA_REG, xfer->tx_buf, cnt);
-       remainder = xfer->len % 4;
-       if (remainder > 0) {
-               reg_val = 0;
--              if (xfer->tx_buf) {
--                      memcpy(&reg_val, xfer->tx_buf + (cnt * 4), remainder);
--                      writel(reg_val, mdata->base + SPI_TX_DATA_REG);
--              }
--              if (xfer->rx_buf) {
--                      reg_val = readl(mdata->base + SPI_RX_DATA_REG);
--                      memcpy(xfer->rx_buf + (cnt * 4), &reg_val, remainder);
--              }
-+              memcpy(&reg_val, xfer->tx_buf + (cnt * 4), remainder);
-+              writel(reg_val, mdata->base + SPI_TX_DATA_REG);
-       }
-       mtk_spi_enable_transfer(master);
index fe49cfee7ed09cb54af7f90dc928f26f04fcbc42..3d458b5d3d9116c7ef945880627808a9b5833d4d 100644 (file)
@@ -7,10 +7,10 @@ net-fix-zero-copy-head-len-calculation.patch
 bdi-move-bdi_dev_name-out-of-line.patch
 bdi-use-bdi_dev_name-to-get-device-name.patch
 bdi-add-a-dev_name-field-to-struct-backing_dev_info.patch
-revert-spi-mediatek-fix-fifo-rx-mode.patch
 revert-bluetooth-shutdown-controller-after-workqueues-are-flushed-or-cancelled.patch
 drm-i915-ensure-intel_engine_init_execlist-builds-with-clang.patch
 firmware-arm_scmi-ensure-drivers-provide-a-probe-function.patch
 revert-watchdog-itco_wdt-account-for-rebooting-on-second-timeout.patch
 padata-validate-cpumask-without-removed-cpu-during-offline.patch
 padata-add-separate-cpuhp-node-for-cpuhp_padata_dead.patch
+spi-mediatek-fix-fifo-transfer.patch
diff --git a/queue-4.19/spi-mediatek-fix-fifo-transfer.patch b/queue-4.19/spi-mediatek-fix-fifo-transfer.patch
new file mode 100644 (file)
index 0000000..ef41827
--- /dev/null
@@ -0,0 +1,68 @@
+From 0d5c3954b35eddff0da0436c31e8d721eceb7dc2 Mon Sep 17 00:00:00 2001
+From: Guenter Roeck <linux@roeck-us.net>
+Date: Sun, 1 Aug 2021 20:00:23 -0700
+Subject: spi: mediatek: Fix fifo transfer
+
+From: Guenter Roeck <linux@roeck-us.net>
+
+commit 0d5c3954b35eddff0da0436c31e8d721eceb7dc2 upstream.
+
+Commit 3a70dd2d0503 ("spi: mediatek: fix fifo rx mode") claims that
+fifo RX mode was never handled, and adds the presumably missing code
+to the FIFO transfer function. However, the claim that receive data
+was not handled is incorrect. It was handled as part of interrupt
+handling after the transfer was complete. The code added with the above
+mentioned commit reads data from the receive FIFO before the transfer
+is started, which is wrong. This results in an actual transfer error
+on a Hayato Chromebook.
+
+Remove the code trying to handle receive data before the transfer is
+started to fix the problem.
+
+Fixes: 3a70dd2d0503 ("spi: mediatek: fix fifo rx mode")
+Cc: Peter Hess <peter.hess@ph-home.de>
+Cc: Frank Wunderlich <frank-w@public-files.de>
+Cc: Tzung-Bi Shih <tzungbi@google.com>
+Cc: Hsin-Yi Wang <hsinyi@google.com>
+Signed-off-by: Guenter Roeck <linux@roeck-us.net>
+Tested-by: Hsin-Yi Wang <hsinyi@google.com>
+Tested-by: Tzung-Bi Shih <tzungbi@google.com>
+Link: https://lore.kernel.org/r/20210802030023.1748777-1-linux@roeck-us.net
+Signed-off-by: Mark Brown <broonie@kernel.org>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/spi/spi-mt65xx.c |   19 +++++--------------
+ 1 file changed, 5 insertions(+), 14 deletions(-)
+
+--- a/drivers/spi/spi-mt65xx.c
++++ b/drivers/spi/spi-mt65xx.c
+@@ -391,24 +391,15 @@ static int mtk_spi_fifo_transfer(struct
+       mtk_spi_prepare_transfer(master, xfer);
+       mtk_spi_setup_packet(master);
+-      cnt = xfer->len / 4;
+-      if (xfer->tx_buf)
++      if (xfer->tx_buf) {
++              cnt = xfer->len / 4;
+               iowrite32_rep(mdata->base + SPI_TX_DATA_REG, xfer->tx_buf, cnt);
+-
+-      if (xfer->rx_buf)
+-              ioread32_rep(mdata->base + SPI_RX_DATA_REG, xfer->rx_buf, cnt);
+-
+-      remainder = xfer->len % 4;
+-      if (remainder > 0) {
+-              reg_val = 0;
+-              if (xfer->tx_buf) {
++              remainder = xfer->len % 4;
++              if (remainder > 0) {
++                      reg_val = 0;
+                       memcpy(&reg_val, xfer->tx_buf + (cnt * 4), remainder);
+                       writel(reg_val, mdata->base + SPI_TX_DATA_REG);
+               }
+-              if (xfer->rx_buf) {
+-                      reg_val = readl(mdata->base + SPI_RX_DATA_REG);
+-                      memcpy(xfer->rx_buf + (cnt * 4), &reg_val, remainder);
+-              }
+       }
+       mtk_spi_enable_transfer(master);