mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
cpu: Rename CPU_ARCH to CPU_CORE
This commit is contained in:
parent
affa7e8081
commit
4d65bc8e0a
@ -1,6 +1,6 @@
|
|||||||
MODULE = silabs_aem
|
MODULE = silabs_aem
|
||||||
|
|
||||||
ifeq ($(CPU_ARCH),cortex-m0plus)
|
ifeq ($(CPU_CORE),cortex-m0plus)
|
||||||
$(error AEM is not available for the Cortex M0+)
|
$(error AEM is not available for the Cortex M0+)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -40,8 +40,8 @@ typedef enum {
|
|||||||
#ifdef MODULE_CORTEXM_COMMON
|
#ifdef MODULE_CORTEXM_COMMON
|
||||||
PANIC_NMI_HANDLER, /**< non maskable interrupt */
|
PANIC_NMI_HANDLER, /**< non maskable interrupt */
|
||||||
PANIC_HARD_FAULT, /**< hard fault */
|
PANIC_HARD_FAULT, /**< hard fault */
|
||||||
#if defined(CPU_ARCH_CORTEX_M3) || defined(CPU_ARCH_CORTEX_M4) || \
|
#if defined(CPU_CORE_CORTEX_M3) || defined(CPU_CORE_CORTEX_M4) || \
|
||||||
defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7)
|
defined(CPU_CORE_CORTEX_M4F) || defined(CPU_CORE_CORTEX_M7)
|
||||||
PANIC_MEM_MANAGE, /**< memory controller interrupt */
|
PANIC_MEM_MANAGE, /**< memory controller interrupt */
|
||||||
PANIC_BUS_FAULT, /**< bus fault */
|
PANIC_BUS_FAULT, /**< bus fault */
|
||||||
PANIC_USAGE_FAULT, /**< undefined instruction or unaligned access */
|
PANIC_USAGE_FAULT, /**< undefined instruction or unaligned access */
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m3
|
CPU_CORE = cortex-m3
|
||||||
|
|
||||||
FEATURES_PROVIDED += periph_cpuid
|
FEATURES_PROVIDED += periph_cpuid
|
||||||
FEATURES_PROVIDED += periph_gpio periph_gpio_irq
|
FEATURES_PROVIDED += periph_gpio periph_gpio_irq
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m3
|
CPU_CORE = cortex-m3
|
||||||
|
|
||||||
FEATURES_PROVIDED += cortexm_mpu
|
FEATURES_PROVIDED += cortexm_mpu
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m4f
|
CPU_CORE = cortex-m4f
|
||||||
|
|
||||||
FEATURES_PROVIDED += cortexm_mpu
|
FEATURES_PROVIDED += cortexm_mpu
|
||||||
|
|
||||||
|
@ -8,6 +8,25 @@ FEATURES_PROVIDED += cpu_check_address
|
|||||||
FEATURES_PROVIDED += ssp
|
FEATURES_PROVIDED += ssp
|
||||||
|
|
||||||
# cortex-m4f and cortex-m7 provide FPU support
|
# cortex-m4f and cortex-m7 provide FPU support
|
||||||
ifneq (,$(filter $(CPU_ARCH),cortex-m4f cortex-m7))
|
ifneq (,$(filter $(CPU_CORE),cortex-m4f cortex-m7))
|
||||||
FEATURES_PROVIDED += cortexm_fpu
|
FEATURES_PROVIDED += cortexm_fpu
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Set CPU_ARCH depending on the CPU_CORE
|
||||||
|
ifeq ($(CPU_CORE),cortex-m0)
|
||||||
|
CPU_ARCH := armv6m
|
||||||
|
else ifeq ($(CPU_CORE),cortex-m0plus)
|
||||||
|
CPU_ARCH := armv6m
|
||||||
|
else ifeq ($(CPU_CORE),cortex-m3)
|
||||||
|
CPU_ARCH := armv7m
|
||||||
|
else ifeq ($(CPU_CORE),cortex-m4)
|
||||||
|
CPU_ARCH := armv7m
|
||||||
|
else ifeq ($(CPU_CORE),cortex-m4f)
|
||||||
|
CPU_ARCH := armv7m
|
||||||
|
else ifeq ($(CPU_CORE),cortex-m7)
|
||||||
|
CPU_ARCH := armv7m
|
||||||
|
else ifeq ($(CPU_CORE),cortex-m23)
|
||||||
|
CPU_ARCH := armv8m
|
||||||
|
else
|
||||||
|
$(error Unkwnown cortexm core: $(CPU_CORE))
|
||||||
|
endif
|
||||||
|
@ -53,7 +53,7 @@ LINKFLAGS += $(if $(FW_ROM_LEN),$(LINKFLAGPREFIX)--defsym=_fw_rom_length=$(FW_RO
|
|||||||
# The values defined here are a theoretical maximum, in practice most cpu's
|
# The values defined here are a theoretical maximum, in practice most cpu's
|
||||||
# CPU_IRQ_NUMOF value is around 100, in these cases the value can be reduced
|
# CPU_IRQ_NUMOF value is around 100, in these cases the value can be reduced
|
||||||
# accordingly in the cpu Makefile.include, e.g: `kinetis/Makefile.include`
|
# accordingly in the cpu Makefile.include, e.g: `kinetis/Makefile.include`
|
||||||
ifneq (,$(filter cortex-m2% cortex-m4% cortex-m3% cortex-m7%,$(CPU_ARCH)))
|
ifneq (,$(filter cortex-m2% cortex-m4% cortex-m3% cortex-m7%,$(CPU_CORE)))
|
||||||
RIOTBOOT_HDR_LEN ?= 0x400
|
RIOTBOOT_HDR_LEN ?= 0x400
|
||||||
else
|
else
|
||||||
RIOTBOOT_HDR_LEN ?= 0x100
|
RIOTBOOT_HDR_LEN ?= 0x100
|
||||||
|
@ -68,9 +68,9 @@ void cortexm_init(void)
|
|||||||
cortexm_init_fpu();
|
cortexm_init_fpu();
|
||||||
|
|
||||||
/* configure the vector table location to internal flash */
|
/* configure the vector table location to internal flash */
|
||||||
#if defined(CPU_ARCH_CORTEX_M3) || defined(CPU_ARCH_CORTEX_M4) || \
|
#if defined(CPU_CORE_CORTEX_M3) || defined(CPU_CORE_CORTEX_M4) || \
|
||||||
defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7) || \
|
defined(CPU_CORE_CORTEX_M4F) || defined(CPU_CORE_CORTEX_M7) || \
|
||||||
(defined(CPU_ARCH_CORTEX_M0PLUS) || defined(CPU_ARCH_CORTEX_M23) \
|
(defined(CPU_CORE_CORTEX_M0PLUS) || defined(CPU_CORE_CORTEX_M23) \
|
||||||
&& (__VTOR_PRESENT == 1))
|
&& (__VTOR_PRESENT == 1))
|
||||||
SCB->VTOR = (uint32_t)&_isr_vectors;
|
SCB->VTOR = (uint32_t)&_isr_vectors;
|
||||||
#endif
|
#endif
|
||||||
@ -81,8 +81,8 @@ void cortexm_init(void)
|
|||||||
|
|
||||||
bool cpu_check_address(volatile const char *address)
|
bool cpu_check_address(volatile const char *address)
|
||||||
{
|
{
|
||||||
#if defined(CPU_ARCH_CORTEX_M3) || defined(CPU_ARCH_CORTEX_M4) || \
|
#if defined(CPU_CORE_CORTEX_M3) || defined(CPU_CORE_CORTEX_M4) || \
|
||||||
defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7)
|
defined(CPU_CORE_CORTEX_M4F) || defined(CPU_CORE_CORTEX_M7)
|
||||||
static const uint32_t BFARVALID_MASK = (0x80 << SCB_CFSR_BUSFAULTSR_Pos);
|
static const uint32_t BFARVALID_MASK = (0x80 << SCB_CFSR_BUSFAULTSR_Pos);
|
||||||
|
|
||||||
bool is_valid = true;
|
bool is_valid = true;
|
||||||
|
@ -99,7 +99,7 @@ void cortexm_init(void);
|
|||||||
static inline void cortexm_init_fpu(void)
|
static inline void cortexm_init_fpu(void)
|
||||||
{
|
{
|
||||||
/* initialize the FPU on Cortex-M4F CPUs */
|
/* initialize the FPU on Cortex-M4F CPUs */
|
||||||
#if defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7)
|
#if defined(CPU_CORE_CORTEX_M4F) || defined(CPU_CORE_CORTEX_M7)
|
||||||
/* give full access to the FPU */
|
/* give full access to the FPU */
|
||||||
SCB->CPACR |= (uint32_t)CORTEXM_SCB_CPACR_FPU_ACCESS_FULL;
|
SCB->CPACR |= (uint32_t)CORTEXM_SCB_CPACR_FPU_ACCESS_FULL;
|
||||||
#endif
|
#endif
|
||||||
@ -226,9 +226,9 @@ static inline void cpu_jump_to_image(uint32_t image_address)
|
|||||||
|
|
||||||
/* The following register is only present for
|
/* The following register is only present for
|
||||||
Cortex-M0+, -M3, -M4, -M7 and -M23 CPUs */
|
Cortex-M0+, -M3, -M4, -M7 and -M23 CPUs */
|
||||||
#if defined(CPU_ARCH_CORTEX_M0PLUS) || defined(CPU_ARCH_CORTEX_M3) || \
|
#if defined(CPU_CORE_CORTEX_M0PLUS) || defined(CPU_CORE_CORTEX_M3) || \
|
||||||
defined(CPU_ARCH_CORTEX_M4) || defined(CPU_ARCH_CORTEX_M4F) || \
|
defined(CPU_CORE_CORTEX_M4) || defined(CPU_CORE_CORTEX_M4F) || \
|
||||||
defined(CPU_ARCH_CORTEX_M7) || defined(CPU_ARCH_CORTEX_M23)
|
defined(CPU_CORE_CORTEX_M7) || defined(CPU_CORE_CORTEX_M23)
|
||||||
static inline uint32_t cpu_get_image_baseaddr(void)
|
static inline uint32_t cpu_get_image_baseaddr(void)
|
||||||
{
|
{
|
||||||
return SCB->VTOR;
|
return SCB->VTOR;
|
||||||
|
@ -92,8 +92,8 @@ void nmi_default(void);
|
|||||||
void hard_fault_default(void);
|
void hard_fault_default(void);
|
||||||
|
|
||||||
/* The following four exceptions are only present for Cortex-M3 and -M4 CPUs */
|
/* The following four exceptions are only present for Cortex-M3 and -M4 CPUs */
|
||||||
#if defined(CPU_ARCH_CORTEX_M3) || defined(CPU_ARCH_CORTEX_M4) || \
|
#if defined(CPU_CORE_CORTEX_M3) || defined(CPU_CORE_CORTEX_M4) || \
|
||||||
defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7)
|
defined(CPU_CORE_CORTEX_M4F) || defined(CPU_CORE_CORTEX_M7)
|
||||||
/**
|
/**
|
||||||
* @brief Memory management exception handler
|
* @brief Memory management exception handler
|
||||||
*
|
*
|
||||||
|
@ -60,7 +60,7 @@ bool mpu_enabled(void) {
|
|||||||
|
|
||||||
int mpu_configure(uint_fast8_t region, uintptr_t base, uint_fast32_t attr) {
|
int mpu_configure(uint_fast8_t region, uintptr_t base, uint_fast32_t attr) {
|
||||||
/* Todo enable MPU support for Cortex-M23/M33 */
|
/* Todo enable MPU support for Cortex-M23/M33 */
|
||||||
#if __MPU_PRESENT && !defined(CPU_ARCH_CORTEX_M23)
|
#if __MPU_PRESENT && !defined(CPU_CORE_CORTEX_M23)
|
||||||
MPU->RNR = region;
|
MPU->RNR = region;
|
||||||
MPU->RBAR = base & MPU_RBAR_ADDR_Msk;
|
MPU->RBAR = base & MPU_RBAR_ADDR_Msk;
|
||||||
MPU->RASR = attr | MPU_RASR_ENABLE_Msk;
|
MPU->RASR = attr | MPU_RASR_ENABLE_Msk;
|
||||||
|
@ -190,8 +190,8 @@ char *thread_stack_init(thread_task_func_t task_func,
|
|||||||
* For the Cortex-M3 and Cortex-M4 we write them continuously onto the stack
|
* For the Cortex-M3 and Cortex-M4 we write them continuously onto the stack
|
||||||
* as they can be read/written continuously by stack instructions. */
|
* as they can be read/written continuously by stack instructions. */
|
||||||
|
|
||||||
#if defined(CPU_ARCH_CORTEX_M0) || defined(CPU_ARCH_CORTEX_M0PLUS) \
|
#if defined(CPU_CORE_CORTEX_M0) || defined(CPU_CORE_CORTEX_M0PLUS) \
|
||||||
|| defined(CPU_ARCH_CORTEX_M23)
|
|| defined(CPU_CORE_CORTEX_M23)
|
||||||
/* start with r7 - r4 */
|
/* start with r7 - r4 */
|
||||||
for (int i = 7; i >= 4; i--) {
|
for (int i = 7; i >= 4; i--) {
|
||||||
stk--;
|
stk--;
|
||||||
@ -297,8 +297,8 @@ void __attribute__((naked)) __attribute__((used)) isr_pendsv(void) {
|
|||||||
"beq select_and_restore_context \n" /* goto select_and_restore_context */
|
"beq select_and_restore_context \n" /* goto select_and_restore_context */
|
||||||
|
|
||||||
"mrs r0, psp \n" /* get stack pointer from user mode */
|
"mrs r0, psp \n" /* get stack pointer from user mode */
|
||||||
#if defined(CPU_ARCH_CORTEX_M0) || defined(CPU_ARCH_CORTEX_M0PLUS) \
|
#if defined(CPU_CORE_CORTEX_M0) || defined(CPU_CORE_CORTEX_M0PLUS) \
|
||||||
|| defined(CPU_ARCH_CORTEX_M23)
|
|| defined(CPU_CORE_CORTEX_M23)
|
||||||
"push {r1} \n" /* push sched_active_thread */
|
"push {r1} \n" /* push sched_active_thread */
|
||||||
"mov r12, sp \n" /* remember the exception SP */
|
"mov r12, sp \n" /* remember the exception SP */
|
||||||
"mov sp, r0 \n" /* set user mode SP as active SP */
|
"mov sp, r0 \n" /* set user mode SP as active SP */
|
||||||
@ -315,7 +315,7 @@ void __attribute__((naked)) __attribute__((used)) isr_pendsv(void) {
|
|||||||
"mov sp, r12 \n"
|
"mov sp, r12 \n"
|
||||||
"pop {r1} \n" /* r1 = sched_active_thread */
|
"pop {r1} \n" /* r1 = sched_active_thread */
|
||||||
#else
|
#else
|
||||||
#if (defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7)) && defined(MODULE_CORTEXM_FPU)
|
#if (defined(CPU_CORE_CORTEX_M4F) || defined(CPU_CORE_CORTEX_M7)) && defined(MODULE_CORTEXM_FPU)
|
||||||
"tst lr, #0x10 \n"
|
"tst lr, #0x10 \n"
|
||||||
"it eq \n"
|
"it eq \n"
|
||||||
"vstmdbeq r0!, {s16-s31} \n" /* save FPU registers if FPU is used */
|
"vstmdbeq r0!, {s16-s31} \n" /* save FPU registers if FPU is used */
|
||||||
@ -332,8 +332,8 @@ void __attribute__((naked)) __attribute__((used)) isr_pendsv(void) {
|
|||||||
"bl sched_run \n" /* perform scheduling */
|
"bl sched_run \n" /* perform scheduling */
|
||||||
|
|
||||||
/* restore now current thread context */
|
/* restore now current thread context */
|
||||||
#if defined(CPU_ARCH_CORTEX_M0) || defined(CPU_ARCH_CORTEX_M0PLUS) \
|
#if defined(CPU_CORE_CORTEX_M0) || defined(CPU_CORE_CORTEX_M0PLUS) \
|
||||||
|| defined(CPU_ARCH_CORTEX_M23)
|
|| defined(CPU_CORE_CORTEX_M23)
|
||||||
"mov lr, sp \n" /* save MSR stack pointer for later */
|
"mov lr, sp \n" /* save MSR stack pointer for later */
|
||||||
"ldr r0, =sched_active_thread \n" /* load address of current TCB */
|
"ldr r0, =sched_active_thread \n" /* load address of current TCB */
|
||||||
"ldr r0, [r0] \n" /* dereference TCB */
|
"ldr r0, [r0] \n" /* dereference TCB */
|
||||||
@ -358,7 +358,7 @@ void __attribute__((naked)) __attribute__((used)) isr_pendsv(void) {
|
|||||||
"ldr r1, [r0] \n" /* load tcb->sp to register 1 */
|
"ldr r1, [r0] \n" /* load tcb->sp to register 1 */
|
||||||
"ldmia r1!, {r0} \n" /* restore exception return value */
|
"ldmia r1!, {r0} \n" /* restore exception return value */
|
||||||
"ldmia r1!, {r4-r11} \n" /* restore other registers */
|
"ldmia r1!, {r4-r11} \n" /* restore other registers */
|
||||||
#if (defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7)) && defined(MODULE_CORTEXM_FPU)
|
#if (defined(CPU_CORE_CORTEX_M4F) || defined(CPU_CORE_CORTEX_M7)) && defined(MODULE_CORTEXM_FPU)
|
||||||
"tst r0, #0x10 \n"
|
"tst r0, #0x10 \n"
|
||||||
"it eq \n"
|
"it eq \n"
|
||||||
"vldmiaeq r1!, {s16-s31} \n" /* load FPU registers if saved */
|
"vldmiaeq r1!, {s16-s31} \n" /* load FPU registers if saved */
|
||||||
@ -383,8 +383,8 @@ void __attribute__((naked)) __attribute__((used)) isr_svc(void)
|
|||||||
* svc is only used by threads, saving a couple of instructions. /Kaspar
|
* svc is only used by threads, saving a couple of instructions. /Kaspar
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(CPU_ARCH_CORTEX_M0) || defined(CPU_ARCH_CORTEX_M0PLUS) \
|
#if defined(CPU_CORE_CORTEX_M0) || defined(CPU_CORE_CORTEX_M0PLUS) \
|
||||||
|| defined(CPU_ARCH_CORTEX_M23)
|
|| defined(CPU_CORE_CORTEX_M23)
|
||||||
__asm__ volatile (
|
__asm__ volatile (
|
||||||
".thumb_func \n"
|
".thumb_func \n"
|
||||||
"movs r0, #4 \n" /* if bit4(lr) == 1): */
|
"movs r0, #4 \n" /* if bit4(lr) == 1): */
|
||||||
|
@ -240,7 +240,7 @@ __attribute__((naked)) void hard_fault_default(void)
|
|||||||
" use_psp: \n" /* else { */
|
" use_psp: \n" /* else { */
|
||||||
"mrs r0, psp \n" /* r0 = psp */
|
"mrs r0, psp \n" /* r0 = psp */
|
||||||
" out: \n" /* } */
|
" out: \n" /* } */
|
||||||
#if (defined(CPU_ARCH_CORTEX_M0) || defined(CPU_ARCH_CORTEX_M0PLUS)) \
|
#if (defined(CPU_CORE_CORTEX_M0) || defined(CPU_CORE_CORTEX_M0PLUS)) \
|
||||||
&& defined(MODULE_CPU_CHECK_ADDRESS)
|
&& defined(MODULE_CPU_CHECK_ADDRESS)
|
||||||
/* catch intended HardFaults on Cortex-M0 to probe memory addresses */
|
/* catch intended HardFaults on Cortex-M0 to probe memory addresses */
|
||||||
"ldr r1, [r0, #0x04] \n" /* read R1 from the stack */
|
"ldr r1, [r0, #0x04] \n" /* read R1 from the stack */
|
||||||
@ -258,8 +258,8 @@ __attribute__((naked)) void hard_fault_default(void)
|
|||||||
"bx lr \n" /* exit the exception handler */
|
"bx lr \n" /* exit the exception handler */
|
||||||
" regular_handler: \n"
|
" regular_handler: \n"
|
||||||
#endif
|
#endif
|
||||||
#if defined(CPU_ARCH_CORTEX_M0) || defined(CPU_ARCH_CORTEX_M0PLUS) \
|
#if defined(CPU_CORE_CORTEX_M0) || defined(CPU_CORE_CORTEX_M0PLUS) \
|
||||||
|| defined(CPU_ARCH_CORTEX_M23)
|
|| defined(CPU_CORE_CORTEX_M23)
|
||||||
"push {r4-r7} \n" /* save r4..r7 to the stack */
|
"push {r4-r7} \n" /* save r4..r7 to the stack */
|
||||||
"mov r3, r8 \n" /* */
|
"mov r3, r8 \n" /* */
|
||||||
"mov r4, r9 \n" /* */
|
"mov r4, r9 \n" /* */
|
||||||
@ -279,8 +279,8 @@ __attribute__((naked)) void hard_fault_default(void)
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(CPU_ARCH_CORTEX_M0) || defined(CPU_ARCH_CORTEX_M0PLUS) \
|
#if defined(CPU_CORE_CORTEX_M0) || defined(CPU_CORE_CORTEX_M0PLUS) \
|
||||||
|| defined(CPU_ARCH_CORTEX_M23)
|
|| defined(CPU_CORE_CORTEX_M23)
|
||||||
/* Cortex-M0, Cortex-M0+ and Cortex-M23 lack the extended fault status
|
/* Cortex-M0, Cortex-M0+ and Cortex-M23 lack the extended fault status
|
||||||
registers found in Cortex-M3 and above. */
|
registers found in Cortex-M3 and above. */
|
||||||
#define CPU_HAS_EXTENDED_FAULT_REGISTERS 0
|
#define CPU_HAS_EXTENDED_FAULT_REGISTERS 0
|
||||||
@ -388,8 +388,8 @@ __attribute__((used)) void hard_fault_handler(uint32_t* sp, uint32_t corrupted,
|
|||||||
"mov lr, r1\n"
|
"mov lr, r1\n"
|
||||||
"mov sp, %[orig_sp]\n"
|
"mov sp, %[orig_sp]\n"
|
||||||
"mov r1, %[extra_stack]\n"
|
"mov r1, %[extra_stack]\n"
|
||||||
#if defined(CPU_ARCH_CORTEX_M0) || defined(CPU_ARCH_CORTEX_M0PLUS) \
|
#if defined(CPU_CORE_CORTEX_M0) || defined(CPU_CORE_CORTEX_M0PLUS) \
|
||||||
|| defined(CPU_ARCH_CORTEX_M23)
|
|| defined(CPU_CORE_CORTEX_M23)
|
||||||
"ldm r1!, {r4-r7}\n"
|
"ldm r1!, {r4-r7}\n"
|
||||||
"mov r8, r4\n"
|
"mov r8, r4\n"
|
||||||
"mov r9, r5\n"
|
"mov r9, r5\n"
|
||||||
@ -422,8 +422,8 @@ void hard_fault_default(void)
|
|||||||
|
|
||||||
#endif /* DEVELHELP */
|
#endif /* DEVELHELP */
|
||||||
|
|
||||||
#if defined(CPU_ARCH_CORTEX_M3) || defined(CPU_ARCH_CORTEX_M4) || \
|
#if defined(CPU_CORE_CORTEX_M3) || defined(CPU_CORE_CORTEX_M4) || \
|
||||||
defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7)
|
defined(CPU_CORE_CORTEX_M4F) || defined(CPU_CORE_CORTEX_M7)
|
||||||
void mem_manage_default(void)
|
void mem_manage_default(void)
|
||||||
{
|
{
|
||||||
core_panic(PANIC_MEM_MANAGE, "MEM MANAGE HANDLER");
|
core_panic(PANIC_MEM_MANAGE, "MEM MANAGE HANDLER");
|
||||||
@ -489,8 +489,8 @@ ISR_VECTOR(0) const cortexm_base_t cortex_vector_base = {
|
|||||||
#endif /* CORTEXM_VECTOR_RESERVED_0X28 */
|
#endif /* CORTEXM_VECTOR_RESERVED_0X28 */
|
||||||
|
|
||||||
/* additional vectors used by M3, M4(F), and M7 */
|
/* additional vectors used by M3, M4(F), and M7 */
|
||||||
#if defined(CPU_ARCH_CORTEX_M3) || defined(CPU_ARCH_CORTEX_M4) || \
|
#if defined(CPU_CORE_CORTEX_M3) || defined(CPU_CORE_CORTEX_M4) || \
|
||||||
defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7)
|
defined(CPU_CORE_CORTEX_M4F) || defined(CPU_CORE_CORTEX_M7)
|
||||||
/* [-12] memory manage exception */
|
/* [-12] memory manage exception */
|
||||||
[ 3] = mem_manage_default,
|
[ 3] = mem_manage_default,
|
||||||
/* [-11] bus fault exception */
|
/* [-11] bus fault exception */
|
||||||
|
@ -13,7 +13,7 @@ USEPKG += gecko_sdk
|
|||||||
USEMODULE += pm_layered
|
USEMODULE += pm_layered
|
||||||
|
|
||||||
# CMSIS-DSP is needed for arm_math.h on Cortex-M0+ architectures
|
# CMSIS-DSP is needed for arm_math.h on Cortex-M0+ architectures
|
||||||
ifeq ($(CPU_ARCH),cortex-m0plus)
|
ifeq ($(CPU_CORE),cortex-m0plus)
|
||||||
USEPKG += cmsis-dsp
|
USEPKG += cmsis-dsp
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
include $(RIOTCPU)/efm32/efm32-info.mk
|
include $(RIOTCPU)/efm32/efm32-info.mk
|
||||||
include $(RIOTCPU)/efm32/efm32-features.mk
|
include $(RIOTCPU)/efm32/efm32-features.mk
|
||||||
|
|
||||||
CPU_ARCH = $(EFM32_ARCHITECTURE)
|
CPU_CORE = $(EFM32_ARCHITECTURE)
|
||||||
|
|
||||||
FEATURES_PROVIDED += arch_efm32
|
FEATURES_PROVIDED += arch_efm32
|
||||||
FEATURES_PROVIDED += cortexm_mpu
|
FEATURES_PROVIDED += cortexm_mpu
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m4f
|
CPU_CORE = cortex-m4f
|
||||||
|
|
||||||
FEATURES_PROVIDED += cortexm_mpu
|
FEATURES_PROVIDED += cortexm_mpu
|
||||||
FEATURES_PROVIDED += periph_cpuid
|
FEATURES_PROVIDED += periph_cpuid
|
||||||
|
@ -31,16 +31,16 @@ export KINETIS_SPEED := $(word 11, $(KINETIS_INFO))
|
|||||||
|
|
||||||
ifeq ($(KINETIS_CORE), Z)
|
ifeq ($(KINETIS_CORE), Z)
|
||||||
# Cortex-M0+
|
# Cortex-M0+
|
||||||
CPU_ARCH = cortex-m0plus
|
CPU_CORE = cortex-m0plus
|
||||||
CPU_FAMILY = klx
|
CPU_FAMILY = klx
|
||||||
else ifeq ($(KINETIS_CORE), D)
|
else ifeq ($(KINETIS_CORE), D)
|
||||||
# Cortex-M4
|
# Cortex-M4
|
||||||
CPU_ARCH = cortex-m4
|
CPU_CORE = cortex-m4
|
||||||
CPU_FAMILY = kx
|
CPU_FAMILY = kx
|
||||||
else ifeq ($(KINETIS_CORE), F)
|
else ifeq ($(KINETIS_CORE), F)
|
||||||
# Cortex-M4F or Cortex-M7
|
# Cortex-M4F or Cortex-M7
|
||||||
# TODO: Add floating point support
|
# TODO: Add floating point support
|
||||||
CPU_ARCH = cortex-m4
|
CPU_CORE = cortex-m4
|
||||||
CPU_FAMILY = kx
|
CPU_FAMILY = kx
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m4f
|
CPU_CORE = cortex-m4f
|
||||||
|
|
||||||
FEATURES_PROVIDED += cortexm_mpu
|
FEATURES_PROVIDED += cortexm_mpu
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m3
|
CPU_CORE = cortex-m3
|
||||||
# This CPU only implements one CPU_MODEL with the same name
|
# This CPU only implements one CPU_MODEL with the same name
|
||||||
CPU_MODEL = lpc1768
|
CPU_MODEL = lpc1768
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
CPU_ARCH = m4k
|
CPU_ARCH = mips32
|
||||||
|
CPU_CORE = m4k
|
||||||
CPU_FAM = pic32mx
|
CPU_FAM = pic32mx
|
||||||
|
|
||||||
-include $(RIOTCPU)/mips_pic32_common/Makefile.features
|
-include $(RIOTCPU)/mips_pic32_common/Makefile.features
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
CPU_ARCH = m5101
|
CPU_ARCH = mips32
|
||||||
|
CPU_CORE = m5101
|
||||||
CPU_FAM = pic32mz
|
CPU_FAM = pic32mz
|
||||||
|
|
||||||
FEATURES_PROVIDED += periph_hwrng
|
FEATURES_PROVIDED += periph_hwrng
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m0
|
CPU_CORE = cortex-m0
|
||||||
CPU_FAM = nrf51
|
CPU_FAM = nrf51
|
||||||
|
|
||||||
-include $(RIOTCPU)/nrf5x_common/Makefile.features
|
-include $(RIOTCPU)/nrf5x_common/Makefile.features
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m4f
|
CPU_CORE = cortex-m4f
|
||||||
CPU_FAM = nrf52
|
CPU_FAM = nrf52
|
||||||
|
|
||||||
# The ADC does not depend on any board configuration, so always available
|
# The ADC does not depend on any board configuration, so always available
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m3
|
CPU_CORE = cortex-m3
|
||||||
CPU_FAM = sam3
|
CPU_FAM = sam3
|
||||||
|
|
||||||
FEATURES_PROVIDED += cortexm_mpu
|
FEATURES_PROVIDED += cortexm_mpu
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m0plus
|
CPU_CORE = cortex-m0plus
|
||||||
CPU_FAM = samd21
|
CPU_FAM = samd21
|
||||||
|
|
||||||
FEATURES_PROVIDED += puf_sram
|
FEATURES_PROVIDED += puf_sram
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m4f
|
CPU_CORE = cortex-m4f
|
||||||
CPU_FAM = samd5x
|
CPU_FAM = samd5x
|
||||||
|
|
||||||
FEATURES_PROVIDED += periph_hwrng
|
FEATURES_PROVIDED += periph_hwrng
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m23
|
CPU_CORE = cortex-m23
|
||||||
CPU_FAM = saml1x
|
CPU_FAM = saml1x
|
||||||
|
|
||||||
FEATURES_PROVIDED += cortexm_mpu
|
FEATURES_PROVIDED += cortexm_mpu
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
CPU_ARCH = cortex-m0plus
|
CPU_CORE = cortex-m0plus
|
||||||
CPU_FAM = saml21
|
CPU_FAM = saml21
|
||||||
|
|
||||||
# The SAMR30 line of MCUs does not contain a TRNG
|
# The SAMR30 line of MCUs does not contain a TRNG
|
||||||
|
@ -13,17 +13,17 @@ STM32_RAMMOD = $(word 8, $(STM32_INFO))
|
|||||||
CPU_FAM = $(call lowercase,$(STM32_TYPE)$(STM32_FAMILY))
|
CPU_FAM = $(call lowercase,$(STM32_TYPE)$(STM32_FAMILY))
|
||||||
|
|
||||||
ifeq (f0,$(CPU_FAM))
|
ifeq (f0,$(CPU_FAM))
|
||||||
CPU_ARCH = cortex-m0
|
CPU_CORE = cortex-m0
|
||||||
else ifneq (,$(filter $(CPU_FAM),f1 f2 l1))
|
else ifneq (,$(filter $(CPU_FAM),f1 f2 l1))
|
||||||
CPU_ARCH = cortex-m3
|
CPU_CORE = cortex-m3
|
||||||
else ifneq (,$(filter $(CPU_FAM),f3 f4 l4))
|
else ifneq (,$(filter $(CPU_FAM),f3 f4 l4))
|
||||||
CPU_ARCH = cortex-m4f
|
CPU_CORE = cortex-m4f
|
||||||
else ifeq (wb,$(CPU_FAM))
|
else ifeq (wb,$(CPU_FAM))
|
||||||
CPU_ARCH = cortex-m4
|
CPU_CORE = cortex-m4
|
||||||
else ifeq (f7,$(CPU_FAM))
|
else ifeq (f7,$(CPU_FAM))
|
||||||
CPU_ARCH = cortex-m7
|
CPU_CORE = cortex-m7
|
||||||
else ifeq (l0,$(CPU_FAM))
|
else ifeq (l0,$(CPU_FAM))
|
||||||
CPU_ARCH = cortex-m0plus
|
CPU_CORE = cortex-m0plus
|
||||||
else
|
else
|
||||||
$(error Not supported CPU family: 'stm32$(CPU_FAM)')
|
$(error Not supported CPU family: 'stm32$(CPU_FAM)')
|
||||||
endif
|
endif
|
||||||
|
1
dist/tools/buildsystem_sanity_check/check.sh
vendored
1
dist/tools/buildsystem_sanity_check/check.sh
vendored
@ -111,6 +111,7 @@ UNEXPORTED_VARIABLES+=('JLINK_PRE_FLASH' 'JLINK_RESET_FILE')
|
|||||||
EXPORTED_VARIABLES_ONLY_IN_VARS=()
|
EXPORTED_VARIABLES_ONLY_IN_VARS=()
|
||||||
EXPORTED_VARIABLES_ONLY_IN_VARS+=('APPDEPS')
|
EXPORTED_VARIABLES_ONLY_IN_VARS+=('APPDEPS')
|
||||||
EXPORTED_VARIABLES_ONLY_IN_VARS+=('CPU_ARCH')
|
EXPORTED_VARIABLES_ONLY_IN_VARS+=('CPU_ARCH')
|
||||||
|
EXPORTED_VARIABLES_ONLY_IN_VARS+=('CPU_CORE')
|
||||||
EXPORTED_VARIABLES_ONLY_IN_VARS+=('CPU_FAM')
|
EXPORTED_VARIABLES_ONLY_IN_VARS+=('CPU_FAM')
|
||||||
EXPORTED_VARIABLES_ONLY_IN_VARS+=('NATIVEINCLUDES')
|
EXPORTED_VARIABLES_ONLY_IN_VARS+=('NATIVEINCLUDES')
|
||||||
EXPORTED_VARIABLES_ONLY_IN_VARS+=('UNDEF')
|
EXPORTED_VARIABLES_ONLY_IN_VARS+=('UNDEF')
|
||||||
|
@ -14,7 +14,7 @@ ifneq (llvm,$(TOOLCHAIN))
|
|||||||
CFLAGS += -mno-thumb-interwork
|
CFLAGS += -mno-thumb-interwork
|
||||||
|
|
||||||
# work around https://gcc.gnu.org/bugzilla/show_bug.cgi?id=85606
|
# work around https://gcc.gnu.org/bugzilla/show_bug.cgi?id=85606
|
||||||
ifneq (,$(filter cortex-m0%,$(CPU_ARCH)))
|
ifeq (armv6m,$(CPU_ARCH))
|
||||||
CFLAGS_CPU += -march=armv6s-m
|
CFLAGS_CPU += -march=armv6s-m
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
@ -58,12 +58,12 @@ ifneq (1,$(BUILD_IN_DOCKER))
|
|||||||
endif # BUILD_IN_DOCKER
|
endif # BUILD_IN_DOCKER
|
||||||
|
|
||||||
CFLAGS += -DCPU_MODEL_$(call uppercase_and_underscore,$(CPU_MODEL))
|
CFLAGS += -DCPU_MODEL_$(call uppercase_and_underscore,$(CPU_MODEL))
|
||||||
CFLAGS += -DCPU_ARCH_$(call uppercase_and_underscore,$(CPU_ARCH))
|
CFLAGS += -DCPU_CORE_$(call uppercase_and_underscore,$(CPU_CORE))
|
||||||
|
|
||||||
# Add corresponding FPU CFLAGS
|
# Add corresponding FPU CFLAGS
|
||||||
# clang assumes there is an FPU, no CFLAGS necessary
|
# clang assumes there is an FPU, no CFLAGS necessary
|
||||||
ifneq (llvm, $(TOOLCHAIN))
|
ifneq (llvm, $(TOOLCHAIN))
|
||||||
ifeq ($(CPU_ARCH),cortex-m7)
|
ifeq ($(CPU_CORE),cortex-m7)
|
||||||
_CORTEX_HW_FPU_CFLAGS = -mfloat-abi=hard -mfpu=fpv5-sp-d16
|
_CORTEX_HW_FPU_CFLAGS = -mfloat-abi=hard -mfpu=fpv5-sp-d16
|
||||||
else
|
else
|
||||||
_CORTEX_HW_FPU_CFLAGS = -mfloat-abi=hard -mfpu=fpv4-sp-d16
|
_CORTEX_HW_FPU_CFLAGS = -mfloat-abi=hard -mfpu=fpv4-sp-d16
|
||||||
@ -73,28 +73,28 @@ endif
|
|||||||
# NOTE: This can be turned into normal conditional syntax once #9913 is fixed
|
# NOTE: This can be turned into normal conditional syntax once #9913 is fixed
|
||||||
CFLAGS_FPU ?= $(if $(filter cortexm_fpu,$(USEMODULE)),$(_CORTEX_HW_FPU_CFLAGS),-mfloat-abi=soft)
|
CFLAGS_FPU ?= $(if $(filter cortexm_fpu,$(USEMODULE)),$(_CORTEX_HW_FPU_CFLAGS),-mfloat-abi=soft)
|
||||||
|
|
||||||
ifeq ($(CPU_ARCH),cortex-m4f)
|
ifeq ($(CPU_CORE),cortex-m4f)
|
||||||
MCPU = cortex-m4
|
MCPU = cortex-m4
|
||||||
else
|
else
|
||||||
MCPU ?= $(CPU_ARCH)
|
MCPU ?= $(CPU_CORE)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# CMSIS DSP needs to know about the CPU core
|
# CMSIS DSP needs to know about the CPU core
|
||||||
ifneq (,$(filter cmsis-dsp,$(USEPKG)))
|
ifneq (,$(filter cmsis-dsp,$(USEPKG)))
|
||||||
# definition needed to use cmsis-dsp headers
|
# definition needed to use cmsis-dsp headers
|
||||||
ifeq ($(CPU_ARCH),cortex-m0)
|
ifeq ($(CPU_CORE),cortex-m0)
|
||||||
CFLAGS += -DARM_MATH_CM0
|
CFLAGS += -DARM_MATH_CM0
|
||||||
else ifeq ($(CPU_ARCH),cortex-m0plus)
|
else ifeq ($(CPU_CORE),cortex-m0plus)
|
||||||
CFLAGS += -DARM_MATH_CM0PLUS
|
CFLAGS += -DARM_MATH_CM0PLUS
|
||||||
else ifeq ($(CPU_ARCH),cortex-m3)
|
else ifeq ($(CPU_CORE),cortex-m3)
|
||||||
CFLAGS += -DARM_MATH_CM3
|
CFLAGS += -DARM_MATH_CM3
|
||||||
else ifeq ($(CPU_ARCH),cortex-m4)
|
else ifeq ($(CPU_CORE),cortex-m4)
|
||||||
CFLAGS += -DARM_MATH_CM4
|
CFLAGS += -DARM_MATH_CM4
|
||||||
else ifeq ($(CPU_ARCH),cortex-m4f)
|
else ifeq ($(CPU_CORE),cortex-m4f)
|
||||||
CFLAGS += -DARM_MATH_CM4
|
CFLAGS += -DARM_MATH_CM4
|
||||||
else ifeq ($(CPU_ARCH),cortex-m7)
|
else ifeq ($(CPU_CORE),cortex-m7)
|
||||||
CFLAGS += -DARM_MATH_CM7
|
CFLAGS += -DARM_MATH_CM7
|
||||||
else ifeq ($(CPU_ARCH),cortex-m23)
|
else ifeq ($(CPU_CORE),cortex-m23)
|
||||||
CFLAGS += -DARM_MATH_CM23
|
CFLAGS += -DARM_MATH_CM23
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
@ -49,7 +49,7 @@ FEATURES_PROVIDED_KCONFIG = $(call lowercase,$(patsubst CONFIG_HAS_%,%,$(filter
|
|||||||
DEPENDENCY_DEBUG_OUTPUT_DIR ?= $(CURDIR)
|
DEPENDENCY_DEBUG_OUTPUT_DIR ?= $(CURDIR)
|
||||||
|
|
||||||
# Save variables that are used for parsing dependencies
|
# Save variables that are used for parsing dependencies
|
||||||
_DEPS_DEBUG_VARS += BOARD CPU CPU_MODEL CPU_ARCH CPU_FAM
|
_DEPS_DEBUG_VARS += BOARD CPU CPU_MODEL CPU_FAM CPU_CORE CPU_ARCH
|
||||||
_DEPS_DEBUG_VARS += FEATURES_PROVIDED _FEATURES_PROVIDED_SORTED
|
_DEPS_DEBUG_VARS += FEATURES_PROVIDED _FEATURES_PROVIDED_SORTED
|
||||||
_DEPS_DEBUG_VARS += FEATURES_REQUIRED _FEATURES_REQUIRED_SORTED
|
_DEPS_DEBUG_VARS += FEATURES_REQUIRED _FEATURES_REQUIRED_SORTED
|
||||||
_DEPS_DEBUG_VARS += FEATURES_REQUIRED_ANY _FEATURES_REQUIRED_ANY_SORTED
|
_DEPS_DEBUG_VARS += FEATURES_REQUIRED_ANY _FEATURES_REQUIRED_ANY_SORTED
|
||||||
|
@ -40,6 +40,7 @@ define board_unsatisfied_features
|
|||||||
undefine CPU
|
undefine CPU
|
||||||
undefine CPU_MODEL
|
undefine CPU_MODEL
|
||||||
undefine CPU_ARCH
|
undefine CPU_ARCH
|
||||||
|
undefine CPU_CORE
|
||||||
undefine CPU_FAM
|
undefine CPU_FAM
|
||||||
|
|
||||||
include $(RIOTBASE)/Makefile.features
|
include $(RIOTBASE)/Makefile.features
|
||||||
|
@ -12,7 +12,8 @@ export APPLICATION_MODULE # The application module name.
|
|||||||
export BOARD # The board to compile the application for.
|
export BOARD # The board to compile the application for.
|
||||||
export CPU # The CPU, set by the board's Makefile.features.
|
export CPU # The CPU, set by the board's Makefile.features.
|
||||||
export CPU_MODEL # The specific identifier of the used CPU, used for some CPU implementations to differentiate between different memory layouts. Set by the board's Makefile.features.
|
export CPU_MODEL # The specific identifier of the used CPU, used for some CPU implementations to differentiate between different memory layouts. Set by the board's Makefile.features.
|
||||||
export CPU_ARCH # The specific identifier of the core present in the CPU, used currently only for ARM CPU's. Needed for depency resolution.
|
export CPU_CORE # The specific identifier of the core present in the CPU. Needed for depency resolution.
|
||||||
|
export CPU_ARCH # The specific identifier of the architecture of the core defined in CPU_CORE.
|
||||||
export CPU_FAM # An intermediate identifier between CPU and CPU_MODEL that represents a sub-group of a Manufacturers CPU's.
|
export CPU_FAM # An intermediate identifier between CPU and CPU_MODEL that represents a sub-group of a Manufacturers CPU's.
|
||||||
export MCU # The MCU, set by the board's Makefile.include, or defaulted to the same value as CPU.
|
export MCU # The MCU, set by the board's Makefile.include, or defaulted to the same value as CPU.
|
||||||
export INCLUDES # The extra include paths, set by the various Makefile.include files.
|
export INCLUDES # The extra include paths, set by the various Makefile.include files.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
INCLUDES += -I$(PKGDIRBASE)/micro-ecc
|
INCLUDES += -I$(PKGDIRBASE)/micro-ecc
|
||||||
|
|
||||||
ifneq (,$(filter cortex-m0%,$(CPU_ARCH)))
|
ifneq (,$(filter cortex-m0%,$(CPU_CORE)))
|
||||||
# LLVM/clang can't handle the inline assembler instructions on M0 in this
|
# LLVM/clang can't handle the inline assembler instructions on M0 in this
|
||||||
# package
|
# package
|
||||||
TOOLCHAINS_BLACKLIST += llvm
|
TOOLCHAINS_BLACKLIST += llvm
|
||||||
|
@ -8,7 +8,7 @@ ifneq (,$(filter openthread_contrib,$(USEMODULE)))
|
|||||||
DIRS += $(OPENTHREAD_DIR)/contrib/netdev
|
DIRS += $(OPENTHREAD_DIR)/contrib/netdev
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq (,$(filter cortex-m0% cortex-m3%,$(CPU_ARCH)))
|
ifneq (,$(filter cortex-m0% cortex-m3%,$(CPU_CORE)))
|
||||||
# There are problem with unused `-mcpu...` arguments in clang and with
|
# There are problem with unused `-mcpu...` arguments in clang and with
|
||||||
# ranlib + LLVM/clang in this package with Cortex-M0 and M3
|
# ranlib + LLVM/clang in this package with Cortex-M0 and M3
|
||||||
TOOLCHAINS_BLACKLIST += llvm
|
TOOLCHAINS_BLACKLIST += llvm
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
ifneq (,$(filter cortex-m23 cortex-m0%,$(CPU_ARCH)))
|
ifneq (,$(filter cortex-m23 cortex-m0%,$(CPU_CORE)))
|
||||||
USEMODULE += qDSA_asm
|
USEMODULE += qDSA_asm
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
ifneq (,$(filter cortex-m23 cortex-m0%,$(CPU_ARCH)))
|
ifneq (,$(filter cortex-m23 cortex-m0%,$(CPU_CORE)))
|
||||||
QDSA_IMPL ?= arm
|
QDSA_IMPL ?= arm
|
||||||
else
|
else
|
||||||
ifneq (,$(filter atmega_common,$(USEMODULE)))
|
ifneq (,$(filter atmega_common,$(USEMODULE)))
|
||||||
@ -12,7 +12,7 @@ export QDSA_IMPL
|
|||||||
|
|
||||||
INCLUDES += -I$(PKGDIRBASE)/qDSA/$(QDSA_IMPL)
|
INCLUDES += -I$(PKGDIRBASE)/qDSA/$(QDSA_IMPL)
|
||||||
|
|
||||||
ifeq (cortex-m0plus,$(CPU_ARCH))
|
ifeq (cortex-m0plus,$(CPU_CORE))
|
||||||
# There are problems with the LLVM assembler and the Cortex-M0+ instruction
|
# There are problems with the LLVM assembler and the Cortex-M0+ instruction
|
||||||
# set with this package
|
# set with this package
|
||||||
TOOLCHAINS_BLACKLIST += llvm
|
TOOLCHAINS_BLACKLIST += llvm
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
INCLUDES += -I$(PKGDIRBASE)/relic/include
|
INCLUDES += -I$(PKGDIRBASE)/relic/include
|
||||||
|
|
||||||
ifneq (,$(filter cortex-m%,$(CPU_ARCH)))
|
ifneq (,$(filter cortex-m%,$(CPU_CORE)))
|
||||||
# relic package package is not using system includes right now, so
|
# relic package package is not using system includes right now, so
|
||||||
# many newlib headers (not even stdio.h) are not found.
|
# many newlib headers (not even stdio.h) are not found.
|
||||||
# Fixed in #9821 for jerryscript, should be applicable here too.
|
# Fixed in #9821 for jerryscript, should be applicable here too.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
INCLUDES += -I$(PKGDIRBASE)/tensorflow-lite
|
INCLUDES += -I$(PKGDIRBASE)/tensorflow-lite
|
||||||
|
|
||||||
ifneq (,$(filter cortex-m%,$(CPU_ARCH)))
|
ifneq (,$(filter cortex-m%,$(CPU_CORE)))
|
||||||
# LLVM/clang triggers a hard fault on Cortex-M
|
# LLVM/clang triggers a hard fault on Cortex-M
|
||||||
TOOLCHAINS_BLACKLIST += llvm
|
TOOLCHAINS_BLACKLIST += llvm
|
||||||
endif
|
endif
|
||||||
|
@ -144,7 +144,7 @@ static void test_mtd_write_read(void)
|
|||||||
TEST_ASSERT_EQUAL_INT(-EINVAL, ret);
|
TEST_ASSERT_EQUAL_INT(-EINVAL, ret);
|
||||||
|
|
||||||
/* Only Cortex-M0 doesn't allow unaligned reads */
|
/* Only Cortex-M0 doesn't allow unaligned reads */
|
||||||
#if defined(CPU_ARCH_CORTEX_M0)
|
#if defined(CPU_CORE_CORTEX_M0)
|
||||||
ret = mtd_read(dev, buf_read, TEST_ADDRESS1 + sizeof(buf_empty), sizeof(buf_read));
|
ret = mtd_read(dev, buf_read, TEST_ADDRESS1 + sizeof(buf_empty), sizeof(buf_read));
|
||||||
TEST_ASSERT_EQUAL_INT(-EINVAL, ret);
|
TEST_ASSERT_EQUAL_INT(-EINVAL, ret);
|
||||||
#endif
|
#endif
|
||||||
|
@ -7,7 +7,7 @@ USEPKG += c25519
|
|||||||
include $(RIOTBASE)/Makefile.include
|
include $(RIOTBASE)/Makefile.include
|
||||||
|
|
||||||
# c25519 takes up to 1.5K in stack, almost independent of the platform
|
# c25519 takes up to 1.5K in stack, almost independent of the platform
|
||||||
ifneq (,$(filter cortex-%,$(CPU_ARCH)))
|
ifneq (,$(filter cortex-%,$(CPU_CORE)))
|
||||||
CFLAGS += -DTHREAD_STACKSIZE_MAIN=\(THREAD_STACKSIZE_DEFAULT+THREAD_EXTRA_STACKSIZE_PRINTF\)
|
CFLAGS += -DTHREAD_STACKSIZE_MAIN=\(THREAD_STACKSIZE_DEFAULT+THREAD_EXTRA_STACKSIZE_PRINTF\)
|
||||||
else
|
else
|
||||||
ifneq (,$(filter atmega_common,$(USEMODULE)))
|
ifneq (,$(filter atmega_common,$(USEMODULE)))
|
||||||
|
@ -27,7 +27,7 @@ static void test_atomic_flag(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Prevent compiler optimization for SAML1X because of gcc internal bug */
|
/* Prevent compiler optimization for SAML1X because of gcc internal bug */
|
||||||
#ifdef CPU_ARCH_CORTEX_M23
|
#ifdef CPU_CORE_CORTEX_M23
|
||||||
#pragma GCC push_options
|
#pragma GCC push_options
|
||||||
#pragma GCC optimize ("O0")
|
#pragma GCC optimize ("O0")
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user