2022-06-04 12:27:12 +01:00
|
|
|
// Deinitions common to all SAMD51 boards
|
|
|
|
#include "samd51.h"
|
|
|
|
|
2022-06-15 14:16:07 +01:00
|
|
|
#define MICROPY_CONFIG_ROM_LEVEL (MICROPY_CONFIG_ROM_LEVEL_FULL_FEATURES)
|
|
|
|
|
|
|
|
// MicroPython emitters
|
|
|
|
#define MICROPY_EMIT_THUMB (1)
|
|
|
|
#define MICROPY_EMIT_INLINE_THUMB (1)
|
|
|
|
|
2022-06-04 12:27:12 +01:00
|
|
|
#define MICROPY_FLOAT_IMPL (MICROPY_FLOAT_IMPL_FLOAT)
|
2022-09-08 16:55:08 +01:00
|
|
|
|
|
|
|
#ifndef MICROPY_PY_BUILTINS_COMPLEX
|
2022-06-04 12:27:12 +01:00
|
|
|
#define MICROPY_PY_BUILTINS_COMPLEX (0)
|
2022-09-08 16:55:08 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef MICROPY_PY_MATH
|
2022-06-21 19:31:20 +01:00
|
|
|
#define MICROPY_PY_MATH (1)
|
|
|
|
#define MP_NEED_LOG2 (1)
|
2022-09-08 16:55:08 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef MICROPY_PY_CMATH
|
2022-06-04 12:27:12 +01:00
|
|
|
#define MICROPY_PY_CMATH (0)
|
2022-09-08 16:55:08 +01:00
|
|
|
#endif
|
2022-06-15 14:16:07 +01:00
|
|
|
|
2022-07-07 08:49:51 +01:00
|
|
|
#define MICROPY_PY_MACHINE_DHT_READINTO (1)
|
2022-06-21 13:27:20 +01:00
|
|
|
#define MICROPY_PY_ONEWIRE (1)
|
2022-06-05 20:08:37 +01:00
|
|
|
#define MICROPY_PY_UOS_URANDOM (1)
|
|
|
|
#define MICROPY_PY_URANDOM_SEED_INIT_FUNC (trng_random_u32())
|
|
|
|
unsigned long trng_random_u32(void);
|
2022-06-04 12:27:12 +01:00
|
|
|
|
2022-09-15 14:58:54 +01:00
|
|
|
#ifndef MICROPY_PY_MACHINE_RTC
|
|
|
|
#if MICROPY_HW_XOSC32K
|
|
|
|
#define MICROPY_PY_MACHINE_RTC (1)
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2022-07-10 11:04:14 +01:00
|
|
|
// fatfs configuration used in ffconf.h
|
|
|
|
#define MICROPY_FATFS_ENABLE_LFN (1)
|
|
|
|
#define MICROPY_FATFS_RPATH (2)
|
|
|
|
#define MICROPY_FATFS_MAX_SS (4096)
|
|
|
|
#define MICROPY_FATFS_LFN_CODE_PAGE 437 /* 1=SFN/ANSI 437=LFN/U.S.(OEM) */
|
|
|
|
|
2022-06-15 14:16:07 +01:00
|
|
|
#define VFS_BLOCK_SIZE_BYTES (1536) //
|
2022-06-04 12:27:12 +01:00
|
|
|
|
2022-09-08 16:55:08 +01:00
|
|
|
#ifndef MICROPY_HW_UART_TXBUF
|
2022-06-15 14:16:07 +01:00
|
|
|
#define MICROPY_HW_UART_TXBUF (1)
|
2022-09-08 16:55:08 +01:00
|
|
|
#endif
|
2022-06-09 12:46:54 +01:00
|
|
|
|
2022-06-15 14:16:07 +01:00
|
|
|
#define CPU_FREQ (120000000)
|
2022-06-30 15:50:15 +01:00
|
|
|
#define DFLL48M_FREQ (48000000)
|
2022-06-29 16:22:20 +01:00
|
|
|
#define MAX_CPU_FREQ (200000000)
|
2022-06-15 14:16:07 +01:00
|
|
|
#define DPLLx_REF_FREQ (32768)
|
2022-06-06 10:13:25 +01:00
|
|
|
|
2022-06-15 14:16:07 +01:00
|
|
|
#define NVIC_PRIORITYGROUP_4 ((uint32_t)0x00000003)
|
|
|
|
#define IRQ_PRI_PENDSV NVIC_EncodePriority(NVIC_PRIORITYGROUP_4, 7, 0)
|
2022-06-06 10:13:25 +01:00
|
|
|
|
|
|
|
static inline uint32_t raise_irq_pri(uint32_t pri) {
|
|
|
|
uint32_t basepri = __get_BASEPRI();
|
|
|
|
// If non-zero, the processor does not process any exception with a
|
|
|
|
// priority value greater than or equal to BASEPRI.
|
|
|
|
// When writing to BASEPRI_MAX the write goes to BASEPRI only if either:
|
|
|
|
// - Rn is non-zero and the current BASEPRI value is 0
|
|
|
|
// - Rn is non-zero and less than the current BASEPRI value
|
|
|
|
pri <<= (8 - __NVIC_PRIO_BITS);
|
|
|
|
__ASM volatile ("msr basepri_max, %0" : : "r" (pri) : "memory");
|
|
|
|
return basepri;
|
|
|
|
}
|
|
|
|
|
|
|
|
// "basepri" should be the value returned from raise_irq_pri
|
|
|
|
static inline void restore_irq_pri(uint32_t basepri) {
|
|
|
|
__set_BASEPRI(basepri);
|
|
|
|
}
|