Commit 0c52310f authored by Davidlohr Bueso's avatar Davidlohr Bueso Committed by Thomas Gleixner

hrtimer: Ignore slack time for RT tasks in schedule_hrtimeout_range()

While in theory the timer can be triggered before expires + delta, for the
cases of RT tasks they really have no business giving any lenience for
extra slack time, so override any passed value by the user and always use
zero for schedule_hrtimeout_range() calls. Furthermore, this is similar to
what the nanosleep(2) family already does with current->timer_slack_ns.
Signed-off-by: default avatarDavidlohr Bueso <dave@stgolabs.net>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Link: https://lore.kernel.org/r/20230123173206.6764-3-dave@stgolabs.net
parent c14fd3dc
...@@ -2272,7 +2272,7 @@ void __init hrtimers_init(void) ...@@ -2272,7 +2272,7 @@ void __init hrtimers_init(void)
/** /**
* schedule_hrtimeout_range_clock - sleep until timeout * schedule_hrtimeout_range_clock - sleep until timeout
* @expires: timeout value (ktime_t) * @expires: timeout value (ktime_t)
* @delta: slack in expires timeout (ktime_t) * @delta: slack in expires timeout (ktime_t) for SCHED_OTHER tasks
* @mode: timer mode * @mode: timer mode
* @clock_id: timer clock to be used * @clock_id: timer clock to be used
*/ */
...@@ -2299,6 +2299,13 @@ schedule_hrtimeout_range_clock(ktime_t *expires, u64 delta, ...@@ -2299,6 +2299,13 @@ schedule_hrtimeout_range_clock(ktime_t *expires, u64 delta,
return -EINTR; return -EINTR;
} }
/*
* Override any slack passed by the user if under
* rt contraints.
*/
if (rt_task(current))
delta = 0;
hrtimer_init_sleeper_on_stack(&t, clock_id, mode); hrtimer_init_sleeper_on_stack(&t, clock_id, mode);
hrtimer_set_expires_range_ns(&t.timer, *expires, delta); hrtimer_set_expires_range_ns(&t.timer, *expires, delta);
hrtimer_sleeper_start_expires(&t, mode); hrtimer_sleeper_start_expires(&t, mode);
...@@ -2318,7 +2325,7 @@ EXPORT_SYMBOL_GPL(schedule_hrtimeout_range_clock); ...@@ -2318,7 +2325,7 @@ EXPORT_SYMBOL_GPL(schedule_hrtimeout_range_clock);
/** /**
* schedule_hrtimeout_range - sleep until timeout * schedule_hrtimeout_range - sleep until timeout
* @expires: timeout value (ktime_t) * @expires: timeout value (ktime_t)
* @delta: slack in expires timeout (ktime_t) * @delta: slack in expires timeout (ktime_t) for SCHED_OTHER tasks
* @mode: timer mode * @mode: timer mode
* *
* Make the current task sleep until the given expiry time has * Make the current task sleep until the given expiry time has
...@@ -2326,7 +2333,8 @@ EXPORT_SYMBOL_GPL(schedule_hrtimeout_range_clock); ...@@ -2326,7 +2333,8 @@ EXPORT_SYMBOL_GPL(schedule_hrtimeout_range_clock);
* the current task state has been set (see set_current_state()). * the current task state has been set (see set_current_state()).
* *
* The @delta argument gives the kernel the freedom to schedule the * The @delta argument gives the kernel the freedom to schedule the
* actual wakeup to a time that is both power and performance friendly. * actual wakeup to a time that is both power and performance friendly
* for regular (non RT/DL) tasks.
* The kernel give the normal best effort behavior for "@expires+@delta", * The kernel give the normal best effort behavior for "@expires+@delta",
* but may decide to fire the timer earlier, but no earlier than @expires. * but may decide to fire the timer earlier, but no earlier than @expires.
* *
......
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