From 1155f57710a068efbdc7fdd167ac4e44dd54ec7f Mon Sep 17 00:00:00 2001 From: Karl Palsson Date: Wed, 12 Jan 2022 17:30:15 +0000 Subject: stm32wb: rtc: initial registers Backup registers are just hardcoded to 32, which is the max seen. Note that the STM32WB only has 20! I've captured that in the platform yaml, even though it's not used anywhere (yet?) Signed-off-by: Karl Palsson --- rtc/stm32_rtc.h | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 rtc/stm32_rtc.h (limited to 'rtc/stm32_rtc.h') diff --git a/rtc/stm32_rtc.h b/rtc/stm32_rtc.h new file mode 100644 index 0000000..bc78128 --- /dev/null +++ b/rtc/stm32_rtc.h @@ -0,0 +1,44 @@ +#pragma once + +#include + +struct STM32_RTC_reg_v2ss_t { + volatile uint32_t TR; + volatile uint32_t DR; + volatile uint32_t CR; + volatile uint32_t ISR; + volatile uint32_t PRER; + volatile uint32_t WUTR; + uint32_t _reserved1; + volatile uint32_t ALRMAR; + volatile uint32_t ALRMBR; + volatile uint32_t WPR; + volatile uint32_t SSR; + volatile uint32_t SHIFTR; + volatile uint32_t TSTR; + volatile uint32_t TSDR; + volatile uint32_t TSSSR; + volatile uint32_t CALR; + volatile uint32_t TAMPCR; + volatile uint32_t ALRMASSR; + volatile uint32_t ALRMBSSR; + volatile uint32_t OR; + volatile uint32_t BKP[32]; /* max known 32, might be less, check DS */ +}; + +template +class STM32_RTC_t : public mmio_ptr { + public: + using mmio_ptr::ptr; + + void lock(void) const { + ptr()->WPR = 0x99; // Doesn't matter... + } + + void unlock(void) const { + ptr()->WPR = 0xCA; + ptr()->WPR = 0x53; + } + +}; + -- cgit v1.2.3