Commit b8725dab authored by Jisheng Zhang's avatar Jisheng Zhang Committed by Daniel Lezcano

clocksource/drivers/samsung_pwm_timer: Prevent ftrace recursion

Currently samsung_pwm_timer can be used as a scheduler clock. We properly
marked samsung_read_sched_clock() as notrace but we then call another
function samsung_clocksource_read() that _wasn't_ notrace.

Having a traceable function in the sched_clock() path leads to a recursion
within ftrace and a kernel crash.

Fix this by adding notrace attribute to the samsung_clocksource_read()
function.
Signed-off-by: default avatarJisheng Zhang <jszhang@marvell.com>
Signed-off-by: default avatarDaniel Lezcano <daniel.lezcano@linaro.org>
parent f8af0e9c
...@@ -307,7 +307,7 @@ static void samsung_clocksource_resume(struct clocksource *cs) ...@@ -307,7 +307,7 @@ static void samsung_clocksource_resume(struct clocksource *cs)
samsung_time_start(pwm.source_id, true); samsung_time_start(pwm.source_id, true);
} }
static cycle_t samsung_clocksource_read(struct clocksource *c) static cycle_t notrace samsung_clocksource_read(struct clocksource *c)
{ {
return ~readl_relaxed(pwm.source_reg); return ~readl_relaxed(pwm.source_reg);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment