Commit 8c2d74f0 authored by Thomas Gleixner's avatar Thomas Gleixner

posix-cpu-timers: Get rid of pointer indirection

Now that the sample functions have no return value anymore, the result can
simply be returned instead of using pointer indirection.
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Reviewed-by: default avatarFrederic Weisbecker <frederic@kernel.org>
Link: https://lkml.kernel.org/r/20190821192920.535079278@linutronix.de
parent 2092c1d4
...@@ -182,22 +182,19 @@ posix_cpu_clock_set(const clockid_t clock, const struct timespec64 *tp) ...@@ -182,22 +182,19 @@ posix_cpu_clock_set(const clockid_t clock, const struct timespec64 *tp)
/* /*
* Sample a per-thread clock for the given task. clkid is validated. * Sample a per-thread clock for the given task. clkid is validated.
*/ */
static void cpu_clock_sample(const clockid_t clkid, struct task_struct *p, static u64 cpu_clock_sample(const clockid_t clkid, struct task_struct *p)
u64 *sample)
{ {
switch (clkid) { switch (clkid) {
case CPUCLOCK_PROF: case CPUCLOCK_PROF:
*sample = prof_ticks(p); return prof_ticks(p);
break;
case CPUCLOCK_VIRT: case CPUCLOCK_VIRT:
*sample = virt_ticks(p); return virt_ticks(p);
break;
case CPUCLOCK_SCHED: case CPUCLOCK_SCHED:
*sample = task_sched_runtime(p); return task_sched_runtime(p);
break;
default: default:
WARN_ON_ONCE(1); WARN_ON_ONCE(1);
} }
return 0;
} }
/* /*
...@@ -299,8 +296,8 @@ thread_group_start_cputime(struct task_struct *tsk, struct task_cputime *times) ...@@ -299,8 +296,8 @@ thread_group_start_cputime(struct task_struct *tsk, struct task_cputime *times)
* held to protect the task traversal on a full update. clkid is already * held to protect the task traversal on a full update. clkid is already
* validated. * validated.
*/ */
static void cpu_clock_sample_group(const clockid_t clkid, struct task_struct *p, static u64 cpu_clock_sample_group(const clockid_t clkid, struct task_struct *p,
u64 *sample, bool start) bool start)
{ {
struct thread_group_cputimer *cputimer = &p->signal->cputimer; struct thread_group_cputimer *cputimer = &p->signal->cputimer;
struct task_cputime cputime; struct task_cputime cputime;
...@@ -316,17 +313,15 @@ static void cpu_clock_sample_group(const clockid_t clkid, struct task_struct *p, ...@@ -316,17 +313,15 @@ static void cpu_clock_sample_group(const clockid_t clkid, struct task_struct *p,
switch (clkid) { switch (clkid) {
case CPUCLOCK_PROF: case CPUCLOCK_PROF:
*sample = cputime.utime + cputime.stime; return cputime.utime + cputime.stime;
break;
case CPUCLOCK_VIRT: case CPUCLOCK_VIRT:
*sample = cputime.utime; return cputime.utime;
break;
case CPUCLOCK_SCHED: case CPUCLOCK_SCHED:
*sample = cputime.sum_exec_runtime; return cputime.sum_exec_runtime;
break;
default: default:
WARN_ON_ONCE(1); WARN_ON_ONCE(1);
} }
return 0;
} }
static int posix_cpu_clock_get(const clockid_t clock, struct timespec64 *tp) static int posix_cpu_clock_get(const clockid_t clock, struct timespec64 *tp)
...@@ -340,9 +335,9 @@ static int posix_cpu_clock_get(const clockid_t clock, struct timespec64 *tp) ...@@ -340,9 +335,9 @@ static int posix_cpu_clock_get(const clockid_t clock, struct timespec64 *tp)
return -EINVAL; return -EINVAL;
if (CPUCLOCK_PERTHREAD(clock)) if (CPUCLOCK_PERTHREAD(clock))
cpu_clock_sample(clkid, tsk, &t); t = cpu_clock_sample(clkid, tsk);
else else
cpu_clock_sample_group(clkid, tsk, &t, false); t = cpu_clock_sample_group(clkid, tsk, false);
put_task_struct(tsk); put_task_struct(tsk);
*tp = ns_to_timespec64(t); *tp = ns_to_timespec64(t);
...@@ -604,11 +599,10 @@ static int posix_cpu_timer_set(struct k_itimer *timer, int timer_flags, ...@@ -604,11 +599,10 @@ static int posix_cpu_timer_set(struct k_itimer *timer, int timer_flags,
* times (in arm_timer). With an absolute time, we must * times (in arm_timer). With an absolute time, we must
* check if it's already passed. In short, we need a sample. * check if it's already passed. In short, we need a sample.
*/ */
if (CPUCLOCK_PERTHREAD(timer->it_clock)) { if (CPUCLOCK_PERTHREAD(timer->it_clock))
cpu_clock_sample(clkid, p, &val); val = cpu_clock_sample(clkid, p);
} else { else
cpu_clock_sample_group(clkid, p, &val, true); val = cpu_clock_sample_group(clkid, p, true);
}
if (old) { if (old) {
if (old_expires == 0) { if (old_expires == 0) {
...@@ -716,7 +710,7 @@ static void posix_cpu_timer_get(struct k_itimer *timer, struct itimerspec64 *itp ...@@ -716,7 +710,7 @@ static void posix_cpu_timer_get(struct k_itimer *timer, struct itimerspec64 *itp
* Sample the clock to take the difference with the expiry time. * Sample the clock to take the difference with the expiry time.
*/ */
if (CPUCLOCK_PERTHREAD(timer->it_clock)) { if (CPUCLOCK_PERTHREAD(timer->it_clock)) {
cpu_clock_sample(clkid, p, &now); now = cpu_clock_sample(clkid, p);
} else { } else {
struct sighand_struct *sighand; struct sighand_struct *sighand;
unsigned long flags; unsigned long flags;
...@@ -736,7 +730,7 @@ static void posix_cpu_timer_get(struct k_itimer *timer, struct itimerspec64 *itp ...@@ -736,7 +730,7 @@ static void posix_cpu_timer_get(struct k_itimer *timer, struct itimerspec64 *itp
timer->it.cpu.expires = 0; timer->it.cpu.expires = 0;
return; return;
} else { } else {
cpu_clock_sample_group(clkid, p, &now, false); now = cpu_clock_sample_group(clkid, p, false);
unlock_task_sighand(p, &flags); unlock_task_sighand(p, &flags);
} }
} }
...@@ -998,7 +992,7 @@ static void posix_cpu_timer_rearm(struct k_itimer *timer) ...@@ -998,7 +992,7 @@ static void posix_cpu_timer_rearm(struct k_itimer *timer)
* Fetch the current sample and update the timer's expiry time. * Fetch the current sample and update the timer's expiry time.
*/ */
if (CPUCLOCK_PERTHREAD(timer->it_clock)) { if (CPUCLOCK_PERTHREAD(timer->it_clock)) {
cpu_clock_sample(clkid, p, &now); now = cpu_clock_sample(clkid, p);
bump_cpu_timer(timer, now); bump_cpu_timer(timer, now);
if (unlikely(p->exit_state)) if (unlikely(p->exit_state))
return; return;
...@@ -1024,7 +1018,7 @@ static void posix_cpu_timer_rearm(struct k_itimer *timer) ...@@ -1024,7 +1018,7 @@ static void posix_cpu_timer_rearm(struct k_itimer *timer)
/* If the process is dying, no need to rearm */ /* If the process is dying, no need to rearm */
goto unlock; goto unlock;
} }
cpu_clock_sample_group(clkid, p, &now, true); now = cpu_clock_sample_group(clkid, p, true);
bump_cpu_timer(timer, now); bump_cpu_timer(timer, now);
/* Leave the sighand locked for the call below. */ /* Leave the sighand locked for the call below. */
} }
...@@ -1192,7 +1186,7 @@ void set_process_cpu_timer(struct task_struct *tsk, unsigned int clock_idx, ...@@ -1192,7 +1186,7 @@ void set_process_cpu_timer(struct task_struct *tsk, unsigned int clock_idx,
if (WARN_ON_ONCE(clock_idx >= CPUCLOCK_SCHED)) if (WARN_ON_ONCE(clock_idx >= CPUCLOCK_SCHED))
return; return;
cpu_clock_sample_group(clock_idx, tsk, &now, true); now = cpu_clock_sample_group(clock_idx, tsk, true);
if (oldval) { if (oldval) {
/* /*
......
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