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: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Frederic Weisbecker <frederic@kernel.org> Link: https://lkml.kernel.org/r/20190821192920.535079278@linutronix.de
This commit is contained in:
parent
2092c1d4fe
commit
8c2d74f037
|
@ -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)
|
||||||
* 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,
|
||||||
|
|
||||||
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)
|
||||||
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,
|
||||||
* 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
|
||||||
* 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
|
||||||
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)
|
||||||
* 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)
|
||||||
/* 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,
|
||||||
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) {
|
||||||
/*
|
/*
|
||||||
|
|
Loading…
Reference in New Issue