diff options
author | Scott Soule Cheloha <cheloha@cvs.openbsd.org> | 2023-01-20 17:18:09 +0000 |
---|---|---|
committer | Scott Soule Cheloha <cheloha@cvs.openbsd.org> | 2023-01-20 17:18:09 +0000 |
commit | ae904be09ea0d3f5691fe4b70b497543684c9d70 (patch) | |
tree | 9c2eabb3fe128cb643e22932f5bd842d6349120a | |
parent | 2a45d73644445b5aa1ecf8c5bf1abdff39308d1b (diff) |
hppa: simplify itmr_rearm()
The nest of branches in itmr_rearm() can be simplified to:
if (cycles <= t1 - t0) {
/* we probably missed */
}
We're doing modular unsigned 32-bit, so the rollover case in the
current code is superfluous.
Tested by miod@.
"Works for me." miod@
-rw-r--r-- | sys/arch/hppa/dev/clock.c | 34 |
1 files changed, 9 insertions, 25 deletions
diff --git a/sys/arch/hppa/dev/clock.c b/sys/arch/hppa/dev/clock.c index 3af77b25f37..79d08d989c8 100644 --- a/sys/arch/hppa/dev/clock.c +++ b/sys/arch/hppa/dev/clock.c @@ -1,4 +1,4 @@ -/* $OpenBSD: clock.c,v 1.33 2022/12/06 00:40:09 cheloha Exp $ */ +/* $OpenBSD: clock.c,v 1.34 2023/01/20 17:18:08 cheloha Exp $ */ /* * Copyright (c) 1998-2003 Michael Shalayeff @@ -162,7 +162,7 @@ itmr_get_timecount(struct timecounter *tc) void itmr_rearm(void *unused, uint64_t nsecs) { - uint32_t cycles, t0, t1, target; + uint32_t cycles, t0, t1; register_t eiem, eirr; if (nsecs > itmr_nsec_max) @@ -171,33 +171,17 @@ itmr_rearm(void *unused, uint64_t nsecs) eiem = hppa_intr_disable(); mfctl(CR_ITMR, t0); - target = t0 + cycles; - mtctl(target, CR_ITMR); + mtctl(t0 + cycles, CR_ITMR); mfctl(CR_ITMR, t1); + mfctl(CR_EIRR, eirr); /* - * If the interrupt isn't already pending we need to check if - * we missed. In general, we are checking whether ITMR had - * already passed the target value when we wrote the register. - * There are two cases. - * - * 1. If (t0 + cycles) did not overflow, we want t1 to be between - * t0 and target. If t0 <= t1 < target, we didn't miss. - * - * 2. If (t0 + cycles) overflowed, either t0 <= t1 or t1 < target - * are sufficient to show we didn't miss. - * - * Only try once. Fall back to itmr_trigger_masked() if we miss. + * If at least "cycles" ITMR ticks have elapsed and the interrupt + * isn't pending, we missed. Fall back to itmr_trigger_masked(). */ - mfctl(CR_EIRR, eirr); - if (!ISSET(eirr, 1U << 31)) { - if (t0 <= target) { - if (target <= t1 || t1 < t0) - itmr_trigger_masked(); - } else { - if (target <= t1 && t1 < t0) - itmr_trigger_masked(); - } + if (cycles <= t1 - t0) { + if (!ISSET(eirr, 1U << 31)) + itmr_trigger_masked(); } hppa_intr_enable(eiem); } |