clk: fixed: fix double free in resource managed fixed-factor clock
authorDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Tue, 6 Apr 2021 23:06:06 +0000 (02:06 +0300)
committerStephen Boyd <sboyd@kernel.org>
Wed, 7 Apr 2021 23:01:25 +0000 (16:01 -0700)
commit50ce6826a48f119baf2794fa384a64efe9bd84a5
treea4c3ef684fff6552015fb03fd6742ca5e2f01f0c
parent7045465500e465b09f09d6e5bdc260a9f1aab97b
clk: fixed: fix double free in resource managed fixed-factor clock

devm_clk_hw_register_fixed_factor_release(), the release function for
the devm_clk_hw_register_fixed_factor(), calls
clk_hw_unregister_fixed_factor(), which will kfree() the clock. However
after that the devres functions will also kfree the allocated data,
resulting in double free/memory corruption. Just call
clk_hw_unregister() instead, leaving kfree() to devres code.

Reported-by: Rob Clark <robdclark@chromium.org>
Cc: Daniel Palmer <daniel@0x0f.com>
Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Link: https://lore.kernel.org/r/20210406230606.3007138-1-dmitry.baryshkov@linaro.org
Fixes: 0b9266d295ce ("clk: fixed: add devm helper for clk_hw_register_fixed_factor()")
[sboyd@kernel.org: Remove ugly cast]
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
drivers/clk/clk-fixed-factor.c