drivers/serial: Do not leave sysfs group in case of error in aspeed_vuart_probe()
authorAlexey Khoroshilov <khoroshilov@ispras.ru>
Fri, 28 Jul 2017 18:54:03 +0000 (21:54 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 30 Jul 2017 14:37:25 +0000 (07:37 -0700)
There are several error handling paths in aspeed_vuart_probe(),
where sysfs group is left unremoved. The patch fixes them.

Found by Linux Driver Verification project (linuxtesting.org).

Signed-off-by: Alexey Khoroshilov <khoroshilov@ispras.ru>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/8250/8250_aspeed_vuart.c

index 822be490676395d25849855774db4c1d858a0ba8..33a801353114c016ca7fe5fa0aebe507a3d2844b 100644 (file)
@@ -223,12 +223,13 @@ static int aspeed_vuart_probe(struct platform_device *pdev)
                if (IS_ERR(vuart->clk)) {
                        dev_warn(&pdev->dev,
                                "clk or clock-frequency not defined\n");
-                       return PTR_ERR(vuart->clk);
+                       rc = PTR_ERR(vuart->clk);
+                       goto err_sysfs_remove;
                }
 
                rc = clk_prepare_enable(vuart->clk);
                if (rc < 0)
-                       return rc;
+                       goto err_sysfs_remove;
 
                clk = clk_get_rate(vuart->clk);
        }
@@ -286,6 +287,8 @@ static int aspeed_vuart_probe(struct platform_device *pdev)
 err_clk_disable:
        clk_disable_unprepare(vuart->clk);
        irq_dispose_mapping(port.port.irq);
+err_sysfs_remove:
+       sysfs_remove_group(&vuart->dev->kobj, &aspeed_vuart_attr_group);
        return rc;
 }