aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/posix-cpu-timers.c
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/posix-cpu-timers.c')
-rw-r--r--kernel/posix-cpu-timers.c44
1 files changed, 23 insertions, 21 deletions
diff --git a/kernel/posix-cpu-timers.c b/kernel/posix-cpu-timers.c
index b60d644ea4b3..69c92374355f 100644
--- a/kernel/posix-cpu-timers.c
+++ b/kernel/posix-cpu-timers.c
@@ -541,6 +541,17 @@ static void clear_dead_task(struct k_itimer *timer, union cpu_time_count now)
541 now); 541 now);
542} 542}
543 543
544static inline int expires_gt(cputime_t expires, cputime_t new_exp)
545{
546 return cputime_eq(expires, cputime_zero) ||
547 cputime_gt(expires, new_exp);
548}
549
550static inline int expires_le(cputime_t expires, cputime_t new_exp)
551{
552 return !cputime_eq(expires, cputime_zero) &&
553 cputime_le(expires, new_exp);
554}
544/* 555/*
545 * Insert the timer on the appropriate list before any timers that 556 * Insert the timer on the appropriate list before any timers that
546 * expire later. This must be called with the tasklist_lock held 557 * expire later. This must be called with the tasklist_lock held
@@ -585,31 +596,26 @@ static void arm_timer(struct k_itimer *timer, union cpu_time_count now)
585 */ 596 */
586 597
587 if (CPUCLOCK_PERTHREAD(timer->it_clock)) { 598 if (CPUCLOCK_PERTHREAD(timer->it_clock)) {
599 union cpu_time_count *exp = &nt->expires;
600
588 switch (CPUCLOCK_WHICH(timer->it_clock)) { 601 switch (CPUCLOCK_WHICH(timer->it_clock)) {
589 default: 602 default:
590 BUG(); 603 BUG();
591 case CPUCLOCK_PROF: 604 case CPUCLOCK_PROF:
592 if (cputime_eq(p->cputime_expires.prof_exp, 605 if (expires_gt(p->cputime_expires.prof_exp,
593 cputime_zero) || 606 exp->cpu))
594 cputime_gt(p->cputime_expires.prof_exp, 607 p->cputime_expires.prof_exp = exp->cpu;
595 nt->expires.cpu))
596 p->cputime_expires.prof_exp =
597 nt->expires.cpu;
598 break; 608 break;
599 case CPUCLOCK_VIRT: 609 case CPUCLOCK_VIRT:
600 if (cputime_eq(p->cputime_expires.virt_exp, 610 if (expires_gt(p->cputime_expires.virt_exp,
601 cputime_zero) || 611 exp->cpu))
602 cputime_gt(p->cputime_expires.virt_exp, 612 p->cputime_expires.virt_exp = exp->cpu;
603 nt->expires.cpu))
604 p->cputime_expires.virt_exp =
605 nt->expires.cpu;
606 break; 613 break;
607 case CPUCLOCK_SCHED: 614 case CPUCLOCK_SCHED:
608 if (p->cputime_expires.sched_exp == 0 || 615 if (p->cputime_expires.sched_exp == 0 ||
609 p->cputime_expires.sched_exp > 616 p->cputime_expires.sched_exp > exp->sched)
610 nt->expires.sched)
611 p->cputime_expires.sched_exp = 617 p->cputime_expires.sched_exp =
612 nt->expires.sched; 618 exp->sched;
613 break; 619 break;
614 } 620 }
615 } else { 621 } else {
@@ -623,17 +629,13 @@ static void arm_timer(struct k_itimer *timer, union cpu_time_count now)
623 default: 629 default:
624 BUG(); 630 BUG();
625 case CPUCLOCK_VIRT: 631 case CPUCLOCK_VIRT:
626 if (!cputime_eq(sig->it[CPUCLOCK_VIRT].expires, 632 if (expires_le(sig->it[CPUCLOCK_VIRT].expires,
627 cputime_zero) &&
628 cputime_lt(sig->it[CPUCLOCK_VIRT].expires,
629 exp->cpu)) 633 exp->cpu))
630 break; 634 break;
631 sig->cputime_expires.virt_exp = exp->cpu; 635 sig->cputime_expires.virt_exp = exp->cpu;
632 break; 636 break;
633 case CPUCLOCK_PROF: 637 case CPUCLOCK_PROF:
634 if (!cputime_eq(sig->it[CPUCLOCK_PROF].expires, 638 if (expires_le(sig->it[CPUCLOCK_PROF].expires,
635 cputime_zero) &&
636 cputime_lt(sig->it[CPUCLOCK_PROF].expires,
637 exp->cpu)) 639 exp->cpu))
638 break; 640 break;
639 i = sig->rlim[RLIMIT_CPU].rlim_cur; 641 i = sig->rlim[RLIMIT_CPU].rlim_cur;