aboutsummaryrefslogtreecommitdiffstats
path: root/src/generic/armcm_timer.c
diff options
context:
space:
mode:
authorKevin O'Connor <kevin@koconnor.net>2019-06-09 20:26:30 -0400
committerKevin O'Connor <kevin@koconnor.net>2019-06-09 20:27:57 -0400
commit700e35c6ac74a64719fbc38fe66386dd422613f3 (patch)
tree2a829c04c12f3b6393d842f1835c2f8f8df023dc /src/generic/armcm_timer.c
parent97840f9851772ffbcc99b8e33c82b0af4770baa8 (diff)
downloadkutter-700e35c6ac74a64719fbc38fe66386dd422613f3.tar.gz
kutter-700e35c6ac74a64719fbc38fe66386dd422613f3.tar.xz
kutter-700e35c6ac74a64719fbc38fe66386dd422613f3.zip
armcm_timer: Unify udelay() implementation
Move the udelay() code from various arm board directories into the src/generic/armcm_timer.c code. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
Diffstat (limited to 'src/generic/armcm_timer.c')
-rw-r--r--src/generic/armcm_timer.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/generic/armcm_timer.c b/src/generic/armcm_timer.c
index a9c8ab9f..7f11cd68 100644
--- a/src/generic/armcm_timer.c
+++ b/src/generic/armcm_timer.c
@@ -54,6 +54,20 @@ timer_kick(void)
SCB->ICSR = SCB_ICSR_PENDSTSET_Msk;
}
+// Implement simple early-boot delay mechanism
+void
+udelay(uint32_t usecs)
+{
+ if (!(CoreDebug->DEMCR & CoreDebug_DEMCR_TRCENA_Msk)) {
+ CoreDebug->DEMCR |= CoreDebug_DEMCR_TRCENA_Msk;
+ DWT->CTRL |= DWT_CTRL_CYCCNTENA_Msk;
+ }
+
+ uint32_t end = timer_read_time() + timer_from_us(usecs);
+ while (timer_is_before(timer_read_time(), end))
+ ;
+}
+
void
timer_init(void)
{