diff options
author | Daniel Friesel <daniel.friesel@uos.de> | 2020-08-12 13:20:23 +0200 |
---|---|---|
committer | Daniel Friesel <daniel.friesel@uos.de> | 2020-08-12 13:20:23 +0200 |
commit | 23f7b0e4ed05685e89c5c1d8d92556106b0845ff (patch) | |
tree | 39c5ef116ef274fd38c7d6ef15d78711517e89ee /src/arch/stm32f446re-nucleo/arch.cc | |
parent | 8458978ad5512dc813ac700d59983c56917fa205 (diff) |
stm32f446re: Add uptime counter and proper loop mode with standby in between
Diffstat (limited to 'src/arch/stm32f446re-nucleo/arch.cc')
-rw-r--r-- | src/arch/stm32f446re-nucleo/arch.cc | 51 |
1 files changed, 49 insertions, 2 deletions
diff --git a/src/arch/stm32f446re-nucleo/arch.cc b/src/arch/stm32f446re-nucleo/arch.cc index 12a612a..4634088 100644 --- a/src/arch/stm32f446re-nucleo/arch.cc +++ b/src/arch/stm32f446re-nucleo/arch.cc @@ -1,3 +1,7 @@ +#include <libopencm3/cm3/nvic.h> +#include <libopencm3/stm32/rcc.h> +#include <libopencm3/stm32/gpio.h> +#include <libopencm3/stm32/timer.h> #include "arch.h" #ifdef __acweaving @@ -6,6 +10,27 @@ void Arch::setup(void) { + // NUCLEO-F443RE uses 8MHz STLINK clock as input + rcc_clock_setup_pll(&rcc_hse_8mhz_3v3[RCC_CLOCK_3V3_168MHZ]); +#ifdef WITH_LOOP + rcc_periph_clock_enable(RCC_TIM2); + nvic_enable_irq(NVIC_TIM2_IRQ); + rcc_periph_reset_pulse(RST_TIM2); + + + timer_set_mode(TIM2, TIM_CR1_CKD_CK_INT, + TIM_CR1_CMS_EDGE, TIM_CR1_DIR_UP); + // 10 kHz timer frequency + timer_set_prescaler(TIM2, ((rcc_apb1_frequency * 2) / 10000)); + + timer_disable_preload(TIM2); // ? + timer_continuous_mode(TIM2); // ? + + timer_set_period(TIM2, 10000); + + timer_enable_counter(TIM2); + timer_enable_irq(TIM2, TIM_DIER_UIE); +#endif } #ifdef WITH_WAKEUP @@ -37,9 +62,13 @@ void Arch::delay_ms(unsigned int const ms) void Arch::idle_loop(void) { while (1) { - delay_ms(1000); + pwr_set_standby_mode(); + __asm__("wfi"); #ifdef WITH_LOOP - loop(); + if (run_loop) { + loop(); + run_loop = 0; + } #endif } } @@ -52,3 +81,21 @@ void Arch::idle(void) } Arch arch; + +#if defined(WITH_LOOP) || defined(TIMER_S) + +#include "driver/uptime.h" + +void tim2_isr(void) +{ + if (timer_get_flag(TIM2, TIM_SR_UIF)) { + timer_clear_flag(TIM2, TIM_SR_UIF); +#ifdef WITH_LOOP + run_loop = 1; +#endif +#ifdef TIMER_S + uptime.tick_s(); +#endif + } +} +#endif |