[ Upstream commit 
2b7d07f7acaac2c7750e420dcf4414588ede6d03 ]
The ftpm_mod_init() returns the driver_register() directly without checking
its return value, if driver_register() failed, the ftpm_tee_plat_driver is
not unregistered.
Fix by unregister ftpm_tee_plat_driver when driver_register() failed.
Fixes: 9f1944c23c8c ("tpm_ftpm_tee: register driver on TEE bus")
Signed-off-by: Yuan Can <yuancan@huawei.com>
Reviewed-by: Maxim Uvarov <maxim.uvarov@linaro.org>
Acked-by: Jarkko Sakkinen <jarkko@kernel.org>
Signed-off-by: Jarkko Sakkinen <jarkko@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
        if (rc)
                return rc;
 
-       return driver_register(&ftpm_tee_driver.driver);
+       rc = driver_register(&ftpm_tee_driver.driver);
+       if (rc) {
+               platform_driver_unregister(&ftpm_tee_plat_driver);
+               return rc;
+       }
+
+       return 0;
 }
 
 static void __exit ftpm_mod_exit(void)