aboutsummaryrefslogtreecommitdiffstats
path: root/app/ticker.c
diff options
context:
space:
mode:
authorroot <root@no.no.james.local>2017-06-13 21:10:37 +0100
committerroot <root@no.no.james.local>2017-06-13 21:10:37 +0100
commiteaf5d4799cc52e9dd1ebcaeafbf8f670658fea98 (patch)
treebbeb1993818c5fc8cbcf5a001080f246facc8de6 /app/ticker.c
downloadserial_over_dp-eaf5d4799cc52e9dd1ebcaeafbf8f670658fea98.tar.gz
serial_over_dp-eaf5d4799cc52e9dd1ebcaeafbf8f670658fea98.tar.bz2
serial_over_dp-eaf5d4799cc52e9dd1ebcaeafbf8f670658fea98.zip
inital commit
Diffstat (limited to 'app/ticker.c')
-rw-r--r--app/ticker.c76
1 files changed, 76 insertions, 0 deletions
diff --git a/app/ticker.c b/app/ticker.c
new file mode 100644
index 0000000..05990d2
--- /dev/null
+++ b/app/ticker.c
@@ -0,0 +1,76 @@
+#include "project.h"
+
+
+static volatile uint32_t ticks;
+static uint32_t scale = 7;
+
+unsigned led1 = 1000, led2 = 1000;
+
+
+
+void
+delay_us (uint32_t d)
+{
+ d *= scale;
+
+ while (d--) {
+ __asm__ ("nop");
+ }
+}
+
+void
+sys_tick_handler (void)
+{
+ ticks++;
+ cdcacm_tick();
+
+ if (led1) {
+ led1--;
+ }
+
+ if (led2) {
+ led2--;
+ }
+
+ if (led1) {
+ gpio_clear (LED1_BANK, LED1_GPIO);
+ } else {
+ gpio_set (LED1_BANK, LED1_GPIO);
+ }
+
+ if (led2) {
+ gpio_clear (LED2_BANK, LED2_GPIO);
+ } else {
+ gpio_set (LED2_BANK, LED2_GPIO);
+ }
+}
+
+
+void
+ticker_init (void)
+{
+ uint32_t v, w;
+ /*Start periodic timer */
+ systick_set_clocksource (STK_CSR_CLKSOURCE_AHB_DIV8);
+ /* 48MHz / 8 = > 6Mhz */
+ systick_set_reload (6000);
+ /* 6MHz / 6000 => 1kHz */
+ systick_interrupt_enable();
+ systick_counter_enable();
+
+ /*Calibrate the delay loop */
+ do {
+ scale--;
+ v = ticks;
+
+ while (v == ticks) {
+ ;
+ }
+
+ delay_us (1000);
+ w = ticks;
+ v++;
+ w -= v;
+ } while (w);
+}
+