]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
serial: 8250_dw: Comment possible corner cases in serial_out() implementation
authorAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Mon, 17 Mar 2025 09:40:21 +0000 (11:40 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 20 Mar 2025 15:05:27 +0000 (08:05 -0700)
8250 DesignWare driver uses a few custom implementations of the serial_out().
These implementations are carefully made to avoid infinite loops. But this is
not obvious from looking at the code. Comment the possible corner cases in
the respective functions.

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

index f068b8d7840a9239f4e194c1a9ccf80dac2dfd0f..1902f29444a1c99f8038ebf2a6328feefc8052db 100644 (file)
@@ -107,11 +107,23 @@ static inline int dw8250_modify_msr(struct uart_port *p, int offset, int value)
        return value;
 }
 
+/*
+ * This function is being called as part of the uart_port::serial_out()
+ * routine. Hence, it must not call serial_port_out() or serial_out()
+ * against the modified registers here, i.e. LCR.
+ */
 static void dw8250_force_idle(struct uart_port *p)
 {
        struct uart_8250_port *up = up_to_u8250p(p);
        unsigned int lsr;
 
+       /*
+        * The following call currently performs serial_out()
+        * against the FCR register. Because it differs to LCR
+        * there will be no infinite loop, but if it ever gets
+        * modified, we might need a new custom version of it
+        * that avoids infinite recursion.
+        */
        serial8250_clear_and_reinit_fifos(up);
 
        /*
@@ -128,6 +140,11 @@ static void dw8250_force_idle(struct uart_port *p)
        serial_port_in(p, UART_RX);
 }
 
+/*
+ * This function is being called as part of the uart_port::serial_out()
+ * routine. Hence, it must not call serial_port_out() or serial_out()
+ * against the modified registers here, i.e. LCR.
+ */
 static void dw8250_check_lcr(struct uart_port *p, int offset, int value)
 {
        struct dw8250_data *d = to_dw8250_data(p->private_data);