android_kernel_xiaomi_sm8350/drivers/clk/bcm
Nathan Chancellor 4d33659ac3 clk: bcm2835: Fix return type of bcm2835_register_gate
[ Upstream commit f376c43bec4f8ee8d1ba5c5c4cfbd6e84fb279cb ]

bcm2835_register_gate is used as a callback for the clk_register member
of bcm2835_clk_desc, which expects a struct clk_hw * return type but
bcm2835_register_gate returns a struct clk *.

This discrepancy is hidden by the fact that bcm2835_register_gate is
cast to the typedef bcm2835_clk_register by the _REGISTER macro. This
turns out to be a control flow integrity violation, which is how this
was noticed.

Change the return type of bcm2835_register_gate to be struct clk_hw *
and use clk_hw_register_gate to do so. This should be a non-functional
change as clk_register_gate calls clk_hw_register_gate anyways but this
is needed to avoid issues with further changes.

Fixes: b19f009d45 ("clk: bcm2835: Migrate to clk_hw based registration and OF APIs")
Link: https://github.com/ClangBuiltLinux/linux/issues/1028
Signed-off-by: Nathan Chancellor <natechancellor@gmail.com>
Link: https://lkml.kernel.org/r/20200516080806.1459784-1-natechancellor@gmail.com
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2020-06-24 17:50:34 +02:00
..
clk-bcm63xx-gate.c
clk-bcm63xx.c
clk-bcm281xx.c
clk-bcm2835-aux.c
clk-bcm2835.c
clk-bcm21664.c
clk-bcm53573-ilp.c
clk-cygnus.c
clk-hr2.c
clk-iproc-armpll.c
clk-iproc-asiu.c
clk-iproc-pll.c
clk-iproc.h
clk-kona-setup.c
clk-kona.c
clk-kona.h
clk-ns2.c
clk-nsp.c
clk-raspberrypi.c
clk-sr.c
Kconfig
Makefile