15#ifndef LIBBSP_ARM_STM32F4_STM32F4XXXX_FLASH_H
16#define LIBBSP_ARM_STM32F4_STM32F4XXXX_FLASH_H
23#define STM32F4_FLASH_ACR_DCRST BSP_BIT32(12)
24#define STM32F4_FLASH_ACR_ICRST BSP_BIT32(11)
25#define STM32F4_FLASH_ACR_DCEN BSP_BIT32(10)
26#define STM32F4_FLASH_ACR_ICEN BSP_BIT32(9)
27#define STM32F4_FLASH_ACR_PRFTEN BSP_BIT32(8)
28#define STM32F4_FLASH_ACR_LATENCY(val) BSP_FLD32(val, 0, 2)
29#define STM32F4_FLASH_ACR_LATENCY_GET(reg) BSP_FLD32GET(reg, 0, 2)
30#define STM32F4_FLASH_ACR_LATENCY_SET(reg, val) BSP_FLD32SET(reg, val, 0, 2)
33#define STM32F4_FLASH_KEYR_KEY1 0x45670123
34#define STM32F4_FLASH_KEYR_KEY2 0xCDEF89AB
37#define STM32F4_FLASH_OPTKEYR_OPTKEY1 0x08192A3B
38#define STM32F4_FLASH_OPTKEYR_OPTKEY2 0x4C5D6E7F
41#define STM32F4_FLASH_SR_BSY BSP_BIT32(16)
42#define STM32F4_FLASH_SR_PGSERR BSP_BIT32(7)
43#define STM32F4_FLASH_SR_PGPERR BSP_BIT32(6)
44#define STM32F4_FLASH_SR_PGAERR BSP_BIT32(5)
45#define STM32F4_FLASH_SR_WRPERR BSP_BIT32(4)
46#define STM32F4_FLASH_SR_OPERR BSP_BIT32(1)
47#define STM32F4_FLASH_SR_EOP BSP_BIT32(0)
50#define STM32F4_FLASH_CR_LOCK BSP_BIT32(31)
51#define STM32F4_FLASH_CR_ERRIE BSP_BIT32(25)
52#define STM32F4_FLASH_CR_EOPIE BSP_BIT32(24)
53#define STM32F4_FLASH_CR_STRT BSP_BIT32(16)
54#define STM32F4_FLASH_CR_PSIZE(val) BSP_FLD32(val, 8, 9)
55#define STM32F4_FLASH_CR_PSIZE_GET(reg) BSP_FLD32GET(reg, 8, 9)
56#define STM32F4_FLASH_CR_PSIZE_SET(reg, val) BSP_FLD32SET(reg, val, 8, 9)
57#define STM32F4_FLASH_CR_SNB BSP_FLD32(val, 3, 6)
58#define STM32F4_FLASH_CR_SNB_GET(reg) BSP_FLD32GET(reg, 3, 6)
59#define STM32F4_FLASH_CR_SNB_SET(reg, val) BSP_FLD32SET(reg, val, 3, 6)
60#define STM32F4_FLASH_CR_MER BSP_BIT32(2)
61#define STM32F4_FLASH_CR_SER BSP_BIT32(1)
62#define STM32F4_FLASH_CR_PG BSP_BIT32(0)
65#define STM32F4_FLASH_OPTCR_NWRP(val) BSP_FLD32(val, 16, 27)
66#define STM32F4_FLASH_OPTCR_NWRP_GET(reg) BSP_FLD32GET(reg, 16, 27)
67#define STM32F4_FLASH_OPTCR_NWRP_SET(reg, val) BSP_FLD32SET(reg, val, 16, 27)
68#define STM32F4_FLASH_OPTCR_RDP(val) BSP_FLD32(val, 8, 15)
69#define STM32F4_FLASH_OPTCR_RDP_GET(reg) BSP_FLD32GET(reg, 8, 15)
70#define STM32F4_FLASH_OPTCR_RDP_SET(reg, val) BSP_FLD32SET(reg, val, 8, 15)
71#define STM32F4_FLASH_OPTCR_USER(val) BSP_FLD32(val, 5, 7)
72#define STM32F4_FLASH_OPTCR_USER_GET(reg) BSP_FLD32GET(reg, 5, 7)
73#define STM32F4_FLASH_OPTCR_USER_SET(reg, val) BSP_FLD32SET(reg, val, 5, 7)
74#define STM32F4_FLASH_OPTCR_BOR_LEVEL(val) BSP_FLD32(val, 2, 3)
75#define STM32F4_FLASH_OPTCR_BOR_LEVEL_GET(reg) BSP_FLD32GET(reg, 2, 3)
76#define STM32F4_FLASH_OPTCR_BOR_LEVEL_SET(reg, val) BSP_FLD32SET(reg, val, 2, 3)
77#define STM32F4_FLASH_CR_OPTSTRT BSP_BIT32(1)
78#define STM32F4_FLASH_CR_OPTLOCK BSP_BIT32(0)
unsigned short int uint16 __attribute__((__may_alias__))
Perform a 32-bit endian conversion.
Definition: mcf5282.h:37
This header file provides utility macros for BSPs.
Definition: stm32f4xxxx_flash.h:20