misc: fastrpc: Fix an error handling path in fastrpc_rpmsg_probe()
authorChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Fri, 25 Nov 2022 17:45:02 +0000 (18:45 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 20 Jan 2023 12:10:46 +0000 (13:10 +0100)
If of_platform_populate() fails, some resources need to be freed as already
done in the other error handling paths.

Fixes: 278d56f970ae ("misc: fastrpc: Reference count channel context")
Fixes: 3abe3ab3cdab ("misc: fastrpc: add secure domain support")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Link: https://lore.kernel.org/r/b909d2f3273b794ea0f1f78d14bc24affb08ea5f.1669398274.git.christophe.jaillet@wanadoo.fr
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/misc/fastrpc.c

index c9902a1dcf5d311043182ee87f4dbc5ec6085cae..1413f5cd79b4d091989076344eaa7ce8b845461f 100644 (file)
@@ -2316,7 +2316,18 @@ static int fastrpc_rpmsg_probe(struct rpmsg_device *rpdev)
        data->domain_id = domain_id;
        data->rpdev = rpdev;
 
-       return of_platform_populate(rdev->of_node, NULL, NULL, rdev);
+       err = of_platform_populate(rdev->of_node, NULL, NULL, rdev);
+       if (err)
+               goto populate_error;
+
+       return 0;
+
+populate_error:
+       if (data->fdevice)
+               misc_deregister(&data->fdevice->miscdev);
+       if (data->secure_fdevice)
+               misc_deregister(&data->secure_fdevice->miscdev);
+
 fdev_error:
        kfree(data);
        return err;