serial: 8250_dw: Deduplicate LCR checks
authorAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Fri, 12 Apr 2024 17:39:31 +0000 (20:39 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 17 Apr 2024 11:14:06 +0000 (13:14 +0200)
All callers of dw8250_check_lcr() perform the same check.
Deduplicate it by moving them into respective call.

Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20240412173931.187411-1-andriy.shevchenko@linux.intel.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/8250/8250_dw.c

index a3acbf0f5da1beff6724e839fa14a0a990a15576..994604c77058d0718a34ab724d6d882f130e2a9f 100644 (file)
@@ -100,14 +100,18 @@ static void dw8250_force_idle(struct uart_port *p)
        (void)p->serial_in(p, UART_RX);
 }
 
-static void dw8250_check_lcr(struct uart_port *p, int value)
+static void dw8250_check_lcr(struct uart_port *p, int offset, int value)
 {
-       void __iomem *offset = p->membase + (UART_LCR << p->regshift);
+       struct dw8250_data *d = to_dw8250_data(p->private_data);
+       void __iomem *addr = p->membase + (offset << p->regshift);
        int tries = 1000;
 
+       if (offset != UART_LCR || d->uart_16550_compatible)
+               return;
+
        /* Make sure LCR write wasn't ignored */
        while (tries--) {
-               unsigned int lcr = p->serial_in(p, UART_LCR);
+               unsigned int lcr = p->serial_in(p, offset);
 
                if ((value & ~UART_LCR_SPAR) == (lcr & ~UART_LCR_SPAR))
                        return;
@@ -116,15 +120,15 @@ static void dw8250_check_lcr(struct uart_port *p, int value)
 
 #ifdef CONFIG_64BIT
                if (p->type == PORT_OCTEON)
-                       __raw_writeq(value & 0xff, offset);
+                       __raw_writeq(value & 0xff, addr);
                else
 #endif
                if (p->iotype == UPIO_MEM32)
-                       writel(value, offset);
+                       writel(value, addr);
                else if (p->iotype == UPIO_MEM32BE)
-                       iowrite32be(value, offset);
+                       iowrite32be(value, addr);
                else
-                       writeb(value, offset);
+                       writeb(value, addr);
        }
        /*
         * FIXME: this deadlocks if port->lock is already held
@@ -158,12 +162,8 @@ static void dw8250_tx_wait_empty(struct uart_port *p)
 
 static void dw8250_serial_out(struct uart_port *p, int offset, int value)
 {
-       struct dw8250_data *d = to_dw8250_data(p->private_data);
-
        writeb(value, p->membase + (offset << p->regshift));
-
-       if (offset == UART_LCR && !d->uart_16550_compatible)
-               dw8250_check_lcr(p, value);
+       dw8250_check_lcr(p, offset, value);
 }
 
 static void dw8250_serial_out38x(struct uart_port *p, int offset, int value)
@@ -194,26 +194,19 @@ static unsigned int dw8250_serial_inq(struct uart_port *p, int offset)
 
 static void dw8250_serial_outq(struct uart_port *p, int offset, int value)
 {
-       struct dw8250_data *d = to_dw8250_data(p->private_data);
-
        value &= 0xff;
        __raw_writeq(value, p->membase + (offset << p->regshift));
        /* Read back to ensure register write ordering. */
        __raw_readq(p->membase + (UART_LCR << p->regshift));
 
-       if (offset == UART_LCR && !d->uart_16550_compatible)
-               dw8250_check_lcr(p, value);
+       dw8250_check_lcr(p, offset, value);
 }
 #endif /* CONFIG_64BIT */
 
 static void dw8250_serial_out32(struct uart_port *p, int offset, int value)
 {
-       struct dw8250_data *d = to_dw8250_data(p->private_data);
-
        writel(value, p->membase + (offset << p->regshift));
-
-       if (offset == UART_LCR && !d->uart_16550_compatible)
-               dw8250_check_lcr(p, value);
+       dw8250_check_lcr(p, offset, value);
 }
 
 static unsigned int dw8250_serial_in32(struct uart_port *p, int offset)
@@ -225,12 +218,8 @@ static unsigned int dw8250_serial_in32(struct uart_port *p, int offset)
 
 static void dw8250_serial_out32be(struct uart_port *p, int offset, int value)
 {
-       struct dw8250_data *d = to_dw8250_data(p->private_data);
-
        iowrite32be(value, p->membase + (offset << p->regshift));
-
-       if (offset == UART_LCR && !d->uart_16550_compatible)
-               dw8250_check_lcr(p, value);
+       dw8250_check_lcr(p, offset, value);
 }
 
 static unsigned int dw8250_serial_in32be(struct uart_port *p, int offset)