1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

cpu/stm32wl: Flashpage configuration

This commit is contained in:
Akshai M 2021-04-09 14:49:44 +02:00
parent df1cae172c
commit 2cf081b509
7 changed files with 31 additions and 13 deletions

View File

@ -1,2 +1,18 @@
# CPU2 defines a restricted memory region. This is not available for
# CPU1 linking or general access, for now we define it by its default
# value.
# The value is descrbed in section 4.10.19 FLASH secure Flash start address
# register (FLASH_SFR) in SFSA[6:0] register of reference manual.
# 0x0003 F800 -> 254K -> 2K left for CPU2.
CPU2_ROM_LEN = 2K
# CPU2 can define restricted SRAM within SRAM2a and SRAM2b. These subregions
# will generate busfaults if accessed by CPU1. For now we will assume that both
# SRAM2a regions are completely dedicated to CPU2.
# The value is described in section 4.10.20 FLASH secure SRAM start address and CPU2
# reset vector register(FLASH_SRRVR) in SBRSA[4:0] of reference manual.
# Section 4.6.4 CPU2 security (ESE) provides detailed information on the same.
CPU2_RAM_LEN = 1K
# load the common Makefile.include for Nucleo boards # load the common Makefile.include for Nucleo boards
include $(RIOTBOARD)/common/nucleo64/Makefile.include include $(RIOTBOARD)/common/nucleo64/Makefile.include

View File

@ -11,7 +11,7 @@ FEATURES_PROVIDED += periph_timer_periodic
FEATURES_PROVIDED += periph_uart_modecfg FEATURES_PROVIDED += periph_uart_modecfg
FEATURES_PROVIDED += periph_uart_nonblocking FEATURES_PROVIDED += periph_uart_nonblocking
ifneq (,$(filter $(CPU_FAM),f0 f1 f3 g0 g4 l0 l1 l4 l5 wb)) ifneq (,$(filter $(CPU_FAM),f0 f1 f3 g0 g4 l0 l1 l4 l5 wb wl))
FEATURES_PROVIDED += periph_flashpage FEATURES_PROVIDED += periph_flashpage
FEATURES_PROVIDED += periph_flashpage_pagewise FEATURES_PROVIDED += periph_flashpage_pagewise
endif endif

View File

@ -12,7 +12,7 @@ KB := 1024
ROM_LEN_K := $(shell echo $(ROM_LEN) | sed 's/K//') ROM_LEN_K := $(shell echo $(ROM_LEN) | sed 's/K//')
RAM_LEN_K := $(shell echo $(RAM_LEN) | sed 's/K//') RAM_LEN_K := $(shell echo $(RAM_LEN) | sed 's/K//')
ifeq (stm32wb55rg,$(CPU_MODEL)) ifneq (,$(filter w%,$(CPU_FAM)))
# adjust RAM_LEN and ROM_LEN according to CPU2 RAM_LEN and ROM_LEN # adjust RAM_LEN and ROM_LEN according to CPU2 RAM_LEN and ROM_LEN
CPU2_RAM_LEN_K := $(shell echo $(CPU2_RAM_LEN) | sed 's/K//') CPU2_RAM_LEN_K := $(shell echo $(CPU2_RAM_LEN) | sed 's/K//')
RAM_LEN := $(shell echo $$(( ($(RAM_LEN_K) - $(CPU2_RAM_LEN_K) ) * $(KB) ))) RAM_LEN := $(shell echo $$(( ($(RAM_LEN_K) - $(CPU2_RAM_LEN_K) ) * $(KB) )))

View File

@ -106,7 +106,7 @@ extern "C" {
|| defined(CPU_LINE_STM32F030xC) || defined(CPU_LINE_STM32F103xE) \ || defined(CPU_LINE_STM32F030xC) || defined(CPU_LINE_STM32F103xE) \
|| defined(CPU_FAM_STM32F3) || defined(CPU_FAM_STM32L4) \ || defined(CPU_FAM_STM32F3) || defined(CPU_FAM_STM32L4) \
|| defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) \ || defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) \
|| defined(CPU_FAM_STM32L5) || defined(CPU_FAM_STM32L5) || defined(CPU_FAM_STM32WL)
#define FLASHPAGE_SIZE (2048U) #define FLASHPAGE_SIZE (2048U)
#elif defined(CPU_LINE_STM32F051x8) || defined(CPU_LINE_STM32F042x6) \ #elif defined(CPU_LINE_STM32F051x8) || defined(CPU_LINE_STM32F042x6) \
|| defined(CPU_LINE_STM32F070xB) || defined(CPU_LINE_STM32F030x8) \ || defined(CPU_LINE_STM32F070xB) || defined(CPU_LINE_STM32F030x8) \
@ -195,7 +195,7 @@ extern "C" {
*/ */
#if defined(CPU_FAM_STM32L4) || defined(CPU_FAM_STM32WB) || \ #if defined(CPU_FAM_STM32L4) || defined(CPU_FAM_STM32WB) || \
defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) || \ defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) || \
defined(CPU_FAM_STM32L5) defined(CPU_FAM_STM32L5) || defined(CPU_FAM_STM32WL)
#define FLASHPAGE_WRITE_BLOCK_SIZE (8U) #define FLASHPAGE_WRITE_BLOCK_SIZE (8U)
typedef uint64_t stm32_flashpage_block_t; typedef uint64_t stm32_flashpage_block_t;
#elif defined(CPU_FAM_STM32L0) || defined(CPU_FAM_STM32L1) || \ #elif defined(CPU_FAM_STM32L0) || defined(CPU_FAM_STM32L1) || \
@ -210,7 +210,7 @@ typedef uint16_t stm32_flashpage_block_t;
#if defined(CPU_FAM_STM32L4) || defined(CPU_FAM_STM32WB) || \ #if defined(CPU_FAM_STM32L4) || defined(CPU_FAM_STM32WB) || \
defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) || \ defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) || \
defined(CPU_FAM_STM32L5) defined(CPU_FAM_STM32L5) || defined(CPU_FAM_STM32WL)
#define FLASHPAGE_WRITE_BLOCK_ALIGNMENT (8U) #define FLASHPAGE_WRITE_BLOCK_ALIGNMENT (8U)
#else #else
/* Writing should be always 4 bytes aligned */ /* Writing should be always 4 bytes aligned */

View File

@ -42,7 +42,7 @@
#if defined(CPU_FAM_STM32L4) || defined(CPU_FAM_STM32WB) || \ #if defined(CPU_FAM_STM32L4) || defined(CPU_FAM_STM32WB) || \
defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) || \ defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) || \
defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \ defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \
defined(CPU_FAM_STM32F7) defined(CPU_FAM_STM32F7) || defined(CPU_FAM_STM32WL)
#define FLASH_KEY1 ((uint32_t)0x45670123) #define FLASH_KEY1 ((uint32_t)0x45670123)
#define FLASH_KEY2 ((uint32_t)0xCDEF89AB) #define FLASH_KEY2 ((uint32_t)0xCDEF89AB)
#endif #endif

View File

@ -110,10 +110,12 @@ static void _erase_page(void *page_addr)
#elif defined(CPU_FAM_STM32L4) || defined(CPU_FAM_STM32WB) || \ #elif defined(CPU_FAM_STM32L4) || defined(CPU_FAM_STM32WB) || \
defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) || \ defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0) || \
defined(CPU_FAM_STM32L5) || defined(CPU_FAM_STM32F2) || \ defined(CPU_FAM_STM32L5) || defined(CPU_FAM_STM32F2) || \
defined(CPU_FAM_STM32F4) || defined(CPU_FAM_STM32F7) defined(CPU_FAM_STM32F4) || defined(CPU_FAM_STM32F7) || \
defined(CPU_FAM_STM32WL)
DEBUG("[flashpage] erase: setting the page address\n"); DEBUG("[flashpage] erase: setting the page address\n");
uint8_t pn; uint8_t pn;
#if (FLASHPAGE_NUMOF <= MAX_PAGES_PER_BANK) || defined(CPU_FAM_STM32WB) #if (FLASHPAGE_NUMOF <= MAX_PAGES_PER_BANK) || defined(CPU_FAM_STM32WB) || \
defined(CPU_FAM_STM32WL)
pn = (uint8_t)flashpage_page(page_addr); pn = (uint8_t)flashpage_page(page_addr);
#else #else
uint16_t page = flashpage_page(page_addr); uint16_t page = flashpage_page(page_addr);
@ -188,7 +190,7 @@ void flashpage_erase(unsigned page)
assert(page < (int)FLASHPAGE_NUMOF); assert(page < (int)FLASHPAGE_NUMOF);
/* ensure there is no attempt to write to CPU2 protected area */ /* ensure there is no attempt to write to CPU2 protected area */
#if defined(CPU_FAM_STM32WB) #if defined(CPU_FAM_STM32WB) || defined(CPU_FAM_STM32WL)
assert(page < (int)(FLASH->SFR & FLASH_SFR_SFSA)); assert(page < (int)(FLASH->SFR & FLASH_SFR_SFSA));
#endif #endif
@ -253,7 +255,7 @@ void flashpage_write(void *target_addr, const void *data, size_t len)
defined(CPU_FAM_STM32WB) || defined(CPU_FAM_STM32G4) || \ defined(CPU_FAM_STM32WB) || defined(CPU_FAM_STM32G4) || \
defined(CPU_FAM_STM32G0) || defined(CPU_FAM_STM32L5) || \ defined(CPU_FAM_STM32G0) || defined(CPU_FAM_STM32L5) || \
defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \ defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \
defined(CPU_FAM_STM32F7) defined(CPU_FAM_STM32F7) || defined(CPU_FAM_STM32WL)
/* set PG bit and program page to flash */ /* set PG bit and program page to flash */
CNTRL_REG |= FLASH_CR_PG; CNTRL_REG |= FLASH_CR_PG;
#endif #endif
@ -273,7 +275,7 @@ void flashpage_write(void *target_addr, const void *data, size_t len)
defined(CPU_FAM_STM32WB) || defined(CPU_FAM_STM32G4) || \ defined(CPU_FAM_STM32WB) || defined(CPU_FAM_STM32G4) || \
defined(CPU_FAM_STM32G0) || defined(CPU_FAM_STM32L5) || \ defined(CPU_FAM_STM32G0) || defined(CPU_FAM_STM32L5) || \
defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \ defined(CPU_FAM_STM32F2) || defined(CPU_FAM_STM32F4) || \
defined(CPU_FAM_STM32F7) defined(CPU_FAM_STM32F7) || defined(CPU_FAM_STM32WL)
CNTRL_REG &= ~(FLASH_CR_PG); CNTRL_REG &= ~(FLASH_CR_PG);
#endif #endif
DEBUG("[flashpage_raw] write: done writing data\n"); DEBUG("[flashpage_raw] write: done writing data\n");

View File

@ -33,7 +33,7 @@ void flashpage_read(unsigned page, void *data)
{ {
assert(page < FLASHPAGE_NUMOF); assert(page < FLASHPAGE_NUMOF);
#if defined(CPU_FAM_STM32WB) #if defined(CPU_FAM_STM32WB) || defined(CPU_FAM_STM32WL)
assert(page < (FLASH->SFR & FLASH_SFR_SFSA)); assert(page < (FLASH->SFR & FLASH_SFR_SFSA));
#endif #endif
@ -44,7 +44,7 @@ int flashpage_verify(unsigned page, const void *data)
{ {
assert(page < (int)FLASHPAGE_NUMOF); assert(page < (int)FLASHPAGE_NUMOF);
#if defined(CPU_FAM_STM32WB) #if defined(CPU_FAM_STM32WB) || defined(CPU_FAM_STM32WL)
assert(page < (int)(FLASH->SFR & FLASH_SFR_SFSA)); assert(page < (int)(FLASH->SFR & FLASH_SFR_SFSA));
#endif #endif