summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZhaoyang Yu <2426767509@qq.com>2026-03-01 19:18:54 +0300
committerHans Verkuil <hverkuil+cisco@kernel.org>2026-03-16 13:51:55 +0300
commitc03222d061fc5d150d696e7c3a91e58a620c7e65 (patch)
treed41cbaf1dd20aaa1e47c0244ac0ac14745ce4174
parentf3e969a5b54304cab6891a58d9dd8b29072bde4c (diff)
downloadlinux-c03222d061fc5d150d696e7c3a91e58a620c7e65.tar.xz
media: fimc: check return value of clk_enable in runtime_resume
In fimc_runtime_resume(), the return value of clk_enable(fimc->clock[CLK_GATE]) was not checked. If enabling the clock fails, subsequent register accesses (fimc_hw_reset() and capture/m2m resume) may trigger a bus error or undefined behavior. Fix this by checking the return value. If clk_enable() fails, return the error immediately, preventing unsafe hardware access. Signed-off-by: Zhaoyang Yu <2426767509@qq.com> Signed-off-by: Hans Verkuil <hverkuil+cisco@kernel.org>
-rw-r--r--drivers/media/platform/samsung/exynos4-is/fimc-core.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/media/platform/samsung/exynos4-is/fimc-core.c b/drivers/media/platform/samsung/exynos4-is/fimc-core.c
index 2c9edd0a559b..57e573949e54 100644
--- a/drivers/media/platform/samsung/exynos4-is/fimc-core.c
+++ b/drivers/media/platform/samsung/exynos4-is/fimc-core.c
@@ -1020,11 +1020,15 @@ err_sclk:
static int fimc_runtime_resume(struct device *dev)
{
struct fimc_dev *fimc = dev_get_drvdata(dev);
+ int ret;
dbg("fimc%d: state: 0x%lx", fimc->id, fimc->state);
/* Enable clocks and perform basic initialization */
- clk_enable(fimc->clock[CLK_GATE]);
+ ret = clk_enable(fimc->clock[CLK_GATE]);
+ if (ret)
+ return ret;
+
fimc_hw_reset(fimc);
/* Resume the capture or mem-to-mem device */