serial: max310x: simplify probe() and remove() error handling
authorHugo Villeneuve <hvilleneuve@dimonoff.com>
Thu, 18 Jan 2024 15:22:05 +0000 (10:22 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 28 Jan 2024 03:05:04 +0000 (19:05 -0800)
Simplify error handling and only call uart_remove_one_port() if line bit
is set, instead of having to manually set s->p[i].port.dev to NULL.

Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com>
Signed-off-by: Hugo Villeneuve <hvilleneuve@dimonoff.com>
Link: https://lore.kernel.org/r/20240118152213.2644269-10-hugo@hugovil.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/max310x.c

index d6219077d23c99dee73bb1d8f013059cdf40b24e..9ef146f09d5b2d024ea11715eb2238a843edb3ed 100644 (file)
@@ -1395,10 +1395,9 @@ static int max310x_probe(struct device *dev, const struct max310x_devtype *devty
 
                /* Register port */
                ret = uart_add_one_port(&max310x_uart, &s->p[i].port);
-               if (ret) {
-                       s->p[i].port.dev = NULL;
+               if (ret)
                        goto out_uart;
-               }
+
                set_bit(line, max310x_lines);
 
                /* Go to suspend mode */
@@ -1433,10 +1432,8 @@ static int max310x_probe(struct device *dev, const struct max310x_devtype *devty
 
 out_uart:
        for (i = 0; i < devtype->nr; i++) {
-               if (s->p[i].port.dev) {
+               if (test_and_clear_bit(s->p[i].port.line, max310x_lines))
                        uart_remove_one_port(&max310x_uart, &s->p[i].port);
-                       clear_bit(s->p[i].port.line, max310x_lines);
-               }
        }
 
 out_clk:
@@ -1454,8 +1451,10 @@ static void max310x_remove(struct device *dev)
                cancel_work_sync(&s->p[i].tx_work);
                cancel_work_sync(&s->p[i].md_work);
                cancel_work_sync(&s->p[i].rs_work);
-               uart_remove_one_port(&max310x_uart, &s->p[i].port);
-               clear_bit(s->p[i].port.line, max310x_lines);
+
+               if (test_and_clear_bit(s->p[i].port.line, max310x_lines))
+                       uart_remove_one_port(&max310x_uart, &s->p[i].port);
+
                s->devtype->power(&s->p[i].port, 0);
        }