posix-cpu-timers: Sample directly in timer check
The thread group accounting is active, otherwise the expiry function would not be running. Sample the thread group time directly. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Frederic Weisbecker <frederic@kernel.org> Link: https://lkml.kernel.org/r/20190821192919.780348088@linutronix.de
This commit is contained in:
parent
a34360d424
commit
a324956fae
@ -914,16 +914,17 @@ static void check_process_timers(struct task_struct *tsk,
|
|||||||
if (!READ_ONCE(tsk->signal->cputimer.running))
|
if (!READ_ONCE(tsk->signal->cputimer.running))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Signify that a thread is checking for process timers.
|
* Signify that a thread is checking for process timers.
|
||||||
* Write access to this field is protected by the sighand lock.
|
* Write access to this field is protected by the sighand lock.
|
||||||
*/
|
*/
|
||||||
sig->cputimer.checking_timer = true;
|
sig->cputimer.checking_timer = true;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Collect the current process totals.
|
* Collect the current process totals. Group accounting is active
|
||||||
|
* so the sample can be taken directly.
|
||||||
*/
|
*/
|
||||||
thread_group_cputimer(tsk, &cputime);
|
sample_cputime_atomic(&cputime, &sig->cputimer.cputime_atomic);
|
||||||
utime = cputime.utime;
|
utime = cputime.utime;
|
||||||
ptime = utime + cputime.stime;
|
ptime = utime + cputime.stime;
|
||||||
sum_sched_runtime = cputime.sum_exec_runtime;
|
sum_sched_runtime = cputime.sum_exec_runtime;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user