:: [maemo-leste] [PATCH AUTOSEL 5.6 11…
Top Page
Delete this message
Reply to this message
Author: Sasha Levin
To: linux-kernel, stable
CC: Tony Lindgren, maemo-leste, Merlijn Wajer, Pavel Machek, Sebastian Reichel, Sasha Levin, devicetree, linux-arm-kernel
Subject: [maemo-leste] [PATCH AUTOSEL 5.6 11/41] ARM: dts: omap4-droid4: Fix occasional lost wakeirq for uart1
From: Tony Lindgren <tony@???>

[ Upstream commit 738b150ecefbffb6e55cfa8a3b66a844f777d8fb ]

Looks like using the UART CTS pin does not always trigger for a wake-up
when the SoC is idle.

This is probably because the modem first uses gpio_149 to signal the SoC
that data will be sent, and the CTS will only get used later when the
data transfer is starting.

Let's fix the issue by configuring the gpio_149 pad as the wakeirq for
UART. We have gpio_149 managed by the USB PHY for powering up the right
USB mode, and after that, the gpio gets recycled as the modem wake-up
pin. If needeed, the USB PHY can also later on be configured to use
gpio_149 pad as the wakeirq as a shared irq.

Let's also configure the missing properties for uart-has-rtscts and
current-speed for the modem port while at it. We already configure the
hardware flow control pins with uart1_pins pinctrl setting.

Cc: maemo-leste@???
Cc: Merlijn Wajer <merlijn@???>
Cc: Pavel Machek <pavel@???>
Cc: Sebastian Reichel <sre@???>
Signed-off-by: Tony Lindgren <tony@???>
Signed-off-by: Sasha Levin <sashal@???>
arch/arm/boot/dts/motorola-mapphone-common.dtsi | 10 +++++++---
1 file changed, 7 insertions(+), 3 deletions(-)

diff --git a/arch/arm/boot/dts/motorola-mapphone-common.dtsi b/arch/arm/boot/dts/motorola-mapphone-common.dtsi
index 01ea9a1e2c86..06fbffa81636 100644
--- a/arch/arm/boot/dts/motorola-mapphone-common.dtsi
+++ b/arch/arm/boot/dts/motorola-mapphone-common.dtsi
@@ -723,14 +723,18 @@

- * As uart1 is wired to mdm6600 with rts and cts, we can use the cts pin for
- * uart1 wakeirq.
+ * The uart1 port is wired to mdm6600 with rts and cts. The modem uses gpio_149
+ * for wake-up events for both the USB PHY and the UART. We can use gpio_149
+ * pad as the shared wakeirq for the UART rather than the RX or CTS pad as we
+ * have gpio_149 trigger before the UART transfer starts.
 &uart1 {
     pinctrl-names = "default";
     pinctrl-0 = <&uart1_pins>;
     interrupts-extended = <&wakeupgen GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH
-                   &omap4_pmx_core 0xfc>;
+                   &omap4_pmx_core 0x110>;
+    uart-has-rtscts;
+    current-speed = <115200>;

&uart3 {