]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
memory: samsung: exynos5422-dmc: handle clk_set_parent() failure
authorKrzysztof Kozlowski <krzysztof.kozlowski@canonical.com>
Wed, 7 Apr 2021 15:45:35 +0000 (17:45 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 14 May 2021 08:49:49 +0000 (10:49 +0200)
[ Upstream commit 132c17c3ff878c7beaba51bdd275d5cc654c0e33 ]

clk_set_parent() can fail and ignoring such case could lead to invalid
clock setup for given frequency.

Addresses-Coverity: Unchecked return value
Fixes: 6e7674c3c6df ("memory: Add DMC driver for Exynos5422")
Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@canonical.com>
Reviewed-by: Lukasz Luba <lukasz.luba@arm.com>
Link: https://lore.kernel.org/r/20210407154535.70756-1-krzysztof.kozlowski@canonical.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/memory/samsung/exynos5422-dmc.c

index c5ee4121a4d22cd3fc2c5f84f1178eb8dc38eab6..3d230f07eaf2122db1ce87516108b099baa458b1 100644 (file)
@@ -1298,7 +1298,9 @@ static int exynos5_dmc_init_clks(struct exynos5_dmc *dmc)
 
        dmc->curr_volt = target_volt;
 
-       clk_set_parent(dmc->mout_mx_mspll_ccore, dmc->mout_spll);
+       ret = clk_set_parent(dmc->mout_mx_mspll_ccore, dmc->mout_spll);
+       if (ret)
+               return ret;
 
        clk_prepare_enable(dmc->fout_bpll);
        clk_prepare_enable(dmc->mout_bpll);