mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-10 11:09:57 +08:00
ath79: restore pin state on probe for ar934x-spi
If bootloader doesn't terminate its last spi operation properly before starting kernel, our first transfer in kernel becomes a continuous transfer to that request instead of a new one. Fix this flaw by restoring IOC register, which restored all pin state to default. Fixes: ebf0d8dade ("ath79: add new ar934x spi driver") Reported-by: Russell Senior <russell@personaltelco.net> Signed-off-by: Chuanhong Guo <gch981213@gmail.com>
This commit is contained in:
parent
7df120b1b0
commit
9c19c35d1e
@ -1,7 +1,7 @@
|
|||||||
From b518f18f89dbd49fe9403a8c92230f1af59219bc Mon Sep 17 00:00:00 2001
|
From 7e161c423a232ef7ddf6c11b09ebe471dd5a23cf Mon Sep 17 00:00:00 2001
|
||||||
From: Chuanhong Guo <gch981213@gmail.com>
|
From: Chuanhong Guo <gch981213@gmail.com>
|
||||||
Date: Wed, 5 Feb 2020 18:25:37 +0800
|
Date: Wed, 5 Feb 2020 18:25:37 +0800
|
||||||
Subject: [PATCH 1/2] spi: add driver for ar934x spi controller
|
Subject: [PATCH v4 1/2] spi: add driver for ar934x spi controller
|
||||||
|
|
||||||
This patch adds driver for SPI controller found in Qualcomm Atheros
|
This patch adds driver for SPI controller found in Qualcomm Atheros
|
||||||
AR934x/QCA95xx SoCs.
|
AR934x/QCA95xx SoCs.
|
||||||
@ -13,8 +13,8 @@ Signed-off-by: Chuanhong Guo <gch981213@gmail.com>
|
|||||||
---
|
---
|
||||||
drivers/spi/Kconfig | 7 ++
|
drivers/spi/Kconfig | 7 ++
|
||||||
drivers/spi/Makefile | 1 +
|
drivers/spi/Makefile | 1 +
|
||||||
drivers/spi/spi-ar934x.c | 229 +++++++++++++++++++++++++++++++++++++++
|
drivers/spi/spi-ar934x.c | 235 +++++++++++++++++++++++++++++++++++++++
|
||||||
3 files changed, 237 insertions(+)
|
3 files changed, 243 insertions(+)
|
||||||
create mode 100644 drivers/spi/spi-ar934x.c
|
create mode 100644 drivers/spi/spi-ar934x.c
|
||||||
|
|
||||||
--- a/drivers/spi/Kconfig
|
--- a/drivers/spi/Kconfig
|
||||||
@ -45,7 +45,7 @@ Signed-off-by: Chuanhong Guo <gch981213@gmail.com>
|
|||||||
obj-$(CONFIG_SPI_ATH79) += spi-ath79.o
|
obj-$(CONFIG_SPI_ATH79) += spi-ath79.o
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/drivers/spi/spi-ar934x.c
|
+++ b/drivers/spi/spi-ar934x.c
|
||||||
@@ -0,0 +1,229 @@
|
@@ -0,0 +1,235 @@
|
||||||
+// SPDX-License-Identifier: GPL-2.0
|
+// SPDX-License-Identifier: GPL-2.0
|
||||||
+//
|
+//
|
||||||
+// SPI controller driver for Qualcomm Atheros AR934x/QCA95xx SoCs
|
+// SPI controller driver for Qualcomm Atheros AR934x/QCA95xx SoCs
|
||||||
@ -70,6 +70,9 @@ Signed-off-by: Chuanhong Guo <gch981213@gmail.com>
|
|||||||
+#define AR934X_SPI_REG_FS 0x00
|
+#define AR934X_SPI_REG_FS 0x00
|
||||||
+#define AR934X_SPI_ENABLE BIT(0)
|
+#define AR934X_SPI_ENABLE BIT(0)
|
||||||
+
|
+
|
||||||
|
+#define AR934X_SPI_REG_IOC 0x08
|
||||||
|
+#define AR934X_SPI_IOC_INITVAL 0x70000
|
||||||
|
+
|
||||||
+#define AR934X_SPI_REG_CTRL 0x04
|
+#define AR934X_SPI_REG_CTRL 0x04
|
||||||
+#define AR934X_SPI_CLK_MASK GENMASK(5, 0)
|
+#define AR934X_SPI_CLK_MASK GENMASK(5, 0)
|
||||||
+
|
+
|
||||||
@ -227,7 +230,10 @@ Signed-off-by: Chuanhong Guo <gch981213@gmail.com>
|
|||||||
+ return -ENOMEM;
|
+ return -ENOMEM;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
+ /* disable flash mapping and expose spi controller registers */
|
||||||
+ iowrite32(AR934X_SPI_ENABLE, base + AR934X_SPI_REG_FS);
|
+ iowrite32(AR934X_SPI_ENABLE, base + AR934X_SPI_REG_FS);
|
||||||
|
+ /* restore pins to default state: CSn=1 DO=CLK=0 */
|
||||||
|
+ iowrite32(AR934X_SPI_IOC_INITVAL, base + AR934X_SPI_REG_IOC);
|
||||||
+
|
+
|
||||||
+ ctlr->mode_bits = SPI_LSB_FIRST;
|
+ ctlr->mode_bits = SPI_LSB_FIRST;
|
||||||
+ ctlr->setup = ar934x_spi_setup;
|
+ ctlr->setup = ar934x_spi_setup;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user