Fixes build issues associated with ARMv7-m mpu support files.

- inline functions within mpu.h converted to macros or moved to up_mpu.c
- mpu.h and up_mpu.c are now conditionally included in build via CONFIG_ARM_MPU

Chips affected by these changes
- imxrt
- kinetis
- lpc17xx
- lpc43xx
- lpc54xx
- sam34
- stm32
- stm32f7
- stm32h7
- stm32l4
- tiva
- xmc4
This commit is contained in:
John Rippetoe 2020-03-27 14:43:35 -04:00 committed by Xiang Xiao
parent 581dbb22fe
commit acb16e087a
16 changed files with 300 additions and 226 deletions

View File

@ -87,7 +87,7 @@
/* MPU Region Number Register Bit Definitions */ /* MPU Region Number Register Bit Definitions */
#if defined(CONFIG_ARM_MPU_NREGIONS) #if defined(CONFIG_ARM_MPU_NREGIONS) && defined(CONFIG_ARM_MPU)
# if CONFIG_ARM_MPU_NREGIONS <= 8 # if CONFIG_ARM_MPU_NREGIONS <= 8
# define MPU_RNR_MASK (0x00000007) # define MPU_RNR_MASK (0x00000007)
# elif CONFIG_ARM_MPU_NREGIONS <= 16 # elif CONFIG_ARM_MPU_NREGIONS <= 16
@ -132,7 +132,7 @@
# define MPU_RASR_TEX_SO (0 << MPU_RASR_TEX_SHIFT) /* Strongly Ordered */ # define MPU_RASR_TEX_SO (0 << MPU_RASR_TEX_SHIFT) /* Strongly Ordered */
# define MPU_RASR_TEX_NOR (1 << MPU_RASR_TEX_SHIFT) /* Normal */ # define MPU_RASR_TEX_NOR (1 << MPU_RASR_TEX_SHIFT) /* Normal */
# define MPU_RASR_TEX_DEV (2 << MPU_RASR_TEX_SHIFT) /* Device */ # define MPU_RASR_TEX_DEV (2 << MPU_RASR_TEX_SHIFT) /* Device */
# define MPU_RASR_TEX_BB(bb) (4|(bb)) << MPU_RASR_TEX_SHIFT) /* Normal BB AA */ # define MPU_RASR_TEX_BB(bb) ((4|(bb)) << MPU_RASR_TEX_SHIFT) /* Normal BB AA */
# define MPU_RASR_CP_NC (0) /* Non-cacheable */ # define MPU_RASR_CP_NC (0) /* Non-cacheable */
# define MPU_RASR_CP_WBRA (1) /* Write back, write and Read- Allocate */ # define MPU_RASR_CP_WBRA (1) /* Write back, write and Read- Allocate */
# define MPU_RASR_CP_WT (2) /* Write through, no Write-Allocate */ # define MPU_RASR_CP_WT (2) /* Write through, no Write-Allocate */
@ -147,6 +147,8 @@
# define MPU_RASR_AP_RORO (6 << MPU_RASR_AP_SHIFT) /* P:RO U:RO */ # define MPU_RASR_AP_RORO (6 << MPU_RASR_AP_SHIFT) /* P:RO U:RO */
# define MPU_RASR_XN (1 << 28) /* Bit 28: Instruction access disable */ # define MPU_RASR_XN (1 << 28) /* Bit 28: Instruction access disable */
#ifdef CONFIG_ARM_MPU
/***************************************************************************** /*****************************************************************************
* Public Function Prototypes * Public Function Prototypes
*****************************************************************************/ *****************************************************************************/
@ -213,6 +215,27 @@ uint8_t mpu_log2regionfloor(size_t size);
uint32_t mpu_subregion(uintptr_t base, size_t size, uint8_t l2size); uint32_t mpu_subregion(uintptr_t base, size_t size, uint8_t l2size);
/*****************************************************************************
* Name: mpu_control
*
* Description:
* Configure and enable (or disable) the MPU
*
*****************************************************************************/
void mpu_control(bool enable, bool hfnmiena, bool privdefena);
/*****************************************************************************
* Name: mpu_configure_region
*
* Description:
* Configure a region for privileged, strongly ordered memory
*
*****************************************************************************/
void mpu_configure_region(uintptr_t base, size_t size,
uint32_t flags);
/***************************************************************************** /*****************************************************************************
* Inline Functions * Inline Functions
*****************************************************************************/ *****************************************************************************/
@ -225,103 +248,19 @@ uint32_t mpu_subregion(uintptr_t base, size_t size, uint8_t l2size);
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_showtype(void)
{
#ifdef CONFIG_DEBUG_SCHED_INFO #ifdef CONFIG_DEBUG_SCHED_INFO
uint32_t regval = getreg32(MPU_TYPE); # define mpu_showtype() \
do \
sinfo("%s MPU Regions: data=%d instr=%d\n", { \
(regval & MPU_TYPE_SEPARATE) != 0 ? "Separate" : "Unified", uint32_t regval = getreg32(MPU_TYPE); \
(regval & MPU_TYPE_DREGION_MASK) >> MPU_TYPE_DREGION_SHIFT, sinfo("%s MPU Regions: data=%d instr=%d\n", \
(regval & MPU_TYPE_IREGION_MASK) >> MPU_TYPE_IREGION_SHIFT); (regval & MPU_TYPE_SEPARATE) != 0 ? "Separate" : "Unified", \
(regval & MPU_TYPE_DREGION_MASK) >> MPU_TYPE_DREGION_SHIFT, \
(regval & MPU_TYPE_IREGION_MASK) >> MPU_TYPE_IREGION_SHIFT); \
} while (0)
#else
# define mpu_showtype() do { } while (0)
#endif #endif
}
/*****************************************************************************
* Name: mpu_control
*
* Description:
* Configure and enable (or disable) the MPU
*
*****************************************************************************/
static inline void mpu_control(bool enable, bool hfnmiena, bool privdefena)
{
uint32_t regval = 0;
if (enable)
{
regval |= MPU_CTRL_ENABLE; /* Enable the MPU */
if (hfnmiena)
{
regval |= MPU_CTRL_HFNMIENA; /* Enable MPU during hard fault, NMI, and FAULTMAS */
}
if (privdefena)
{
regval |= MPU_CTRL_PRIVDEFENA; /* Enable privileged access to default memory map */
}
}
putreg32(regval, MPU_CTRL);
}
/*****************************************************************************
* Name: mpu_configure_region
*
* Description:
* Configure a region for privileged, strongly ordered memory
*
*****************************************************************************/
static inline void mpu_configure_region(uintptr_t base, size_t size,
uint32_t flags)
{
unsigned int region = mpu_allocregion();
uint32_t regval;
uint8_t l2size;
uint8_t subregions;
uintptr_t alignedbase;
/* Ensure the base address alignment
*
* ARMv7-M Architecture Reference Manual
* B3.5.8 MPU Region Base Address Register, MPU_RBAR
* "Software must ensure that the value written to the ADDR field
* aligns with the size of the selected region."
*/
alignedbase = base & MPU_RBAR_ADDR_MASK;
l2size = mpu_log2regionceil(size + base - alignedbase);
alignedbase &= ~((1 << l2size) - 1);
l2size = mpu_log2regionceil(size + base - alignedbase);
DEBUGASSERT(alignedbase + (1 << l2size) >= base + size);
DEBUGASSERT(l2size == 5 || alignedbase + (1 << (l2size - 1)) < base + size);
DEBUGASSERT((alignedbase & MPU_RBAR_ADDR_MASK) == alignedbase);
DEBUGASSERT((alignedbase & ((1 << l2size) - 1)) == 0);
/* Select the region */
putreg32(region, MPU_RNR);
/* Select the region base address */
putreg32(alignedbase | region | MPU_RBAR_VALID, MPU_RBAR);
/* Select the region size and the sub-region map */
subregions = mpu_subregion(base, size, l2size);
/* The configure the region */
regval = MPU_RASR_ENABLE | /* Enable region */
MPU_RASR_SIZE_LOG2((uint32_t)l2size) | /* Region size */
((uint32_t)subregions << MPU_RASR_SRD_SHIFT) | /* Sub-regions */
flags;
putreg32(regval, MPU_RASR);
}
/***************************************************************************** /*****************************************************************************
* Name: mpu_priv_stronglyordered * Name: mpu_priv_stronglyordered
@ -331,18 +270,18 @@ static inline void mpu_configure_region(uintptr_t base, size_t size,
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_priv_stronglyordered(uintptr_t base, size_t size) #define mpu_priv_stronglyordered(base, size) \
{ do \
/* The configure the region */ { \
/* The configure the region */ \
mpu_configure_region(base, size, mpu_configure_region(base, size, \
MPU_RASR_TEX_SO | /* Ordered */ MPU_RASR_TEX_SO | /* Ordered */ \
/* Not Cacheable */ /* Not Cacheable */ \
/* Not Bufferable */ /* Not Bufferable */ \
MPU_RASR_S | /* Shareable */ MPU_RASR_S | /* Shareable */ \
MPU_RASR_AP_RWNO /* P:RW U:None */ MPU_RASR_AP_RWNO /* P:RW U:None */ \
/* Instruction access */); /* Instruction access */); \
} } while (0)
/***************************************************************************** /*****************************************************************************
* Name: mpu_user_flash * Name: mpu_user_flash
@ -352,18 +291,18 @@ static inline void mpu_priv_stronglyordered(uintptr_t base, size_t size)
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_user_flash(uintptr_t base, size_t size) #define mpu_user_flash(base, size) \
{ do \
/* The configure the region */ { \
/* The configure the region */ \
mpu_configure_region(base, size, mpu_configure_region(base, size, \
MPU_RASR_TEX_SO | /* Ordered */ MPU_RASR_TEX_SO | /* Ordered */ \
MPU_RASR_C | /* Cacheable */ MPU_RASR_C | /* Cacheable */ \
/* Not Bufferable */ /* Not Bufferable */ \
/* Not Shareable */ /* Not Shareable */ \
MPU_RASR_AP_RORO /* P:RO U:RO */ MPU_RASR_AP_RORO /* P:RO U:RO */ \
/* Instruction access */); /* Instruction access */); \
} } while (0)
/***************************************************************************** /*****************************************************************************
* Name: mpu_priv_flash * Name: mpu_priv_flash
@ -373,18 +312,18 @@ static inline void mpu_user_flash(uintptr_t base, size_t size)
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_priv_flash(uintptr_t base, size_t size) #define mpu_priv_flash(base, size) \
{ do \
/* The configure the region */ { \
/* The configure the region */ \
mpu_configure_region(base, size, mpu_configure_region(base, size, \
MPU_RASR_TEX_SO | /* Ordered */ MPU_RASR_TEX_SO | /* Ordered */ \
MPU_RASR_C | /* Cacheable */ MPU_RASR_C | /* Cacheable */ \
/* Not Bufferable */ /* Not Bufferable */ \
/* Not Shareable */ /* Not Shareable */ \
MPU_RASR_AP_RONO /* P:RO U:None */ MPU_RASR_AP_RONO /* P:RO U:None */ \
/* Instruction access */); /* Instruction access */); \
} } while (0)
/***************************************************************************** /*****************************************************************************
* Name: mpu_user_intsram * Name: mpu_user_intsram
@ -394,18 +333,18 @@ mpu_configure_region(base, size,
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_user_intsram(uintptr_t base, size_t size) #define mpu_user_intsram(base, size) \
{ do \
/* The configure the region */ { \
/* The configure the region */ \
mpu_configure_region(base, size, mpu_configure_region(base, size, \
MPU_RASR_TEX_SO | /* Ordered */ MPU_RASR_TEX_SO | /* Ordered */ \
MPU_RASR_C | /* Cacheable */ MPU_RASR_C | /* Cacheable */ \
/* Not Bufferable */ /* Not Bufferable */ \
MPU_RASR_S | /* Shareable */ MPU_RASR_S | /* Shareable */ \
MPU_RASR_AP_RWRW /* P:RW U:RW */ MPU_RASR_AP_RWRW /* P:RW U:RW */ \
/* Instruction access */); /* Instruction access */); \
} } while (0)
/***************************************************************************** /*****************************************************************************
* Name: mpu_priv_intsram * Name: mpu_priv_intsram
@ -415,18 +354,18 @@ static inline void mpu_user_intsram(uintptr_t base, size_t size)
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_priv_intsram(uintptr_t base, size_t size) #define mpu_priv_intsram(base, size) \
{ do \
/* The configure the region */ { \
/* The configure the region */ \
mpu_configure_region(base, size, mpu_configure_region(base, size,\
MPU_RASR_TEX_SO | /* Ordered */ MPU_RASR_TEX_SO | /* Ordered */ \
MPU_RASR_C | /* Cacheable */ MPU_RASR_C | /* Cacheable */ \
/* Not Bufferable */ /* Not Bufferable */ \
MPU_RASR_S | /* Shareable */ MPU_RASR_S | /* Shareable */ \
MPU_RASR_AP_RWNO /* P:RW U:None */ MPU_RASR_AP_RWNO /* P:RW U:None */ \
/* Instruction access */); /* Instruction access */); \
} } while (0)
/***************************************************************************** /*****************************************************************************
* Name: mpu_user_extsram * Name: mpu_user_extsram
@ -436,18 +375,18 @@ static inline void mpu_priv_intsram(uintptr_t base, size_t size)
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_user_extsram(uintptr_t base, size_t size) #define mpu_user_extsram(base, size) \
{ do \
/* The configure the region */ { \
/* The configure the region */ \
mpu_configure_region(base, size, mpu_configure_region(base, size, \
MPU_RASR_TEX_SO | /* Ordered */ MPU_RASR_TEX_SO | /* Ordered */ \
MPU_RASR_C | /* Cacheable */ MPU_RASR_C | /* Cacheable */ \
MPU_RASR_B | /* Bufferable */ MPU_RASR_B | /* Bufferable */ \
MPU_RASR_S | /* Shareable */ MPU_RASR_S | /* Shareable */ \
MPU_RASR_AP_RWRW /* P:RW U:RW */ MPU_RASR_AP_RWRW /* P:RW U:RW */ \
/* Instruction access */); /* Instruction access */); \
} } while (0)
/***************************************************************************** /*****************************************************************************
* Name: mpu_priv_extsram * Name: mpu_priv_extsram
@ -457,18 +396,18 @@ static inline void mpu_user_extsram(uintptr_t base, size_t size)
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_priv_extsram(uintptr_t base, size_t size) #define mpu_priv_extsram(base, size) \
{ do \
/* The configure the region */ { \
/* The configure the region */ \
mpu_configure_region(base, size, mpu_configure_region(base, size, \
MPU_RASR_TEX_SO | /* Ordered */ MPU_RASR_TEX_SO | /* Ordered */ \
MPU_RASR_C | /* Cacheable */ MPU_RASR_C | /* Cacheable */ \
MPU_RASR_B | /* Bufferable */ MPU_RASR_B | /* Bufferable */ \
MPU_RASR_S | /* Shareable */ MPU_RASR_S | /* Shareable */ \
MPU_RASR_AP_RWNO /* P:RW U:None */ MPU_RASR_AP_RWNO /* P:RW U:None */ \
/* Instruction access */); /* Instruction access */); \
} } while (0)
/***************************************************************************** /*****************************************************************************
* Name: mpu_peripheral * Name: mpu_peripheral
@ -478,18 +417,18 @@ static inline void mpu_priv_extsram(uintptr_t base, size_t size)
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_peripheral(uintptr_t base, size_t size) #define mpu_peripheral(base, size) \
{ do \
/* Then configure the region */ { \
/* Then configure the region */ \
mpu_configure_region(base, size, mpu_configure_region(base, size, \
MPU_RASR_TEX_DEV | /* Device */ MPU_RASR_TEX_DEV | /* Device */ \
/* Not Cacheable */ /* Not Cacheable */ \
MPU_RASR_B | /* Bufferable */ MPU_RASR_B | /* Bufferable */ \
MPU_RASR_S | /* Shareable */ MPU_RASR_S | /* Shareable */ \
MPU_RASR_AP_RWNO | /* P:RW U:None */ MPU_RASR_AP_RWNO | /* P:RW U:None */ \
MPU_RASR_XN /* No Instruction access */); MPU_RASR_XN /* No Instruction access */); \
} } while (0)
/***************************************************************************** /*****************************************************************************
* Name: mpu_user_peripheral * Name: mpu_user_peripheral
@ -499,18 +438,18 @@ static inline void mpu_peripheral(uintptr_t base, size_t size)
* *
*****************************************************************************/ *****************************************************************************/
static inline void mpu_user_peripheral(uintptr_t base, size_t size) #define mpu_user_peripheral(base, size) \
{ do \
/* Then configure the region */ { \
/* Then configure the region */ \
mpu_configure_region(base, size, mpu_configure_region(base, size, \
MPU_RASR_TEX_DEV | /* Device */ MPU_RASR_TEX_DEV | /* Device */ \
/* Not Cacheable */ /* Not Cacheable */ \
MPU_RASR_B | /* Bufferable */ MPU_RASR_B | /* Bufferable */ \
MPU_RASR_S | /* Shareable */ MPU_RASR_S | /* Shareable */ \
MPU_RASR_AP_RWRW | /* P:RW U:RW */ MPU_RASR_AP_RWRW | /* P:RW U:RW */ \
MPU_RASR_XN /* No Instruction access */); MPU_RASR_XN /* No Instruction access */); \
} } while (0)
#undef EXTERN #undef EXTERN
#if defined(__cplusplus) #if defined(__cplusplus)
@ -518,4 +457,5 @@ static inline void mpu_user_peripheral(uintptr_t base, size_t size)
#endif #endif
#endif /* __ASSEMBLY__ */ #endif /* __ASSEMBLY__ */
#endif /* CONFIG_ARM_MPU */
#endif /* __ARCH_ARM_SRC_ARMV7M_MPU_H */ #endif /* __ARCH_ARM_SRC_ARMV7M_MPU_H */

View File

@ -48,6 +48,7 @@
/**************************************************************************** /****************************************************************************
* Pre-processor Definitions * Pre-processor Definitions
****************************************************************************/ ****************************************************************************/
/* Configuration ************************************************************/ /* Configuration ************************************************************/
#ifndef CONFIG_ARM_MPU_NREGIONS #ifndef CONFIG_ARM_MPU_NREGIONS
@ -314,3 +315,89 @@ uint32_t mpu_subregion(uintptr_t base, size_t size, uint8_t l2size)
ret |= mpu_subregion_ls(offset, l2size); ret |= mpu_subregion_ls(offset, l2size);
return ret; return ret;
} }
/*****************************************************************************
* Name: mpu_control
*
* Description:
* Configure and enable (or disable) the MPU
*
*****************************************************************************/
void mpu_control(bool enable, bool hfnmiena, bool privdefena)
{
uint32_t regval = 0;
if (enable)
{
regval |= MPU_CTRL_ENABLE; /* Enable the MPU */
if (hfnmiena)
{
regval |= MPU_CTRL_HFNMIENA; /* Enable MPU during hard fault, NMI, and FAULTMAS */
}
if (privdefena)
{
regval |= MPU_CTRL_PRIVDEFENA; /* Enable privileged access to default memory map */
}
}
putreg32(regval, MPU_CTRL);
}
/*****************************************************************************
* Name: mpu_configure_region
*
* Description:
* Configure a region for privileged, strongly ordered memory
*
*****************************************************************************/
void mpu_configure_region(uintptr_t base, size_t size,
uint32_t flags)
{
unsigned int region = mpu_allocregion();
uint32_t regval;
uint8_t l2size;
uint8_t subregions;
uintptr_t alignedbase;
/* Ensure the base address alignment
*
* ARMv7-M Architecture Reference Manual
* B3.5.8 MPU Region Base Address Register, MPU_RBAR
* "Software must ensure that the value written to the ADDR field
* aligns with the size of the selected region."
*/
alignedbase = base & MPU_RBAR_ADDR_MASK;
l2size = mpu_log2regionceil(size + base - alignedbase);
alignedbase &= ~((1 << l2size) - 1);
l2size = mpu_log2regionceil(size + base - alignedbase);
DEBUGASSERT(alignedbase + (1 << l2size) >= base + size);
DEBUGASSERT(l2size == 5 || alignedbase + (1 << (l2size - 1)) < base + size);
DEBUGASSERT((alignedbase & MPU_RBAR_ADDR_MASK) == alignedbase);
DEBUGASSERT((alignedbase & ((1 << l2size) - 1)) == 0);
/* Select the region */
putreg32(region, MPU_RNR);
/* Select the region base address */
putreg32(alignedbase | region | MPU_RBAR_VALID, MPU_RBAR);
/* Select the region size and the sub-region map */
subregions = mpu_subregion(base, size, l2size);
/* The configure the region */
regval = MPU_RASR_ENABLE | /* Enable region */
MPU_RASR_SIZE_LOG2((uint32_t)l2size) | /* Region size */
((uint32_t)subregions << MPU_RASR_SRD_SHIFT) | /* Sub-regions */
flags;
putreg32(regval, MPU_RASR);
}

View File

@ -73,8 +73,12 @@ ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif
@ -113,14 +117,12 @@ CHIP_CSRCS += imxrt_gpioirq.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y) ifeq ($(CONFIG_ARM_MPU),y)
ifneq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c
endif
CHIP_CSRCS += imxrt_mpuinit.c CHIP_CSRCS += imxrt_mpuinit.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CHIP_CSRCS += imxrt_userspace.c CHIP_CSRCS += imxrt_userspace.c
endif endif
endif
ifeq ($(CONFIG_IMXRT_EDMA),y) ifeq ($(CONFIG_IMXRT_EDMA),y)
CHIP_CSRCS += imxrt_edma.c CHIP_CSRCS += imxrt_edma.c

View File

@ -71,8 +71,12 @@ ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif

View File

@ -76,8 +76,12 @@ ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif

View File

@ -64,8 +64,12 @@ ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif

View File

@ -64,8 +64,12 @@ ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif

View File

@ -80,8 +80,12 @@ ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif

View File

@ -75,8 +75,12 @@ ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif

View File

@ -53,13 +53,13 @@
#include <arch/board/board.h> #include <arch/board/board.h>
#include "chip.h" #include "chip.h"
#ifdef CONFIG_ARM_MPU
# include "mpu.h" #include "mpu.h"
# include "stm32_mpuinit.h"
#endif
#include "up_arch.h" #include "up_arch.h"
#include "up_internal.h" #include "up_internal.h"
#include "stm32_mpuinit.h"
/**************************************************************************** /****************************************************************************
* Pre-processor Definitions * Pre-processor Definitions
****************************************************************************/ ****************************************************************************/

View File

@ -93,8 +93,12 @@ ifeq ($(CONFIG_ARMV7M_ITMSYSLOG),y)
CMN_CSRCS += up_itm_syslog.c CMN_CSRCS += up_itm_syslog.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif

View File

@ -1186,6 +1186,7 @@ if STM32H7_BKPSRAM
config STM32H7_BBSRAM config STM32H7_BBSRAM
bool "BBSRAM File Support" bool "BBSRAM File Support"
default n default n
select ARM_MPU
config STM32H7_BBSRAM_FILES config STM32H7_BBSRAM_FILES
int "Max Files to support in BBSRAM" int "Max Files to support in BBSRAM"

View File

@ -92,8 +92,12 @@ ifeq ($(CONFIG_STM32H7_PROGMEM),y)
CMN_CSRCS += stm32_flash.c CMN_CSRCS += stm32_flash.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif
@ -130,7 +134,7 @@ endif
ifeq ($(CONFIG_STM32H7_BBSRAM),y) ifeq ($(CONFIG_STM32H7_BBSRAM),y)
ifeq ($(CONFIG_ARMV7M_DCACHE),y) ifeq ($(CONFIG_ARMV7M_DCACHE),y)
ifeq ($(CONFIG_BUILD_PROTECTED),) ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c CMN_CSRCS += up_mpu.c
endif endif
endif endif

View File

@ -84,8 +84,12 @@ ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif

View File

@ -83,8 +83,12 @@ ifeq ($(CONFIG_STACK_COLORATION),y)
CMN_CSRCS += up_checkstack.c CMN_CSRCS += up_checkstack.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
else else

View File

@ -71,8 +71,12 @@ ifeq ($(CONFIG_ARCH_RAMVECTORS),y)
CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c CMN_CSRCS += up_ramvec_initialize.c up_ramvec_attach.c
endif endif
ifeq ($(CONFIG_ARM_MPU),y)
CMN_CSRCS += up_mpu.c
endif
ifeq ($(CONFIG_BUILD_PROTECTED),y) ifeq ($(CONFIG_BUILD_PROTECTED),y)
CMN_CSRCS += up_mpu.c up_task_start.c up_pthread_start.c CMN_CSRCS += up_task_start.c up_pthread_start.c
CMN_CSRCS += up_signal_dispatch.c CMN_CSRCS += up_signal_dispatch.c
CMN_UASRCS += up_signal_handler.S CMN_UASRCS += up_signal_handler.S
endif endif