mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-11-04 06:54:27 -05:00 
			
		
		
		
	Manually rebased patches:
 bcm27xx/patches-5.4/950-0135-spi-spi-bcm2835-Disable-forced-software-CS.patch
 generic-backport/744-v5.5-net-sfp-soft-status-and-control-support.patch
 layerscape/patches-5.4/819-uart-0005-tty-serial-fsl_lpuart-enable-dma-mode-for-imx8qxp.patch
 mvebu/patches-5.4/521-arm64-dts-marvell-espressobin-Add-ethernet-switch-al.patch
Removed:
 layerscape/patches-5.4/819-uart-0012-tty-serial-lpuart-add-LS1028A-support.patch
All modifications made by update_kernel.sh
Build system: x86_64
Build-tested: ipq806x/R7800, ath79/generic, bcm27xx/bcm2711,
              lantiq/Easybox 904 xDSL, x86_64
Run-tested: ipq806x/R7800, lantiq/Easybox 904 xDSL, x86_64
No dmesg regressions, everything functional
Signed-off-by: John Audia <graysky@archlinux.us>
Co-developed-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
		
	
			
		
			
				
	
	
		
			41 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
From 5b05462e88dc87d83566d04dd196b4f3d9dc0eef Mon Sep 17 00:00:00 2001
 | 
						|
From: Fugang Duan <fugang.duan@nxp.com>
 | 
						|
Date: Mon, 28 Jan 2019 10:12:52 +0800
 | 
						|
Subject: [PATCH] tty: serial: fsl_lpuart: add modem device reset
 | 
						|
 | 
						|
Add modem device reset, wthether to reset depend on dts configuration.
 | 
						|
 | 
						|
Signed-off-by: Fugang Duan <fugang.duan@nxp.com>
 | 
						|
---
 | 
						|
 drivers/tty/serial/fsl_lpuart.c | 10 ++++++++++
 | 
						|
 1 file changed, 10 insertions(+)
 | 
						|
 | 
						|
--- a/drivers/tty/serial/fsl_lpuart.c
 | 
						|
+++ b/drivers/tty/serial/fsl_lpuart.c
 | 
						|
@@ -22,6 +22,7 @@
 | 
						|
 #include <linux/of_dma.h>
 | 
						|
 #include <linux/pm_domain.h>
 | 
						|
 #include <linux/pm_runtime.h>
 | 
						|
+#include <linux/reset.h>
 | 
						|
 #include <linux/serial_core.h>
 | 
						|
 #include <linux/slab.h>
 | 
						|
 #include <linux/tty_flip.h>
 | 
						|
@@ -1555,8 +1556,17 @@ static void lpuart32_configure(struct lp
 | 
						|
 static int lpuart32_startup(struct uart_port *port)
 | 
						|
 {
 | 
						|
 	struct lpuart_port *sport = container_of(port, struct lpuart_port, port);
 | 
						|
+	struct tty_port *tty_port = &sport->port.state->port;
 | 
						|
 	unsigned long flags;
 | 
						|
 	unsigned long temp;
 | 
						|
+	int ret;
 | 
						|
+
 | 
						|
+	/* some modem may need reset */
 | 
						|
+	if (!tty_port_suspended(tty_port)) {
 | 
						|
+		ret = device_reset(sport->port.dev);
 | 
						|
+		if (ret && ret != -ENOENT)
 | 
						|
+			return ret;
 | 
						|
+	}
 | 
						|
 
 | 
						|
 	/* determine FIFO size */
 | 
						|
 	temp = lpuart32_read(&sport->port, UARTFIFO);
 |