From 110c16cb01265099e33d79d4edec952c02f251fb Mon Sep 17 00:00:00 2001 From: Vincent Dupont Date: Mon, 9 Jul 2018 13:57:13 +0200 Subject: [PATCH] cpu/stm32f0: add periph_pm support --- cpu/stm32_common/include/periph_cpu_common.h | 7 +- cpu/stm32_common/periph/pm.c | 75 ++++++++++++++------ cpu/stm32f0/Makefile.include | 2 + 3 files changed, 61 insertions(+), 23 deletions(-) diff --git a/cpu/stm32_common/include/periph_cpu_common.h b/cpu/stm32_common/include/periph_cpu_common.h index ef036dd56436d..ce11fde418c4a 100644 --- a/cpu/stm32_common/include/periph_cpu_common.h +++ b/cpu/stm32_common/include/periph_cpu_common.h @@ -77,9 +77,10 @@ extern "C" { /** * @brief Number of usable low power modes */ -#if defined(CPU_FAM_STM32F1) || defined(CPU_FAM_STM32F2) || \ - defined(CPU_FAM_STM32F4) || defined(CPU_FAM_STM32L0) || \ - defined(CPU_FAM_STM32L1) || defined(DOXYGEN) +#if defined(CPU_FAM_STM32F0) || defined(CPU_FAM_STM32F1) || \ + defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \ + defined(CPU_FAM_STM32L0) || defined(CPU_FAM_STM32L1) || \ + defined(DOXYGEN) #define PM_NUM_MODES (2U) /** diff --git a/cpu/stm32_common/periph/pm.c b/cpu/stm32_common/periph/pm.c index 0fceee1b9ba7a..6a744ca97fd75 100644 --- a/cpu/stm32_common/periph/pm.c +++ b/cpu/stm32_common/periph/pm.c @@ -2,6 +2,7 @@ * Copyright (C) 2016 Kaspar Schleiser * 2015 Freie Universität Berlin * 2015 Engineering-Spirit + * 2017-2018 OTA keys S.A. * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level @@ -19,15 +20,16 @@ * @author Nick v. IJzendoorn * @author Kaspar Schleiser * @author Fabian Nack + * @author Vincent Dupont * * @} */ #include "irq.h" #include "periph/pm.h" -#if defined(CPU_FAM_STM32F1) || defined(CPU_FAM_STM32F2) || \ - defined(CPU_FAM_STM32F4) || defined(CPU_FAM_STM32L0) || \ - defined(CPU_FAM_STM32L1) +#if defined(CPU_FAM_STM32F0) || defined(CPU_FAM_STM32F1) || \ + defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \ + defined(CPU_FAM_STM32L0) || defined(CPU_FAM_STM32L1) #include "stmclk.h" #endif @@ -40,8 +42,48 @@ * * Available values can be found in reference manual, PWR section, register CR. */ +#if defined(CPU_FAM_STM32F0) +#define PM_STOP_CONFIG (PWR_CR_LPDS) +#else #define PM_STOP_CONFIG (PWR_CR_LPDS | PWR_CR_FPDS) #endif +#endif + +static inline uint32_t _ewup_config(void) +{ + uint32_t tmp = 0; +#ifdef PM_EWUP_CONFIG + tmp |= PM_EWUP_CONFIG; +#elif defined(PWR_CSR_EWUP) + tmp |= PWR_CSR_EWUP; +#else +#if defined(PWR_CSR_EWUP8) + tmp |= PWR_CSR_EWUP8; +#endif +#if defined(PWR_CSR_EWUP7) + tmp |= PWR_CSR_EWUP7; +#endif +#if defined(PWR_CSR_EWUP6) + tmp |= PWR_CSR_EWUP6; +#endif +#if defined(PWR_CSR_EWUP5) + tmp |= PWR_CSR_EWUP5; +#endif +#if defined(PWR_CSR_EWUP4) + tmp |= PWR_CSR_EWUP4; +#endif +#if defined(PWR_CSR_EWUP3) + tmp |= PWR_CSR_EWUP3; +#endif +#if defined(PWR_CSR_EWUP2) + tmp |= PWR_CSR_EWUP2; +#endif +#if defined(PWR_CSR_EWUP1) + tmp |= PWR_CSR_EWUP1; +#endif +#endif + return tmp; +} void pm_set(unsigned mode) { @@ -49,9 +91,9 @@ void pm_set(unsigned mode) /* I just copied it from stm32f1/2/4, but I suppose it would work for the * others... /KS */ -#if defined(CPU_FAM_STM32F1) || defined(CPU_FAM_STM32F2) || \ - defined(CPU_FAM_STM32F4) || defined(CPU_FAM_STM32L0) || \ - defined(CPU_FAM_STM32L1) +#if defined(CPU_FAM_STM32F0) || defined(CPU_FAM_STM32F1) || \ + defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \ + defined(CPU_FAM_STM32L0) || defined(CPU_FAM_STM32L1) switch (mode) { case STM32_PM_STANDBY: /* Set PDDS to enter standby mode on deepsleep and clear flags */ @@ -60,15 +102,8 @@ void pm_set(unsigned mode) #if defined(CPU_FAM_STM32L0) || defined(CPU_FAM_STM32L1) /* Enable Ultra Low Power mode */ PWR->CR |= PWR_CR_ULP; - - PWR->CSR |= PWR_CSR_EWUP1; -#if !defined(CPU_LINE_STM32L053xx) - /* STM32L053 only have 2 wake pins */ - PWR->CSR |= PWR_CSR_EWUP3; -#endif -#else - PWR->CSR |= PWR_CSR_EWUP; #endif + PWR->CSR |= _ewup_config(); /* Set SLEEPDEEP bit of system control block */ deep = 1; break; @@ -99,9 +134,9 @@ void pm_set(unsigned mode) cortexm_sleep(deep); -#if defined(CPU_FAM_STM32F1) || defined(CPU_FAM_STM32F2) || \ - defined(CPU_FAM_STM32F4) || defined(CPU_FAM_STM32L0) || \ - defined(CPU_FAM_STM32L1) +#if defined(CPU_FAM_STM32F0) || defined(CPU_FAM_STM32F1) || \ + defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \ + defined(CPU_FAM_STM32L0) || defined(CPU_FAM_STM32L1) if (deep) { /* Re-init clock after STOP */ stmclk_init_sysclk(); @@ -109,9 +144,9 @@ void pm_set(unsigned mode) #endif } -#if defined(CPU_FAM_STM32F1) || defined(CPU_FAM_STM32F2) || \ - defined(CPU_FAM_STM32F4) || defined(CPU_FAM_STM32L0) || \ - defined(CPU_FAM_STM32L1) +#if defined(CPU_FAM_STM32F0) || defined(CPU_FAM_STM32F1) || \ + defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \ + defined(CPU_FAM_STM32L0) || defined(CPU_FAM_STM32L1) void pm_off(void) { irq_disable(); diff --git a/cpu/stm32f0/Makefile.include b/cpu/stm32f0/Makefile.include index 18fc5c661dc29..2010afd0ad4cc 100644 --- a/cpu/stm32f0/Makefile.include +++ b/cpu/stm32f0/Makefile.include @@ -1,5 +1,7 @@ export CPU_ARCH = cortex-m0 export CPU_FAM = stm32f0 +USEMODULE += pm_layered + include $(RIOTCPU)/stm32_common/Makefile.include include $(RIOTMAKE)/arch/cortexm.inc.mk