arch: use CMSIS after all
It was inevitable, tbh. I really wanted to do everything entirely from scratch, but all those hardware registers are just too much to be maintained by a single person. And since i plan on supporting different boards at some point in the future, it would be complete madness to redo everything for that board.
This commit is contained in:
parent
b122e54ec8
commit
60f1ebea8a
13 changed files with 165 additions and 841 deletions
6
.gitmodules
vendored
Normal file
6
.gitmodules
vendored
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
[submodule "contrib/arduino-cmsis"]
|
||||||
|
path = contrib/arduino-cmsis
|
||||||
|
url = https://github.com/arduino/ArduinoModule-CMSIS-Atmel.git
|
||||||
|
[submodule "contrib/cmsis"]
|
||||||
|
path = contrib/cmsis
|
||||||
|
url = https://github.com/ARM-software/CMSIS_5.git
|
|
@ -15,6 +15,17 @@ endif()
|
||||||
|
|
||||||
find_package(Git QUIET)
|
find_package(Git QUIET)
|
||||||
if(GIT_FOUND AND EXISTS "${PROJECT_SOURCE_DIR}/.git")
|
if(GIT_FOUND AND EXISTS "${PROJECT_SOURCE_DIR}/.git")
|
||||||
|
option(GIT_SUBMODULE "Update git submodules during build" ON)
|
||||||
|
if(GIT_SUBMODULE)
|
||||||
|
message(STATUS "Git submodule update")
|
||||||
|
execute_process(COMMAND ${GIT_EXECUTABLE} submodule update --init --recursive
|
||||||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
RESULT_VARIABLE GIT_SUBMOD_RESULT)
|
||||||
|
if(NOT GIT_SUBMOD_RESULT EQUAL "0")
|
||||||
|
message(FATAL_ERROR "git submodule update --init --recursive failed with ${GIT_SUBMOD_RESULT}, please checkout submodules")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
execute_process(
|
execute_process(
|
||||||
COMMAND ${GIT_EXECUTABLE} rev-parse --short HEAD
|
COMMAND ${GIT_EXECUTABLE} rev-parse --short HEAD
|
||||||
WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
||||||
|
|
|
@ -4,7 +4,13 @@ add_library(ardix_arch STATIC)
|
||||||
target_link_libraries(ardix INTERFACE ardix_arch)
|
target_link_libraries(ardix INTERFACE ardix_arch)
|
||||||
|
|
||||||
target_compile_options(ardix_arch PRIVATE ${ARDIX_COMPILE_OPTIONS})
|
target_compile_options(ardix_arch PRIVATE ${ARDIX_COMPILE_OPTIONS})
|
||||||
target_include_directories(ardix_arch PRIVATE ${ARDIX_INCLUDE_DIRS})
|
target_include_directories(ardix_arch PRIVATE
|
||||||
|
${ARDIX_INCLUDE_DIRS}
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/../../contrib/arduino-cmsis/CMSIS-Atmel/CMSIS/Device/ATMEL/sam3xa/include
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/../../contrib/cmsis/CMSIS/Core/Include
|
||||||
|
)
|
||||||
|
|
||||||
|
target_compile_definitions(ardix_arch PRIVATE ARDIX_ARCH)
|
||||||
|
|
||||||
configure_file(
|
configure_file(
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/config.ld.in
|
${CMAKE_CURRENT_SOURCE_DIR}/config.ld.in
|
||||||
|
@ -22,7 +28,6 @@ target_sources(ardix_arch PRIVATE
|
||||||
handle_pend_sv.S
|
handle_pend_sv.S
|
||||||
handle_reset.c
|
handle_reset.c
|
||||||
handle_svc.S
|
handle_svc.S
|
||||||
interrupt.c
|
|
||||||
mutex.S
|
mutex.S
|
||||||
sched.c
|
sched.c
|
||||||
serial.c
|
serial.c
|
||||||
|
|
|
@ -10,22 +10,22 @@
|
||||||
/** Setup UART to manual byte-by-byte control */
|
/** Setup UART to manual byte-by-byte control */
|
||||||
static inline void uart_emergency_setup(void)
|
static inline void uart_emergency_setup(void)
|
||||||
{
|
{
|
||||||
REG_UART_PDC_PTCR = REG_UART_PDC_PTCR_RXTDIS_MASK | REG_UART_PDC_PTCR_TXTDIS_MASK;
|
UART->UART_PTCR = UART_PTCR_RXTDIS | UART_PTCR_TXTDIS;
|
||||||
|
|
||||||
REG_UART_CR = REG_UART_CR_RXDIS_MASK | REG_UART_CR_RSTRX_MASK
|
UART->UART_CR = UART_CR_RXDIS | UART_CR_RSTRX
|
||||||
| REG_UART_CR_TXDIS_MASK | REG_UART_CR_RSTTX_MASK;
|
| UART_CR_TXDIS | UART_CR_RSTTX;
|
||||||
|
|
||||||
REG_UART_IDR = 0xffffffff;
|
UART->UART_IDR = 0xffffffff;
|
||||||
|
|
||||||
REG_UART_CR = REG_UART_CR_RXEN_MASK | REG_UART_CR_TXEN_MASK;
|
UART->UART_CR = UART_CR_RXEN | UART_CR_TXEN;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void uart_write_sync(const char *s)
|
static void uart_write_sync(const char *s)
|
||||||
{
|
{
|
||||||
char c;
|
char c;
|
||||||
while ((c = *s++) != '\0') {
|
while ((c = *s++) != '\0') {
|
||||||
mom_are_we_there_yet(REG_UART_SR & REG_UART_SR_TXRDY_MASK);
|
mom_are_we_there_yet(UART->UART_SR & UART_SR_TXRDY);
|
||||||
REG_UART_THR = c;
|
UART->UART_THR = c;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,31 +6,8 @@
|
||||||
|
|
||||||
typedef uint32_t word_t;
|
typedef uint32_t word_t;
|
||||||
|
|
||||||
/** Current (volatile) system frequency in Hertz. */
|
/** Current system frequency in Hertz. */
|
||||||
extern uint32_t sys_core_clock;
|
extern volatile uint32_t SystemCoreClock;
|
||||||
|
|
||||||
/** Pointer size in bytes */
|
|
||||||
#define PTRSIZE 4
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A software snapshot of all registers that have not been saved by automated
|
|
||||||
* hardware routines on IRQ entry. Required for scheduling / context switching.
|
|
||||||
*/
|
|
||||||
struct reg_sw_snapshot {
|
|
||||||
word_t r4;
|
|
||||||
word_t r5;
|
|
||||||
word_t r6;
|
|
||||||
word_t r7;
|
|
||||||
word_t r8;
|
|
||||||
word_t r9;
|
|
||||||
word_t r10;
|
|
||||||
word_t r11;
|
|
||||||
/*
|
|
||||||
* lr is saved by hardware, but we need to store it twice
|
|
||||||
* because the IRQ entry overwrites it
|
|
||||||
*/
|
|
||||||
void *lr; /* alias r14 */
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* All registers that are automatically saved by hardware routines when entering
|
* All registers that are automatically saved by hardware routines when entering
|
||||||
|
@ -47,705 +24,48 @@ struct reg_hw_snapshot {
|
||||||
word_t psr;
|
word_t psr;
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Combination of `struct reg_sw_snapshot` and `struct reg_hw_snapshot`. */
|
|
||||||
struct reg_snapshot {
|
struct reg_snapshot {
|
||||||
struct reg_sw_snapshot sw;
|
word_t r0;
|
||||||
struct reg_hw_snapshot hw;
|
word_t r1;
|
||||||
|
word_t r2;
|
||||||
|
word_t r3;
|
||||||
|
word_t r4;
|
||||||
|
word_t r5;
|
||||||
|
word_t r6;
|
||||||
|
word_t r7;
|
||||||
|
word_t r8;
|
||||||
|
word_t r9;
|
||||||
|
word_t r10;
|
||||||
|
word_t r11;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ATTENTION: the following registers might actually be stored on the
|
||||||
|
* other stack; don't access them unless you know exactly
|
||||||
|
* what you're doing
|
||||||
|
*/
|
||||||
|
|
||||||
|
word_t _r12;
|
||||||
|
void *_lr; /* alias r14 */
|
||||||
|
void *_pc; /* alias r15 */
|
||||||
|
word_t _psr;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define arch_syscall_num(reg_snap) ((reg_snap)->sw.r7)
|
#define arch_syscall_num(reg_snap) ((reg_snap)->r7)
|
||||||
#define arch_syscall_arg1(reg_snap) ((reg_snap)->hw.r0)
|
#define arch_syscall_arg1(reg_snap) ((reg_snap)->r0)
|
||||||
#define arch_syscall_arg2(reg_snap) ((reg_snap)->hw.r1)
|
#define arch_syscall_arg2(reg_snap) ((reg_snap)->r1)
|
||||||
#define arch_syscall_arg3(reg_snap) ((reg_snap)->hw.r2)
|
#define arch_syscall_arg3(reg_snap) ((reg_snap)->r2)
|
||||||
#define arch_syscall_arg4(reg_snap) ((reg_snap)->hw.r3)
|
#define arch_syscall_arg4(reg_snap) ((reg_snap)->r3)
|
||||||
#define arch_syscall_arg5(reg_snap) ((reg_snap)->sw.r4)
|
#define arch_syscall_arg5(reg_snap) ((reg_snap)->r4)
|
||||||
#define arch_syscall_arg6(reg_snap) ((reg_snap)->sw.r5)
|
#define arch_syscall_arg6(reg_snap) ((reg_snap)->r5)
|
||||||
|
|
||||||
#define arch_syscall_set_rval(reg_snap, val) ((reg_snap)->hw.r0 = (word_t)(val));
|
#define arch_syscall_set_rval(reg_snap, val) ((reg_snap)->r0 = (word_t)(val));
|
||||||
|
|
||||||
/*
|
#ifdef ARDIX_ARCH
|
||||||
* Real-time Timer (RTT)
|
# define __SAM3X8E__
|
||||||
*/
|
# define DONT_USE_CMSIS_INIT
|
||||||
|
# define __PROGRAM_START
|
||||||
/** Real-time Timer Mode Register */
|
# include <sam3x8e.h>
|
||||||
#define REG_RTT_MR (*(volatile uint32_t *)0x400E1A30U)
|
#endif /* ARDIX_ARCH */
|
||||||
/** Real-time Timer Restart bitmask (for `RTT_MR`) */
|
|
||||||
#define REG_RTT_RTTRST_BIT ((uint32_t)1 << 18)
|
|
||||||
/** Real-time Timer Increment Interrupt Enable bitmask (for `REG_RTT_MR`) */
|
|
||||||
#define REG_RTT_RTTINCIEN_BIT ((uint32_t)1 << 17)
|
|
||||||
/** Alarm Interrupt Enable bitmask (for `REG_RTT_MR`) */
|
|
||||||
#define REG_RTT_ALMIEN_BIT ((uint32_t)1 << 16)
|
|
||||||
/** Real-time Timer Prescaler Value */
|
|
||||||
#define REG_RTT_RTPRES (*(volatile uint16_t *)0x400E1A30U)
|
|
||||||
|
|
||||||
/** Real-time Timer Alarm Register */
|
|
||||||
#define REG_RTT_AR (*(volatile uint32_t *)0x400E1A34U)
|
|
||||||
/** Real-time Timer Alarm Value */
|
|
||||||
#define REG_RTT_AR_ALMV REG_RTT_AR
|
|
||||||
|
|
||||||
/** Real-time timer Value Register */
|
|
||||||
#define REG_RTT_VR (*(volatile uint32_t *)0x400E1A38U)
|
|
||||||
/** Current Real-time Value */
|
|
||||||
#define REG_RTT_VR_CRTV REG_RTT_VR
|
|
||||||
|
|
||||||
/** Real-time Timer Status Register */
|
|
||||||
#define REG_RTT_SR (*(const volatile uint32_t *)0x400E1A3CU)
|
|
||||||
/** Real-time Timer Increment bitmask (for `REG_RTT_SR`) */
|
|
||||||
#define REG_RTT_SR_RTTINC_BIT ((uint32_t)1 << 1)
|
|
||||||
/** Real-time Timer Alarm Status bitmask (for `REG_RTT_SR`) */
|
|
||||||
#define REG_RTT_SR_ALMS_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* SysTick
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** SysTick Control and Status Register */
|
|
||||||
#define REG_SYSTICK_CTRL (*(volatile uint32_t *)0xE000E010U)
|
|
||||||
/** SysTick CTRL COUNTFLAG bitmask (for `REG_SYSTICK_CTRL`) */
|
|
||||||
#define REG_SYSTICK_CTRL_COUNTFLAG_BIT ((uint32_t)1 << 16)
|
|
||||||
/** SysTick CTRL CLKSOURCE bitmask (for `REG_SYSTICK_CTRL`) */
|
|
||||||
#define REG_SYSTICK_CTRL_CLKSOURCE_BIT ((uint32_t)1 << 2)
|
|
||||||
/** SysTick CTRL exception request enable bitmask (for `REG_SYSTICK_CTRL`) */
|
|
||||||
#define REG_SYSTICK_CTRL_TICKINT_BIT ((uint32_t)1 << 1)
|
|
||||||
/** SysTick CTRL enable bitmask (for `REG_SYSTICK_CTRL`) */
|
|
||||||
#define REG_SYSTICK_CTRL_ENABLE_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/** SysTick Reload Value Register */
|
|
||||||
#define REG_SYSTICK_LOAD (*(volatile uint32_t *)0xE000E014U)
|
|
||||||
#define REG_SYSTICK_LOAD_RELOAD_MASK ((uint32_t)0x00FFFFFFU)
|
|
||||||
|
|
||||||
/** SysTick Current Value Register */
|
|
||||||
#define REG_SYSTICK_VAL (*(volatile uint32_t *)0xE000E018U)
|
|
||||||
/** SysTick Current Value bitmask (for `REG_SYSTICK_VAL`) */
|
|
||||||
#define REG_SYSTICK_VAL_CURRENT_MASK ((uint32_t)0x00FFFFFFU)
|
|
||||||
|
|
||||||
/** SysTick Calibration Value Register */
|
|
||||||
#define REG_SYSTICK_CALIB (*(volatile uint32_t *)0xE000E01CU)
|
|
||||||
#define REG_SYSTICK_CALIB_NOREF_MASK ((uint32_t)1 << 31)
|
|
||||||
#define REG_SYSTICK_CALIB_SKEW_MASK ((uint32_t)1 << 30)
|
|
||||||
#define REG_SYSTICK_CALIB_TENMS_MASK ((uint32_t)0x00FFFFFFU)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Real-time Clock (RTC)
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** RTC Control Register */
|
|
||||||
#define REG_RTC_CR (*(volatile uint32_t *)0x400E1A60U)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Parallel Input/Output Controller (PIO)
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* put these into the `n` parameter below. PIOA - PIOF are exactly the same,
|
|
||||||
* except that their register addresses are offset by 0x200 respectively.
|
|
||||||
*/
|
|
||||||
#define PIOA 0
|
|
||||||
#define PIOB 1
|
|
||||||
#define PIOC 2
|
|
||||||
#define PIOD 3
|
|
||||||
|
|
||||||
/** PIO Controller n Enable Register (requires `REG_PIOA_WPMR` to be cleared) */
|
|
||||||
#define REG_PIO_PER(n) (*(volatile uint32_t *)(0x400E0E00U + 0x200U * n))
|
|
||||||
/** PIO Controller n Disable Register (requires `REG_PIO_WPMR` to be cleared) */
|
|
||||||
#define REG_PIO_PDR(n) (*(volatile uint32_t *)(0x400E0E04U + 0x200U * n))
|
|
||||||
/** PIO Controller n Status Register */
|
|
||||||
#define REG_PIO_PSR(n) (*(volatile uint32_t *)(0x400E0E08U + 0x200U * n))
|
|
||||||
/** PIO Controller n Output Enable Register (requires `REG_PIO_WPMR` to be cleared) */
|
|
||||||
#define REG_PIO_OER(n) (*(volatile uint32_t *)(0x400E0E10U + 0x200U * n))
|
|
||||||
/** PIO Controller n Output Disable Register (newwds `REG_PIO_WPMR` to be cleared) */
|
|
||||||
#define REG_PIO_ODR(n) (*(volatile uint32_t *)(0x400E0E14U + 0x200U * n))
|
|
||||||
/** PIO Controller n Output Status Register */
|
|
||||||
#define REG_PIO_OSR(n) (*(volatile uint32_t *)(0x400E0E18U + 0x200U * n))
|
|
||||||
/** PIO Controller n Input Filter Enable Register (requires `REG_PIO_WPMR` to be cleared) */
|
|
||||||
#define REG_PIO_IFER(n) (*(volatile uint32_t *)(0x400E0E20U + 0x200U * n))
|
|
||||||
/** PIO Controller A Input Filter Disable Register (requires `REG_PIO_WPMR` to be cleared) */
|
|
||||||
#define REG_PIO_IFDR(n) (*(volatile uint32_t *)(0x400E0E24U + 0x200U * n))
|
|
||||||
/** PIO Controller n Input Filter Status Register */
|
|
||||||
#define REG_PIO_IFSR(n) (*(volatile uint32_t *)(0x400E0E28U + 0x200U * n))
|
|
||||||
/** PIO Controller n Set Output Data Register */
|
|
||||||
#define REG_PIO_SODR(n) (*(volatile uint32_t *)(0x400E0E30U + 0x200U * n))
|
|
||||||
/** PIO Controller n Clear Output Data Register */
|
|
||||||
#define REG_PIO_CODR(n) (*(volatile uint32_t *)(0x400E0E34U + 0x200U * n))
|
|
||||||
/** PIO Controller n Output Data Status Register */
|
|
||||||
#define REG_PIO_ODSR(n) (*(volatile uint32_t *)(0x400E0E38U + 0x200U * n))
|
|
||||||
/** PIO Controller n Pin Data Status Register */
|
|
||||||
#define REG_PIO_PDSR(n) (*(volatile uint32_t *)(0x400E0E3CU + 0x200U * n))
|
|
||||||
/** PIO Controller n Interrupt Enable Register */
|
|
||||||
#define REG_PIO_IER(n) (*(volatile uint32_t *)(0x400E0E40U + 0x200U * n))
|
|
||||||
/** PIO Controller n Interrupt Disable Register */
|
|
||||||
#define REG_PIO_IDR(n) (*(volatile uint32_t *)(0x400E0E44U + 0x200U * n))
|
|
||||||
/** PIO Controller n Interrupt Mask Register */
|
|
||||||
#define REG_PIO_IMR(n) (*(volatile uint32_t *)(0x400E0E48U + 0x200U * n))
|
|
||||||
/** PIO Controller n Interrupt Status Register */
|
|
||||||
#define REG_PIO_ISR(n) (*(volatile uint32_t *)(0x400E0E4CU + 0x200U * n))
|
|
||||||
/** PIO Controller n Multi-driver Enable Register */
|
|
||||||
#define REG_PIO_MDER(n) (*(volatile uint32_t *)(0x400E0E50U + 0x200U * n))
|
|
||||||
/** PIO Controller n Multi-dtiver Disable Register */
|
|
||||||
#define REG_PIO_MDDR(n) (*(volatile uint32_t *)(0x400E0E54U + 0x200U * n))
|
|
||||||
/** PIO Controller n Multi-driver Status Register */
|
|
||||||
#define REG_PIO_MDSR(n) (*(volatile uint32_t *)(0x400E0E58U + 0x200U * n))
|
|
||||||
/** PIO Controller n Pull Up Disable Register (requires `REG_PIO_WPMR` to be cleared) */
|
|
||||||
#define REG_PIO_PUDR(n) (*(volatile uint32_t *)(0x400E0E60U + 0x200U * n))
|
|
||||||
/** PIO Controller n Pull Up Enable Register (requires `REG_PIO_WPMR` to be cleared) */
|
|
||||||
#define REG_PIO_PUER(n) (*(volatile uint32_t *)(0x400E0E64U + 0x200U * n))
|
|
||||||
/** PIO Controller n Pull Up Status Register */
|
|
||||||
#define REG_PIO_PUSR(n) (*(volatile uint32_t *)(0x400E0E68U + 0x200U * n))
|
|
||||||
/** PIO Controller n Peripheral AB Select Register (requires `REG_PIO_WPMR` to be cleared) */
|
|
||||||
#define REG_PIO_ABSR(n) (*(volatile uint32_t *)(0x400E0E70U + 0x200U * n))
|
|
||||||
|
|
||||||
/* TODO: It's 3 am I really don't feel like doint the rest of these endless registers */
|
|
||||||
|
|
||||||
/** PIO Controller n Write Protect Mode Register */
|
|
||||||
#define REG_PIO_WPMR(n) (*(volatile uint32_t *)(0x400E0EE4U + 0x200U * n))
|
|
||||||
#define REG_PIO_WPMR_KEY ((uint32_t)0x50494FU << 8)
|
|
||||||
#define REG_PIO_WPMR_WPEN_VAL(val) ((uint32_t)val | REG_PIO_WPMR_KEY)
|
|
||||||
/** PIO Controller n Write Protect Status Register */
|
|
||||||
#define REG_PIO_WPSR(n) (*(volatile uint32_t *)0x400E0EE8U + 0x200U * n)
|
|
||||||
#define REG_PIO_WPSR_WPVSRC_MASK ((uint32_t)0x00FFFF00U)
|
|
||||||
#define REG_PIO_WPSR_WPVSRC_VAL(val) ((val & REG_PIO_WPSR_WPVSRC_MASK) >> 8)
|
|
||||||
#define REG_PIO_WPSR_WPVS_MASK ((uint32_t)1)
|
|
||||||
#define REG_PIO_WPST_WPVS_VAL(val) (val & 1U)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Universal Asynchronous Receiver Transceiver (UART)
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** UART Control Register */
|
|
||||||
#define REG_UART_CR (*(volatile uint32_t *)0x400E0800U)
|
|
||||||
/** UART Control Register Reset Status Bits bitmask (for `REG_UART_CR`) */
|
|
||||||
#define REG_UART_CR_RSTSTA_MASK ((uint32_t)1 << 8)
|
|
||||||
/** UART Control Register Transmitter Disable bitmaask (for `REG_UART_CR`) */
|
|
||||||
#define REG_UART_CR_TXDIS_MASK ((uint32_t)1 << 7)
|
|
||||||
/** UART Control Register Transmitter Enable bitmaask (for `REG_UART_CR`) */
|
|
||||||
#define REG_UART_CR_TXEN_MASK ((uint32_t)1 << 6)
|
|
||||||
/** UART Control Register Receiver Disable bitmask (for `REG_UART_CR`) */
|
|
||||||
#define REG_UART_CR_RXDIS_MASK ((uint32_t)1 << 5)
|
|
||||||
/** UART Control Register Receiver Enable bitmask (for `REG_UART_CR`) */
|
|
||||||
#define REG_UART_CR_RXEN_MASK ((uint32_t)1 << 4)
|
|
||||||
/** UART Control Register Reset Transmitter bitmask (for `REG_UART_CR`) */
|
|
||||||
#define REG_UART_CR_RSTTX_MASK ((uint32_t)1 << 3)
|
|
||||||
/** UART Control Register Reset Receiver bitmask (for `REG_UART_CR`) */
|
|
||||||
#define REG_UART_CR_RSTRX_MASK ((uint32_t)1 << 2)
|
|
||||||
|
|
||||||
/** UART Mode Register */
|
|
||||||
#define REG_UART_MR (*(volatile uint32_t *)0x400E0804U)
|
|
||||||
/** UART Mode Register Channel Mode bitmask (for `REG_UART_MR`) */
|
|
||||||
#define REG_UART_MR_CHMODE_MASK ((uint32_t)3 << 14)
|
|
||||||
/** Mask and shift the value of `REG_UART_MR` to get `CHMODE` */
|
|
||||||
#define REG_UART_MR_CHMODE_VAL(val) ((val & REG_UART_MR_CHMODE_MASK) >> 14)
|
|
||||||
/** UART Mode Register Parity Type bitmask (for `REG_UART_MR`) */
|
|
||||||
#define REG_UART_MR_PAR_MASK ((uint32_t)7 << 9)
|
|
||||||
/** Mask and shift the value of `REG_UART_MR` to get `PAR`*/
|
|
||||||
#define REG_UART_MR_PAR_VAL(val) ((val & REG_UART_MR_PAR_MASK) >> 9)
|
|
||||||
/** Normal mode */
|
|
||||||
#define REG_UART_MR_CHMODE_NORMAL ((uint32_t)0)
|
|
||||||
/** Automatic Echo */
|
|
||||||
#define REG_UART_MR_CHMODE_AUTOMATIC ((uint32_t)1 << 14)
|
|
||||||
/** Local Loopback */
|
|
||||||
#define REG_UART_MR_CHMODE_LOCAL_LOOPBACK ((uint32_t)2 << 14)
|
|
||||||
/** Remote Loopback */
|
|
||||||
#define REG_UART_MR_CHMODE_REMOTE_LOOPBACK ((uint32_t)3 << 14)
|
|
||||||
|
|
||||||
#define REG_UART_MR_PAR_EVEN ((uint32_t)0)
|
|
||||||
#define REG_UART_MR_PAR_ODD ((uint32_t)1 << 9)
|
|
||||||
#define REG_UART_MR_PAR_SPACE ((uint32_t)2 << 9)
|
|
||||||
#define REG_UART_MR_PAR_MARK ((uint32_t)3 << 9)
|
|
||||||
#define REG_UART_MR_PAR_NO ((uint32_t)4 << 9)
|
|
||||||
|
|
||||||
/** UART Interrupt Enable Register */
|
|
||||||
#define REG_UART_IER (*(volatile uint32_t *)0x400E0808U)
|
|
||||||
/** UART IER Enable RXRDY Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_RXRDY_MASK ((uint32_t)1 << 0)
|
|
||||||
/** UART IER Enable TXRDY Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_TXRDY_MASK ((uint32_t)1 << 1)
|
|
||||||
/** UART IER Enable End of Receive Transfer Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_ENDRX_MASK ((uint32_t)1 << 3)
|
|
||||||
/** UART IER Enable End of Transmit Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_ENDTX_MASK ((uint32_t)1 << 4)
|
|
||||||
/** UART IER Enable Overrun Error Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_OVRE_MASK ((uint32_t)1 << 5)
|
|
||||||
/** UART IER Enable Framing Error Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_FRAME_MASK ((uint32_t)1 << 6)
|
|
||||||
/** UART IER Enable Parity Error Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_PARE_MASK ((uint32_t)1 << 7)
|
|
||||||
/** UART IER Enable TXEMPTY Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_TXEMPTY_MASK ((uint32_t)1 << 9)
|
|
||||||
/** UART IER Enable Buffer Empty Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_TXBUFE_MASK ((uint32_t)1 << 11)
|
|
||||||
/** UART IER Enable Buffer Full Interrupt bitmask (for `REG_UART_IER`) */
|
|
||||||
#define REG_UART_IER_RXBUFF_MASK ((uint32_t)1 << 12)
|
|
||||||
|
|
||||||
/** UART Interrupt Disable Register */
|
|
||||||
#define REG_UART_IDR (*(volatile uint32_t *)0x400E080CU)
|
|
||||||
/** UART IDR Disable RXRDY Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_RXRDY_MASK ((uint32_t)1 << 0)
|
|
||||||
/** UART IDR Disable TXRDY Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_TXRDY_MASK ((uint32_t)1 << 1)
|
|
||||||
/** UART IDR Disable End of Receive Transfer Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_ENDRX_MASK ((uint32_t)1 << 3)
|
|
||||||
/** UART IDR Disable End of Transmit Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_ENDTX_MASK ((uint32_t)1 << 4)
|
|
||||||
/** UART IDR Disable Overrun Error Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_OVRE_MASK ((uint32_t)1 << 5)
|
|
||||||
/** UART IDR Disable Framing Error Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_FRAME_MASK ((uint32_t)1 << 6)
|
|
||||||
/** UART IDR Disable Parity Error Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_PARE_MASK ((uint32_t)1 << 7)
|
|
||||||
/** UART IDR Disable TXEMPTY Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_TXEMPTY_MASK ((uint32_t)1 << 9)
|
|
||||||
/** UART IDR Disable Buffer Empty Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_TXBUFE_MASK ((uint32_t)1 << 11)
|
|
||||||
/** UART IDR Disable Buffer Full Interrupt bitmask (for `REG_UART_IDR`) */
|
|
||||||
#define REG_UART_IDR_RXBUFF_MASK ((uint32_t)1 << 12)
|
|
||||||
|
|
||||||
/** UART Interrupt Mask Register */
|
|
||||||
#define REG_UART_IMR (*(volatile uint32_t *)0x400E0810U)
|
|
||||||
/** UART IMR Mask RXRDY Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_RXRDY_MASK ((uint32_t)1 << 0)
|
|
||||||
/** UART IMR Mask TXRDY Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_TXRDY_MASK ((uint32_t)1 << 1)
|
|
||||||
/** UART IMR Mask End of Receive Transfer Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_ENDRX_MASK ((uint32_t)1 << 3)
|
|
||||||
/** UART IMR Mask End of Transmit Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_ENDTX_MASK ((uint32_t)1 << 4)
|
|
||||||
/** UART IMR Mask Overrun Error Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_OVRE_MASK ((uint32_t)1 << 5)
|
|
||||||
/** UART IMR Mask Framing Error Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_FRAME_MASK ((uint32_t)1 << 6)
|
|
||||||
/** UART IMR Mask Parity Error Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_PARE_MASK ((uint32_t)1 << 7)
|
|
||||||
/** UART IMR Mask TXEMPTY Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_TXEMPTY_MASK ((uint32_t)1 << 9)
|
|
||||||
/** UART IMR Mask Buffer Empty Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_TXBUFE_MASK ((uint32_t)1 << 11)
|
|
||||||
/** UART IMR Mask Buffer Full Interrupt bitmask (for `REG_UART_IMR`) */
|
|
||||||
#define REG_UART_IMR_RXBUFF_MASK ((uint32_t)1 << 12)
|
|
||||||
|
|
||||||
/** UART Status Register */
|
|
||||||
#define REG_UART_SR (*(volatile uint32_t *)0x400E0814U)
|
|
||||||
/** UART SR Receiver Ready bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_RXRDY_MASK ((uint32_t)1 << 0)
|
|
||||||
/** UART SR Transmitter Ready bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_TXRDY_MASK ((uint32_t)1 << 1)
|
|
||||||
/** UART SR End of Receiver Transfer bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_ENDRX_MASK ((uint32_t)1 << 3)
|
|
||||||
/** UART SR End of Transmitter Transfer bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_ENDTX_MASK ((uint32_t)1 << 4)
|
|
||||||
/** UART SR Overrun Error bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_OVRE_MASK ((uint32_t)1 << 5)
|
|
||||||
/** UART SR Framing Error bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_FRAME_MASK ((uint32_t)1 << 6)
|
|
||||||
/** UART SR Parity Error bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_PARE_MASK ((uint32_t)1 << 7)
|
|
||||||
/** UART SR TXEMPTY bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_TXEMPTY_MASK ((uint32_t)1 << 9)
|
|
||||||
/** UART SR Buffer Empty bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_TXBUFE_MASK ((uint32_t)1 << 11)
|
|
||||||
/** UART SR Buffer Full bitmask (for `REG_UART_SR`) */
|
|
||||||
#define REG_UART_SR_RXBUFF_MASK ((uint32_t)1 << 12)
|
|
||||||
|
|
||||||
/** UART Receiver Holding Register */
|
|
||||||
#define REG_UART_RHR (*(volatile uint8_t *)0x400E0818U)
|
|
||||||
/** UART Receiver Holding Register */
|
|
||||||
#define REG_UART_THR (*(volatile uint8_t *)0x400E081CU)
|
|
||||||
|
|
||||||
/** UART Baud Rate Generator Register */
|
|
||||||
#define REG_UART_BRGR (*(volatile volatile uint16_t *)0x400E0820U)
|
|
||||||
|
|
||||||
/* UART PDC Area */
|
|
||||||
|
|
||||||
/** UART PDC Receive Pointer Register */
|
|
||||||
#define REG_UART_PDC_RPR (*(volatile uint32_t *)0x400E0900U)
|
|
||||||
/** UART PDC Receive Counter Register */
|
|
||||||
#define REG_UART_PDC_RCR (*(volatile uint16_t *)0x400E0904U)
|
|
||||||
/** UART PDC Transmit Pointer Register */
|
|
||||||
#define REG_UART_PDC_TPR (*(volatile uint32_t *)0x400E0908U)
|
|
||||||
/** UART PDC Transmit Counter Register */
|
|
||||||
#define REG_UART_PDC_TCR (*(volatile uint16_t *)0x400E090CU)
|
|
||||||
/** UART PDC Receive Next Pointer Register */
|
|
||||||
#define REG_UART_PDC_RNPR (*(volatile uint32_t *)0x400E0910U)
|
|
||||||
/** UART PDC Receive Next Counter Register */
|
|
||||||
#define REG_UART_PDC_RNCR (*(volatile uint32_t *)0x400E0914U)
|
|
||||||
/** UART PDC Transmit Next Pointer Register */
|
|
||||||
#define REG_UART_PDC_TNPR (*(volatile uint32_t *)0x400E0918U)
|
|
||||||
/** UART PDC Transmit Next Counter Register */
|
|
||||||
#define REG_UART_PDC_TNCR (*(volatile uint32_t *)0x400E091CU)
|
|
||||||
|
|
||||||
/** UART PDC Transfer Control Register */
|
|
||||||
#define REG_UART_PDC_PTCR (*(volatile uint32_t *)0x400E0920U)
|
|
||||||
#define REG_UART_PDC_PTCR_TXTDIS_MASK ((uint32_t)1 << 9)
|
|
||||||
#define REG_UART_PDC_PTCR_TXTEN_MASK ((uint32_t)1 << 8)
|
|
||||||
#define REG_UART_PDC_PTCR_RXTDIS_MASK ((uint32_t)1 << 1)
|
|
||||||
#define REG_UART_PDC_PTCR_RXTEN_MASK ((uint32_t)1 << 0)
|
|
||||||
|
|
||||||
/** UART PDC Transfer Status Register */
|
|
||||||
#define REG_UART_PDC_PTSR (*(volatile uint32_t *)(0x400E0800U + 0x124C))
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Nested Vectored Interrupt Controller
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** NVIC Interrupt Set-Enable Registers (2 total) */
|
|
||||||
#define REG_NVIC_ISER(n) (((volatile uint32_t *)0xE000E100U)[n])
|
|
||||||
/** NVIC Interrupt Clear-Enable Registers (2 total) */
|
|
||||||
#define REG_NVIC_ICER(n) (((volatile uint32_t *)0xE000E180U)[n])
|
|
||||||
/** NVIC Interrupt Set-Pending Registers (2 total) */
|
|
||||||
#define REG_NVIC_ISPR(n) (((volatile uint32_t *)0xE000E200U)[n])
|
|
||||||
/** NVIC Interrupt Clear-Pending Registers (2 total) */
|
|
||||||
#define REG_NVIC_ICPR(n) (((volatile uint32_t *)0xE000E280U)[n])
|
|
||||||
/** NVIC Interrupt Active Bit Registers (2 total) */
|
|
||||||
#define REG_NVIC_IABR(n) (((volatile uint32_t *)0xE000E300U)[n])
|
|
||||||
/** NVIC Interrupt Priority Registers (8 total) */
|
|
||||||
#define REG_NVIC_IPR(n) ((volatile uint32_t *)0xE000E400U)[n])
|
|
||||||
/** NVIC Software Trigger Interrupt Register */
|
|
||||||
#define REG_NVIC_STIR (*(volatile uint32_t *)0xE000EF00U)
|
|
||||||
|
|
||||||
/** System Control Block: Interrupt Control and State Register */
|
|
||||||
#define REG_SCB_ICSR (*(volatile uint32_t *)0xE000ED04U)
|
|
||||||
/** ICSR PendSV set-pending bit bitmask */
|
|
||||||
#define REG_SCB_ICSR_PENDSVSET_BIT ((uint32_t)1 << 28)
|
|
||||||
/** ICSR PendSV clear-pending bit bitmask */
|
|
||||||
#define REG_SCB_ICSR_PENDSVCLR_BIT ((uint32_t)1 << 27)
|
|
||||||
/** ICSR SysTick exception set-pending bit bitmask */
|
|
||||||
#define REG_SCB_ICSR_PENDSTSET_BIT ((uint32_t)1 << 26)
|
|
||||||
/** ICSR SysTick exception clear-pending bit bitmask */
|
|
||||||
#define REG_SCB_ICSR_PENDSTCLR_BIT ((uint32_t)1 << 25)
|
|
||||||
/** ICSR Interrupt pending flag, excluding Faults bitmask */
|
|
||||||
#define REG_SCB_ICSR_IRQPENDING_BIT ((uint32_t)1 << 22)
|
|
||||||
/**
|
|
||||||
* ICSR bitmask for highest priority pending & enabled exception
|
|
||||||
* (for `SCB_ICSR`). The value is shifted 12 to the left.
|
|
||||||
*/
|
|
||||||
#define REG_SCB_ICSR_VECTPENDING_MASK ((uint32_t)0b1111111111u << 12)
|
|
||||||
#define REG_SCB_ICSR_VECTPENDING_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 12) & REG_SCB_ICSR_VECTPENDING_MASK )
|
|
||||||
/** ICSR bitmask for whether there are preempted active exceptions */
|
|
||||||
#define REG_SCB_ICSR_RETTOBASE_BIT ((uint32_t)1 << 11)
|
|
||||||
/** ICSR active exception number bitmask */
|
|
||||||
#define REG_SCB_ICSR_VECTACTIVE_MASK ((uint32_t)0b111111111u)
|
|
||||||
#define REG_SCB_ICSR_VECTACTIVE_VAL(x) \
|
|
||||||
((uint32_t)(x) & REG_SCB_ICSR_VECTACTIVE_MASK)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* System Control Block:
|
|
||||||
* Application Interrupt and Reset Control Register
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Application Interrupt and Reset Control Register (AIRCR) */
|
|
||||||
#define REG_SCB_AIRCR (*(volatile uint32_t *)0xE000ED0CU)
|
|
||||||
#define REG_SCB_AIRCR_VECTKEY_MASK ((uint32_t)0xFFFF << 16)
|
|
||||||
#define REG_SCB_AIRCR_VECTKEY_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 16) & REG_SCB_AIRCR_VECTKEY_MASK )
|
|
||||||
#define REG_SCB_AIRCR_VECTKEY_MAGIC 0x05FA
|
|
||||||
#define REG_SCB_AIRCR_ENDIANESS_BIT ((uint32_t)1 << 15)
|
|
||||||
#define REG_SCB_AIRCR_PRIGROUP_MASK ((uint32_t)0x3 << 8)
|
|
||||||
#define REG_SCB_AIRCR_PRIGROUP_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 8) & REG_SCB_AIRCR_PRIGROUP_MASK )
|
|
||||||
#define REG_SCB_AIRCR_SYSRESETREQ_BIT ((uint32_t)1 << 2)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Enhanced Embedded Flash Controller (EEFC)
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** EEFC 0 Flash Mode Register */
|
|
||||||
#define REG_EEFC0_FMR (*(volatile uint32_t *)0x400E0A00U)
|
|
||||||
/** EEFC 1 Flash Mode Register */
|
|
||||||
#define REG_EEFC1_FMR (*(volatile uint32_t *)0x400E0C00U)
|
|
||||||
/** EEFC Flash Access Mode bitmask */
|
|
||||||
#define REG_EEFC_FAM_BIT ((uint32_t)1 << 24)
|
|
||||||
/** EEFC Flash Wait State bitmask (number of cycles for read/write = FWS + 1) */
|
|
||||||
#define REG_EEFC_FWS_MASK ((uint32_t)0x7U << 8)
|
|
||||||
#define REG_EEFC_FWS_VAL(x) ( ((uint32_t)(x) << 8) & REG_EEFC_FWS_MASK )
|
|
||||||
/** EEFC Ready Interrupt Enable bitmask */
|
|
||||||
#define REG_EEFC_FRDY_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Watchdog Timer (WDT)
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Watchdog Timer Control Register */
|
|
||||||
#define REG_WDT_CR (*(volatile uint32_t *)0x400E1A50U)
|
|
||||||
/** Watchdog Timer magic */
|
|
||||||
#define REG_WDT_CR_KEY ((uint32_t)0xA5U << 24)
|
|
||||||
/** Watchdog Restart bit */
|
|
||||||
#define REG_WDT_CR_WDRSTT_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/** Watchdog Timer Mode Register */
|
|
||||||
#define REG_WDT_MR (*(volatile uint32_t *)0x400E1A54U)
|
|
||||||
/** Watchdog Idle Halt bit */
|
|
||||||
#define REG_WDT_MR_WDIDLEHLT_BIT ((uint32_t)1 << 29)
|
|
||||||
/** Watchdog Debug Halt bit */
|
|
||||||
#define REG_WDT_MR_WDDBGHLT_BIT ((uint32_t)1 << 28)
|
|
||||||
/** Watchdog Delta Value bitmask */
|
|
||||||
#define REG_WDT_MR_WDD_MASK ((uint32_t)0xFFF << 16)
|
|
||||||
/** Set the Watchdog Delta Value */
|
|
||||||
#define REG_WDT_MR_WDD_VAL(x) ( ((uint32_t)(x) << 16) & REG_WDT_MR_WDD_MASK )
|
|
||||||
/** Watchdog Disable bit */
|
|
||||||
#define REG_WDT_MR_WDDIS_BIT ((uint32_t)1 << 15)
|
|
||||||
/** Watchdog Reset Processor bit */
|
|
||||||
#define REG_WDT_MR_WDRPROC_BIT ((uint32_t)1 << 14)
|
|
||||||
/** Watchdog Reset Enable bit */
|
|
||||||
#define REG_WDT_MR_WDRSTEN_BIT ((uint32_t)1 << 13)
|
|
||||||
/** Watchdog Fault Interrupt Enable bit */
|
|
||||||
#define REG_WDT_MR_WDFIEN_BIT ((uint32_t)1 << 12)
|
|
||||||
/** Watchdog Counter Value bitmask */
|
|
||||||
#define REG_WDT_MR_WDV_MASK ((uint32_t)0xFFF)
|
|
||||||
/** Get or set the Watchdog counter value */
|
|
||||||
#define REG_WDT_MR_WDV_VAL(x) ( ((uint32_t)(x)) & REG_WDT_MR_WDV_MASK )
|
|
||||||
|
|
||||||
/** Watchdog Timer Status Register */
|
|
||||||
#define REG_WDT_SR (*(volatile uint32_t *)0x400E1A58U)
|
|
||||||
/** Watchdog Error bit */
|
|
||||||
#define REG_WDT_SR_WDERR_BIT ((uint32_t)1 << 1)
|
|
||||||
/** Watchdog Underflow bit */
|
|
||||||
#define REG_WDT_SR_WDUNF_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Power Management Controller (PMC)
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** PMC System Clock Enable Register */
|
|
||||||
#define REG_PMC_SCER (*(volatile uint32_t *)0x400E0600U)
|
|
||||||
/** PMC Programmable Clock 2 Output Enable bitmask (for `REG_PMC_SCER`) */
|
|
||||||
#define REG_PMC_SCER_PCK2_BIT ((uint32_t)1 << 10)
|
|
||||||
/** PMC Programmable Clock 1 Output Enable bitmask (for `REG_PMC_SCER`) */
|
|
||||||
#define REG_PMC_SCER_PCK1_BIT ((uint32_t)1 << 9)
|
|
||||||
/** PMC Programmable Clock 0 Output Enable bitmask (for `REG_PMC_SCER`) */
|
|
||||||
#define REG_PMC_SCER_PCK0_BIT ((uint32_t)1 << 8)
|
|
||||||
/** PMC Enable USB OTG Clock bitmask for UTMI (for `REG_PMC_SCER`) */
|
|
||||||
#define REG_PMC_SCER_UOTGCLK_BIT ((uint32_t)1 << 5)
|
|
||||||
|
|
||||||
/** PMC System Clock Disable Register */
|
|
||||||
#define REG_PMC_SCDR (*(volatile uint32_t *)0x400E0604U)
|
|
||||||
/** PMC Programmable Clock 2 Output Disable bitmask (for `REG_PMC_SCDR`) */
|
|
||||||
#define REG_PMC_SCDR_PCK2_BIT ((uint32_t)1 << 10)
|
|
||||||
/** PMC Programmable Clock 1 Output Disable bitmask (for `REG_PMC_SCDR`) */
|
|
||||||
#define REG_PMC_SCDR_PCK1_BIT ((uint32_t)1 << 9)
|
|
||||||
/** PMC Programmable Clock 0 Output Disable bitmask (for `REG_PMC_SCDR`) */
|
|
||||||
#define REG_PMC_SCDR_PCK0_BIT ((uint32_t)1 << 8)
|
|
||||||
/** PMC Disable USB OTG Clock bitmask for UTMI (for `REG_PMC_SCDR`) */
|
|
||||||
#define REG_PMC_SCDR_UOTGCLK_BIT ((uint32_t)1 << 5)
|
|
||||||
|
|
||||||
/** PMC System Clock Status Register */
|
|
||||||
#define REG_PMC_SCSR (*(volatile uint32_t *)0x400E0608U)
|
|
||||||
/** PMC Programmable Clock 2 Output Status bitmask */
|
|
||||||
#define REG_PMC_SCSR_PCK2_BIT ((uint32_t)1 << 10)
|
|
||||||
/** PMC Programmable Clock 1 Output Status bitmask */
|
|
||||||
#define REG_PMC_SCSR_PCK1_BIT ((uint32_t)1 << 9)
|
|
||||||
/** PMC Programmable Clock 0 Output Status bitmask */
|
|
||||||
#define REG_PMC_SCSR_PCK0_BIT ((uint32_t)1 << 8)
|
|
||||||
/** PMC USB OTG Clock Status bitmask */
|
|
||||||
#define REG_PMC_SCSR_UOTGCLK_BIT ((uint32_t)1 << 5)
|
|
||||||
|
|
||||||
/** PMC Peripheral Clock Enable Register 0 */
|
|
||||||
#define REG_PMC_PCER0 (*(volatile uint32_t *)0x400E0610U)
|
|
||||||
/** PMC Peripheral Clock x Enable bitmask (2-31) */
|
|
||||||
#define REG_PMC_PCER0_PID(x) ((uint32_t)1 << x)
|
|
||||||
|
|
||||||
/** PMC Peripheral Clock Disable Register 0 */
|
|
||||||
#define REG_PMC_PCDR0 (*(volatile uint32_t *)0x400E0614U)
|
|
||||||
/** PMC Peripheral Clock x Disable bitmask (2-31) */
|
|
||||||
#define REG_PMC_PCDR0_PID(x) ((uint32_t)1 << x)
|
|
||||||
|
|
||||||
/** PMC Peripheral Clock Status Register 0 */
|
|
||||||
#define REG_PMC_PCSR0 (*(const volatile uint32_t *)0x400E0618U)
|
|
||||||
/** PMC Peripheral Clock x Status bitmask (2-31) */
|
|
||||||
#define REG_PMC_PCSR0_PID(x) ((uint32_t)1 << x)
|
|
||||||
|
|
||||||
/** PMC UTMI Clock Configuration Register */
|
|
||||||
#define REG_PMC_CKGR_UCKR (*(volatile uint32_t *)0x400E061CU)
|
|
||||||
/** PMC UTMI PLL Start-Up Time bitmask (shifted 20 to the left) */
|
|
||||||
#define REG_PMC_CKGR_UCKR_UPLLCOUNT_MASK ((uint32_t)0b1111 << 20)
|
|
||||||
/** PMC UTMI PLL Enable bitmask */
|
|
||||||
#define REG_PMC_CKGR_UCKR_UPLLEN_MASK ((uint32_t)1 << 16)
|
|
||||||
|
|
||||||
/** PMC Clock Generator Main Oscillator Register */
|
|
||||||
#define REG_CKGR_MOR (*(volatile uint32_t *)0x400E0620U)
|
|
||||||
/** PMC Clock Failure Detector Enable bitmask */
|
|
||||||
#define REG_CKGR_MOR_CFDEN_BIT ((uint32_t)1 << 25)
|
|
||||||
/** PMC Main Oscillator Selection bitmask */
|
|
||||||
#define REG_CKGR_MOR_MOSCSEL_BIT ((uint32_t)1 << 24)
|
|
||||||
/** PMC Main Oscillator Password bitmask */
|
|
||||||
#define REG_CKGR_MOR_KEY_MASK ((uint32_t)0xFF << 16)
|
|
||||||
#define REG_CKGR_MOR_KEY_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 16) & REG_CKGR_MOR_KEY_MASK )
|
|
||||||
#define REG_CKGR_MOR_KEY_MAGIC (0x37)
|
|
||||||
/** PMC Main Crystal Oscillator Start-up Time bitmask (<< 8, 8 bits, unit: clock cycles * 8) */
|
|
||||||
#define REG_CKGR_MOR_MOSCXTST_MASK ((uint32_t)0xFF << 8)
|
|
||||||
#define REG_CKGR_MOR_MOSCXTST_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 8) & REG_CKGR_MOR_MOSCXTST_MASK )
|
|
||||||
/** PMC Main On-Chip RC Oscillator Frequency Selection bitmask (<< 4, 2 bits) */
|
|
||||||
#define REG_CKGR_MOR_MOSCRCF_MASK ((uint32_t)0b111 << 4)
|
|
||||||
#define REG_CKGR_MOR_MOSCRCF_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 4) & REG_CKGR_MOR_MOSCRCF_MASK )
|
|
||||||
/** PMC Main On-Chip RC Oscillator Enable bitmask */
|
|
||||||
#define REG_CKGR_MOR_MOSCRCEN_BIT ((uint32_t)1 << 3)
|
|
||||||
/** PMC Main Crystal Oscillator Bypass bitmask */
|
|
||||||
#define REG_CKGR_MOR_MOSCXTBY_BIT ((uint32_t)1 << 1)
|
|
||||||
/** PMC Main Crystal Oscillator Enable bitmask */
|
|
||||||
#define REG_CKGR_MOR_MOSCXTEN_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/** PMC Clock Generator Main Clock Frequency Register */
|
|
||||||
#define REG_CKGR_MCFR (*(const volatile uint32_t *)0x400E0624U)
|
|
||||||
/** PMC Main Clock Ready bitmask */
|
|
||||||
#define REG_CKGR_MCFR_MAINFRDY_BIT ((uint32_t)1 << 16)
|
|
||||||
/** PMC Main Clock Frequency bitmask (16-bit, equals amount of main clocks per 16 slow clocks) */
|
|
||||||
#define REG_CKGR_MCFR_MAINF_MASK ((uint32_t)0xFFFF)
|
|
||||||
|
|
||||||
/** PMC Clock Generator PLLA Register */
|
|
||||||
#define REG_CKGR_PLLAR (*(volatile uint32_t *)0x400E0628U)
|
|
||||||
/** PMC Clock Generator: Must be set to one when writing to CKGR_PLLAR bitmask */
|
|
||||||
#define REG_CKGR_PLLAR_ONE_BIT ((uint32_t)1 << 29)
|
|
||||||
/** PMC PLLA Multiplier bitmask (<< 16, 11 bits) */
|
|
||||||
#define REG_CKGR_PLLAR_MULA_MASK ((uint32_t)0x7FF << 16)
|
|
||||||
#define REG_CKGR_PLLAR_MULA_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 16) & REG_CKGR_PLLAR_MULA_MASK )
|
|
||||||
/** PMC PLLA Counter bitmask (<< 8, 6 bits) */
|
|
||||||
#define REG_CKGR_PLLAR_PLLACOUNT_MASK ((uint32_t)0x3F << 8)
|
|
||||||
#define REG_CKGR_PLLAR_PLLACOUNT_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 8) & REG_CKGR_PLLAR_PLLACOUNT_MASK )
|
|
||||||
/** PMC PLLA Divider bitmask (8 bits) */
|
|
||||||
#define REG_CKGR_PLLAR_DIVA_MASK ((uint32_t)0xFF)
|
|
||||||
#define REG_CKGR_PLLAR_DIVA_VAL(x) \
|
|
||||||
((uint32_t)(x) & REG_CKGR_PLLAR_DIVA_MASK)
|
|
||||||
|
|
||||||
/** PMC Master Clock Register */
|
|
||||||
#define REG_PMC_MCKR (*(volatile uint32_t *)0x400E0630U)
|
|
||||||
/** PMC Master Clock UPLL Divisor by 2 bitmask */
|
|
||||||
#define REG_PMC_MCKR_UPLLDIV2_BIT ((uint32_t)1 << 13)
|
|
||||||
/** PMC Master Clock PLLA Divisor by 2 bitmask */
|
|
||||||
#define REG_PMC_MCKR_PLLADIV2_BIT ((uint32_t)1 << 12)
|
|
||||||
/** PMC Master Clock Processor Clock Prescaler bitmask (<< 4, 3 bits) */
|
|
||||||
#define REG_PMC_MCKR_PRES_MASK ((uint32_t)0x7 << 4)
|
|
||||||
#define REG_PMC_MCKR_PRES_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 4) & REG_PMC_MCKR_PRES_MASK )
|
|
||||||
/** PMC Master Clock Source Selection bitmask (2 bits) */
|
|
||||||
#define REG_PMC_MCKR_CSS_MASK ((uint32_t)0x3)
|
|
||||||
#define REG_PMC_MCKR_CSS_VAL(x) ((uint32_t)(x) & REG_PMC_MCKR_CSS_MASK)
|
|
||||||
|
|
||||||
/** PMC USB Clock Register */
|
|
||||||
#define REG_PMC_USB (*(volatile uint32_t *)0x400E0638U)
|
|
||||||
/** PMC USB Divider for USB Clock bitmask (<< 8, 8 bits) */
|
|
||||||
#define REG_PMC_USB_USBDIV_MASK ((uint32_t)0xF << 8)
|
|
||||||
/** PMC USB Input Clock Selection bitmask */
|
|
||||||
#define REG_PMC_USB_USBS_MASK ((uint32_t)1)
|
|
||||||
|
|
||||||
/** PMC Programmable Clock Register */
|
|
||||||
#define REG_PMC_PCKx (*(volatile uint32_t *)0x400E0640U)
|
|
||||||
/** PMC Programmable Clock Prescaler bitmask (<< 4, 3 bits) */
|
|
||||||
#define REG_PMC_PCKx_PRES_MASK ((uint32_t)0x7 << 4)
|
|
||||||
#define REG_PMC_PCKx_PRES_VAL(x) \
|
|
||||||
( ((uint32_t)(x) << 4) & REG_PMC_PCKx_PRES_MASK )
|
|
||||||
/** PMC Master Clock Source Selection bitmask (3 bits) */
|
|
||||||
#define REG_PMC_PCKx_CSS_MASK ((uint32_t)0x7)
|
|
||||||
#define REG_PMC_PCKx_CSS_VAL(x) ((uint32_t)(x) & REG_PMC_PCKx_CSS_MASK)
|
|
||||||
|
|
||||||
/** PMC Interrupt Enable Register */
|
|
||||||
#define REG_PMC_IER (*(volatile uint32_t *)0x400E0660U)
|
|
||||||
/** PMC Clock Failure Detector Event Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_CFDEV_BIT ((uint32_t)1 << 18)
|
|
||||||
/** PMC Main On-Chip RC Status Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_MOSCRCS_BIT ((uint32_t)1 << 17)
|
|
||||||
/** PMC Main Oscillator Selection Status Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_MOSCSELS_BIT ((uint32_t)1 << 16)
|
|
||||||
/** PMC Programmable Clock Ready 2 Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_PCKRDY2_BIT ((uint32_t)1 << 10)
|
|
||||||
/** PMC Programmable Clock Ready 1 Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_PCKRDY1_BIT ((uint32_t)1 << 9)
|
|
||||||
/** PMC Programmable Clock Ready 0 Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_PCKRDY0_BIT ((uint32_t)1 << 8)
|
|
||||||
/** PMC UTMI PLL Lock Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_LOCKU_BIT ((uint32_t)1 << 6)
|
|
||||||
/** PMC Master Clock Ready Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_MCKRDY_BIT ((uint32_t)1 << 3)
|
|
||||||
/** PMC PLLA Lock Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_LOCKA_BIT ((uint32_t)1 << 1)
|
|
||||||
/** PMC Main Crystal Oscillator Status Interrupt Enable bitmask */
|
|
||||||
#define REG_PMC_IER_MOSCXTS_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/** PMC Interrupt Disable Register */
|
|
||||||
#define REG_PMC_IDR (*(volatile uint32_t *)0x400E0664U)
|
|
||||||
/** PMC Clock Failure Detector Event Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_CFDEV_BIT ((uint32_t)1 << 18)
|
|
||||||
/** PMC Main On-Chip RC Status Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_MOSCRCS_BIT ((uint32_t)1 << 17)
|
|
||||||
/** PMC Main Oscillator Selection Status Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_MOSCSELS_BIT ((uint32_t)1 << 16)
|
|
||||||
/** PMC Programmable Clock Ready 2 Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_PCKRDY2_BIT ((uint32_t)1 << 10)
|
|
||||||
/** PMC Programmable Clock Ready 1 Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_PCKRDY1_BIT ((uint32_t)1 << 9)
|
|
||||||
/** PMC Programmable Clock Ready 0 Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_PCKRDY0_BIT ((uint32_t)1 << 8)
|
|
||||||
/** PMC UTMI PLL Lock Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_LOCKU_BIT ((uint32_t)1 << 6)
|
|
||||||
/** PMC Master Clock Ready Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_MCKRDY_BIT ((uint32_t)1 << 3)
|
|
||||||
/** PMC PLLA Lock Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_LOCKA_BIT ((uint32_t)1 << 1)
|
|
||||||
/** PMC Main Crystal Oscillator Status Interrupt Disable bitmask */
|
|
||||||
#define REG_PMC_IDR_MOSCXTS_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/** PMC Status Register */
|
|
||||||
#define REG_PMC_SR (*(const volatile uint32_t *)0x400E0668U)
|
|
||||||
/** PMC Clock Failure Detector Event bitmask */
|
|
||||||
#define REG_PMC_SR_CFDEV_BIT ((uint32_t)1 << 18)
|
|
||||||
/** PMC Main On-Chip RC Oscillator Status bitmask */
|
|
||||||
#define REG_PMC_SR_MOSCRCS_BIT ((uint32_t)1 << 17)
|
|
||||||
/** PMC Main Oscillator Selection Status bitmask */
|
|
||||||
#define REG_PMC_SR_MOSCSELS_BIT ((uint32_t)1 << 16)
|
|
||||||
/** PMC Programmable Clock 2 Ready Status bitmask */
|
|
||||||
#define REG_PMC_SR_PCKRDY2_BIT ((uint32_t)1 << 10)
|
|
||||||
/** PMC Programmable Clock 1 Ready Status bitmask */
|
|
||||||
#define REG_PMC_SR_PCKRDY1_BIT ((uint32_t)1 << 9)
|
|
||||||
/** PMC Programmable Clock 0 Ready Status bitmask */
|
|
||||||
#define REG_PMC_SR_PCKRDY0_BIT ((uint32_t)1 << 8)
|
|
||||||
/** PMC UTMI PLL Lock Status bitmask */
|
|
||||||
#define REG_PMC_SR_LOCKU_BIT ((uint32_t)1 << 6)
|
|
||||||
/** PMC Master Clock Status bitmask */
|
|
||||||
#define REG_PMC_SR_MCKRDY_BIT ((uint32_t)1 << 3)
|
|
||||||
/** PMC PLLA Lock Status bitmask */
|
|
||||||
#define REG_PMC_SR_LOCKA_BIT ((uint32_t)1 << 1)
|
|
||||||
/** PMC Main Crystal Oscillator Status bitmask */
|
|
||||||
#define REG_PMC_SR_MOSCXTS_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/** PMC Interrupt Mask Register */
|
|
||||||
#define REG_PMC_IMR (*(const volatile uint32_t *)0x400E066CU)
|
|
||||||
/** PMC Clock Failure Detector Event Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_CFDEV_BIT ((uint32_t)1 << 18)
|
|
||||||
/** PMC Main On-Chip RC Status Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_MOSCRCS_BIT ((uint32_t)1 << 17)
|
|
||||||
/** PMC Main Oscillator Selection Status Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_MOSCSELS_BIT ((uint32_t)1 << 16)
|
|
||||||
/** PMC Programmable Clock Ready 2 Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_PCKRDY2_BIT ((uint32_t)1 << 10)
|
|
||||||
/** PMC Programmable Clock Ready 1 Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_PCKRDY1_BIT ((uint32_t)1 << 9)
|
|
||||||
/** PMC Programmable Clock Ready 0 Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_PCKRDY0_BIT ((uint32_t)1 << 8)
|
|
||||||
/** PMC UTMI PLL Lock Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_LOCKU_BIT ((uint32_t)1 << 6)
|
|
||||||
/** PMC Master Clock Ready Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_MCKRDY_BIT ((uint32_t)1 << 3)
|
|
||||||
/** PMC PLLA Lock Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_LOCKA_BIT ((uint32_t)1 << 1)
|
|
||||||
/** PMC Main Crystal Oscillator Status Interrupt Mask bitmask */
|
|
||||||
#define REG_PMC_IMR_MOSCXTS_BIT ((uint32_t)1)
|
|
||||||
|
|
||||||
/* TODO */
|
|
||||||
|
|
||||||
/** PMC Write Protect Mode Register */
|
|
||||||
#define REG_PMC_WPMR (*(volatile uint32_t *)0x400E06E4U)
|
|
||||||
#define REG_PMC_WPMR_WPKEY_MAGIC (0x504D43 << 8) /* "PMC" in ASCII */
|
|
||||||
#define REG_PMC_WPMR_WPEN_VAL(x) ((uint32_t)(x) | REG_PMC_WPMR_WPKEY_MAGIC)
|
|
||||||
|
|
||||||
/** PMC Write Protect Status Register */
|
|
||||||
#define REG_PMC_WPSR (*(volatile uint32_t *)0x400E06E8U)
|
|
||||||
/** PMC Write Protect Violation Status bitmask */
|
|
||||||
#define REG_PMC_WPSR_WPVSRC_MASK ((uint32_t)0xFFFF << 8)
|
|
||||||
/** PMC Write Protect Violation Status bitmask (<< 8, 16 bits) */
|
|
||||||
#define REG_PMC_WPSR_WPVS_MASK ((uint32_t)1)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This file is part of Ardix.
|
* This file is part of Ardix.
|
||||||
|
|
|
@ -1,50 +0,0 @@
|
||||||
/* See the end of this file for copyright, license, and warranty information. */
|
|
||||||
|
|
||||||
#include <arch/hardware.h>
|
|
||||||
#include <arch/interrupt.h>
|
|
||||||
|
|
||||||
void arch_irq_enable(enum irqno irqno)
|
|
||||||
{
|
|
||||||
if (irqno >= 0)
|
|
||||||
REG_NVIC_ISER((uint32_t)irqno >> 5) = 1 << ( ((uint32_t)irqno) & 0x1F );
|
|
||||||
}
|
|
||||||
|
|
||||||
void arch_irq_disable(enum irqno irqno)
|
|
||||||
{
|
|
||||||
if (irqno >= 0)
|
|
||||||
REG_NVIC_ICER((uint32_t)irqno >> 5) = 1 << ( ((uint32_t)irqno) & 0x1F );
|
|
||||||
}
|
|
||||||
|
|
||||||
void arch_irq_invoke(enum irqno irqno)
|
|
||||||
{
|
|
||||||
if (irqno < 0) {
|
|
||||||
switch (irqno) {
|
|
||||||
case IRQNO_PEND_SV:
|
|
||||||
REG_SCB_ICSR = REG_SCB_ICSR_PENDSVSET_BIT;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case IRQNO_SYS_TICK:
|
|
||||||
REG_SCB_ICSR = REG_SCB_ICSR_PENDSTSET_BIT;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
/* TODO: Implement the rest of interrupts < 0 */
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
REG_NVIC_ISPR((uint32_t)irqno >> 5) = 1 << ( ((uint32_t)irqno) & 0x1F );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* This file is part of Ardix.
|
|
||||||
* Copyright (c) 2020, 2021 Felix Kopp <owo@fef.moe>.
|
|
||||||
*
|
|
||||||
* Ardix is non-violent software: you may only use, redistribute,
|
|
||||||
* and/or modify it under the terms of the CNPLv6+ as found in
|
|
||||||
* the LICENSE file in the source code root directory or at
|
|
||||||
* <https://git.pixie.town/thufie/CNPL>.
|
|
||||||
*
|
|
||||||
* Ardix comes with ABSOLUTELY NO WARRANTY, to the extent
|
|
||||||
* permitted by applicable law. See the CNPLv6+ for details.
|
|
||||||
*/
|
|
|
@ -33,34 +33,32 @@ int arch_serial_init(struct serial_device *dev)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
/* enable peripheral clock for UART (which has peripheral id 8) */
|
/* enable peripheral clock for UART (which has peripheral id 8) */
|
||||||
REG_PMC_PCER0 |= REG_PMC_PCER0_PID(8);
|
PMC->PMC_PCER0 |= PMC_PCER0_PID8;
|
||||||
|
|
||||||
/* ensure the PIO controller is turned off on the serial pins */
|
/* ensure the PIO controller is turned off on the serial pins */
|
||||||
REG_PIO_PDR(PIOA) = (1 << 8) | (1 << 9);
|
PIOA->PIO_PDR = PIO_PDR_P8 | PIO_PDR_P9;
|
||||||
|
|
||||||
/* configure peripheral DMA controller */
|
/* configure peripheral DMA controller */
|
||||||
REG_UART_PDC_PTCR = REG_UART_PDC_PTCR_RXTDIS_MASK | REG_UART_PDC_PTCR_TXTEN_MASK;
|
UART->UART_PTCR = UART_PTCR_RXTDIS | UART_PTCR_TXTEN;
|
||||||
|
|
||||||
/* reset & disable rx and tx */
|
/* reset & disable rx and tx */
|
||||||
REG_UART_CR = REG_UART_CR_RXDIS_MASK | REG_UART_CR_RSTRX_MASK
|
UART->UART_CR = UART_CR_RXDIS | UART_CR_RSTRX
|
||||||
| REG_UART_CR_TXDIS_MASK | REG_UART_CR_RSTTX_MASK;
|
| UART_CR_TXDIS | UART_CR_RSTTX;
|
||||||
|
|
||||||
/* no parity, normal mode */
|
/* no parity, normal mode */
|
||||||
REG_UART_MR = REG_UART_MR_PAR_NO | REG_UART_MR_CHMODE_NORMAL;
|
UART->UART_MR = UART_MR_PAR_NO | UART_MR_CHMODE_NORMAL;
|
||||||
|
|
||||||
/* From Atmel Datasheet: baud rate = MCK / (REG_UART_BRGR * 16) */
|
/* From Atmel Datasheet: baud rate = MCK / (REG_UART_BRGR * 16) */
|
||||||
REG_UART_BRGR = (uint16_t)(( sys_core_clock / (uint32_t)dev->baud ) >> 4);
|
UART->UART_BRGR = UART_BRGR_CD(( SystemCoreClock / (uint32_t)dev->baud ) >> 4);
|
||||||
|
|
||||||
/* choose the events we want an interrupt on */
|
/* choose the events we want an interrupt on */
|
||||||
REG_UART_IDR = 0xFFFFFFFF; /* make sure all interrupts are disabled first */
|
UART->UART_IDR = 0xffffffff; /* make sure all interrupts are disabled first */
|
||||||
REG_UART_IER = REG_UART_IER_RXRDY_MASK
|
UART->UART_IER = UART_IER_RXRDY | UART_IER_OVRE | UART_IER_FRAME;
|
||||||
| REG_UART_IER_OVRE_MASK
|
|
||||||
| REG_UART_IER_FRAME_MASK;
|
|
||||||
|
|
||||||
arch_irq_enable(IRQNO_UART);
|
NVIC_EnableIRQ(UART_IRQn);
|
||||||
|
|
||||||
/* enable receiver and transmitter */
|
/* enable receiver and transmitter */
|
||||||
REG_UART_CR = REG_UART_CR_RXEN_MASK | REG_UART_CR_TXEN_MASK;
|
UART->UART_CR = UART_CR_RXEN | UART_CR_TXEN;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -71,12 +69,12 @@ void arch_serial_exit(struct serial_device *dev)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* disable receiver and transmitter */
|
/* disable receiver and transmitter */
|
||||||
REG_UART_CR = REG_UART_CR_RXDIS_MASK | REG_UART_CR_TXDIS_MASK;
|
UART->UART_CR = UART_CR_RXDIS | UART_CR_TXDIS;
|
||||||
|
|
||||||
arch_irq_disable(IRQNO_UART);
|
NVIC_DisableIRQ(UART_IRQn);
|
||||||
|
|
||||||
/* disable peripheral clock for UART (PID is taken from Atmel Datasheet, Section 9.1 */
|
/* disable peripheral clock for UART (PID is taken from Atmel Datasheet, Section 9.1 */
|
||||||
REG_PMC_PCDR0 = REG_PMC_PCDR0_PID(8);
|
PMC->PMC_PCDR0 = PMC_PCDR0_PID8;
|
||||||
|
|
||||||
dev->id = -1;
|
dev->id = -1;
|
||||||
}
|
}
|
||||||
|
@ -111,14 +109,14 @@ ssize_t serial_write_dma(struct serial_device *dev, struct dmabuf *buf)
|
||||||
|
|
||||||
if (arch_dev->tx_current == NULL) {
|
if (arch_dev->tx_current == NULL) {
|
||||||
arch_dev->tx_current = buf;
|
arch_dev->tx_current = buf;
|
||||||
REG_UART_PDC_TPR = (uint32_t)buf->data;
|
UART->UART_TPR = (uint32_t)buf->data;
|
||||||
REG_UART_PDC_TCR = len;
|
UART->UART_TCR = len;
|
||||||
/* we weren't transmitting, so the interrupt was masked */
|
/* we weren't transmitting, so the interrupt was masked */
|
||||||
REG_UART_IER = REG_UART_IER_ENDTX_MASK;
|
UART->UART_IER = UART_IER_ENDTX;
|
||||||
} else {
|
} else {
|
||||||
arch_dev->tx_next = buf;
|
arch_dev->tx_next = buf;
|
||||||
REG_UART_PDC_TNPR = (uint32_t)buf->data;
|
UART->UART_TNPR = (uint32_t)buf->data;
|
||||||
REG_UART_PDC_TNCR = len;
|
UART->UART_TNCR = len;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (ssize_t)len;
|
return (ssize_t)len;
|
||||||
|
@ -127,11 +125,11 @@ ssize_t serial_write_dma(struct serial_device *dev, struct dmabuf *buf)
|
||||||
void irq_uart(void)
|
void irq_uart(void)
|
||||||
{
|
{
|
||||||
uint8_t tmp;
|
uint8_t tmp;
|
||||||
uint32_t state = REG_UART_SR;
|
uint32_t state = UART->UART_SR;
|
||||||
|
|
||||||
/* RX has received a byte, store it into the ring buffer */
|
/* RX has received a byte, store it into the ring buffer */
|
||||||
if (state & REG_UART_SR_RXRDY_MASK) {
|
if (state & UART_SR_RXRDY) {
|
||||||
tmp = REG_UART_RHR;
|
tmp = (uint8_t)UART->UART_RHR;
|
||||||
ringbuf_write(arch_serial_default_device.device.rx, &tmp, sizeof(tmp));
|
ringbuf_write(arch_serial_default_device.device.rx, &tmp, sizeof(tmp));
|
||||||
|
|
||||||
device_kevent_create_and_dispatch(&serial_default_device->device,
|
device_kevent_create_and_dispatch(&serial_default_device->device,
|
||||||
|
@ -139,7 +137,7 @@ void irq_uart(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* REG_UART_PDC_TCR has reached zero */
|
/* REG_UART_PDC_TCR has reached zero */
|
||||||
if (state & REG_UART_SR_ENDTX_MASK) {
|
if (state & UART_SR_ENDTX) {
|
||||||
if (arch_serial_default_device.tx_current != NULL)
|
if (arch_serial_default_device.tx_current != NULL)
|
||||||
dmabuf_put(arch_serial_default_device.tx_current);
|
dmabuf_put(arch_serial_default_device.tx_current);
|
||||||
|
|
||||||
|
@ -148,16 +146,16 @@ void irq_uart(void)
|
||||||
arch_serial_default_device.tx_next = NULL;
|
arch_serial_default_device.tx_next = NULL;
|
||||||
|
|
||||||
if (arch_serial_default_device.tx_current == NULL)
|
if (arch_serial_default_device.tx_current == NULL)
|
||||||
REG_UART_IDR = REG_UART_IDR_ENDTX_MASK;
|
UART->UART_IDR = UART_IDR_ENDTX;
|
||||||
|
|
||||||
device_kevent_create_and_dispatch(&serial_default_device->device,
|
device_kevent_create_and_dispatch(&serial_default_device->device,
|
||||||
DEVICE_CHANNEL_OUT);
|
DEVICE_CHANNEL_OUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check for error conditions */
|
/* check for error conditions */
|
||||||
if ((state & REG_UART_SR_OVRE_MASK) || (state & REG_UART_SR_FRAME_MASK)) {
|
if ((state & UART_SR_OVRE) || (state & UART_SR_FRAME)) {
|
||||||
/* TODO: write some proper error handling routines ffs */
|
/* TODO: write some proper error handling routines ffs */
|
||||||
REG_UART_CR = REG_UART_CR_RSTSTA_MASK;
|
UART->UART_CR = UART_CR_RSTSTA;
|
||||||
}
|
}
|
||||||
|
|
||||||
__clrex();
|
__clrex();
|
||||||
|
|
|
@ -9,6 +9,16 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <toolchain.h>
|
#include <toolchain.h>
|
||||||
|
|
||||||
|
#define SYS_BOARD_OSCOUNT (CKGR_MOR_MOSCXTST(0x8))
|
||||||
|
#define SYS_BOARD_MCKR (PMC_MCKR_PRES_CLK_2 | PMC_MCKR_CSS_PLLA_CLK)
|
||||||
|
|
||||||
|
#define SYS_BOARD_PLLAR ( \
|
||||||
|
CKGR_PLLAR_ONE \
|
||||||
|
| CKGR_PLLAR_MULA(0xdUL) \
|
||||||
|
| CKGR_PLLAR_PLLACOUNT(0x3fUL) \
|
||||||
|
| CKGR_PLLAR_DIVA(0x1UL) \
|
||||||
|
)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The initial sys_core_clock on system boot would actually be 4000000 because
|
* The initial sys_core_clock on system boot would actually be 4000000 because
|
||||||
* the 4 MHz RC oscillator is used by default. However, for performance
|
* the 4 MHz RC oscillator is used by default. However, for performance
|
||||||
|
@ -18,7 +28,7 @@
|
||||||
* So, since we trust the clock to be configured correctly before this global
|
* So, since we trust the clock to be configured correctly before this global
|
||||||
* variable is accessed anywhere, we initialize it to the 84 MHz clock.
|
* variable is accessed anywhere, we initialize it to the 84 MHz clock.
|
||||||
*/
|
*/
|
||||||
uint32_t sys_core_clock = 84000000UL;
|
uint32_t SystemCoreClock = 84000000UL;
|
||||||
|
|
||||||
void sys_init(void)
|
void sys_init(void)
|
||||||
{
|
{
|
||||||
|
@ -28,33 +38,29 @@ void sys_init(void)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* # of wait states as per hardware spec (stolen from SAM SysInit) */
|
/* # of wait states as per hardware spec (stolen from SAM SysInit) */
|
||||||
REG_EEFC0_FMR = REG_EEFC_FWS_VAL(4);
|
EFC0->EEFC_FMR = EEFC_FMR_FWS(4);
|
||||||
REG_EEFC1_FMR = REG_EEFC_FWS_VAL(4);
|
EFC1->EEFC_FMR = EEFC_FMR_FWS(4);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 1. Enabling the Main Oscillator
|
* 1. Enabling the Main Oscillator
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* initialize main osc */
|
/* initialize main osc */
|
||||||
if (!(REG_CKGR_MOR & REG_CKGR_MOR_MOSCSEL_BIT)) {
|
if (!(PMC->CKGR_MOR & CKGR_MOR_MOSCSEL)) {
|
||||||
REG_CKGR_MOR = REG_CKGR_MOR_KEY_VAL(REG_CKGR_MOR_KEY_MAGIC)
|
PMC->CKGR_MOR = CKGR_MOR_KEY_PASSWD
|
||||||
| REG_CKGR_MOR_MOSCXTST_VAL(8)
|
| SYS_BOARD_OSCOUNT
|
||||||
| REG_CKGR_MOR_MOSCRCEN_BIT
|
| CKGR_MOR_MOSCRCEN
|
||||||
| REG_CKGR_MOR_MOSCXTEN_BIT;
|
| CKGR_MOR_MOSCXTEN;
|
||||||
mom_are_we_there_yet(REG_PMC_SR & REG_PMC_SR_MOSCXTS_BIT);
|
mom_are_we_there_yet(PMC->PMC_SR & PMC_SR_MOSCXTS);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* switch to Xtal osc */
|
/* Switch to 3-20MHz Xtal oscillator */
|
||||||
REG_CKGR_MOR = REG_CKGR_MOR_KEY_VAL(REG_CKGR_MOR_KEY_MAGIC)
|
PMC->CKGR_MOR = CKGR_MOR_KEY_PASSWD
|
||||||
| REG_CKGR_MOR_MOSCXTST_VAL(8)
|
| SYS_BOARD_OSCOUNT
|
||||||
| REG_CKGR_MOR_MOSCRCEN_BIT
|
| CKGR_MOR_MOSCRCEN
|
||||||
| REG_CKGR_MOR_MOSCXTEN_BIT
|
| CKGR_MOR_MOSCXTEN
|
||||||
| REG_CKGR_MOR_MOSCSEL_BIT;
|
| CKGR_MOR_MOSCSEL;
|
||||||
mom_are_we_there_yet(REG_PMC_SR & REG_PMC_SR_MOSCSELS_BIT);
|
mom_are_we_there_yet(PMC->PMC_SR & PMC_SR_MOSCSELS);
|
||||||
|
|
||||||
REG_PMC_MCKR = (REG_PMC_MCKR & ~REG_PMC_MCKR_CSS_MASK)
|
|
||||||
| REG_PMC_MCKR_CSS_VAL(1 /* = main clock */);
|
|
||||||
mom_are_we_there_yet(REG_PMC_SR & REG_PMC_SR_MCKRDY_BIT);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 2. Checking the Main Oscillator Frequency (Optional)
|
* 2. Checking the Main Oscillator Frequency (Optional)
|
||||||
|
@ -66,24 +72,24 @@ void sys_init(void)
|
||||||
* 3. Setting PLL and Divider
|
* 3. Setting PLL and Divider
|
||||||
*/
|
*/
|
||||||
|
|
||||||
REG_CKGR_PLLAR = REG_CKGR_PLLAR_ONE_BIT
|
PMC->PMC_MCKR = (PMC->PMC_MCKR & ~(uint32_t)PMC_MCKR_CSS_Msk) | PMC_MCKR_CSS_MAIN_CLK;
|
||||||
| REG_CKGR_PLLAR_MULA_VAL(0xD)
|
mom_are_we_there_yet(PMC->PMC_SR & PMC_SR_MCKRDY);
|
||||||
| REG_CKGR_PLLAR_PLLACOUNT_VAL(0x3F /* maximum value */)
|
|
||||||
| REG_CKGR_PLLAR_DIVA_VAL(0x1);
|
|
||||||
mom_are_we_there_yet(REG_PMC_SR & REG_PMC_SR_LOCKA_BIT);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 4. Selection of Master Clock and Processor Clock
|
* 4. Selection of Master Clock and Processor Clock
|
||||||
*/
|
*/
|
||||||
|
|
||||||
REG_PMC_MCKR = REG_PMC_MCKR_PRES_VAL(1 /* = as fast as it gets */)
|
/* Initialize PLLA */
|
||||||
| REG_PMC_MCKR_CSS_VAL(1 /* = main clock */);
|
PMC->CKGR_PLLAR = SYS_BOARD_PLLAR;
|
||||||
mom_are_we_there_yet(REG_PMC_SR & REG_PMC_SR_MCKRDY_BIT);
|
mom_are_we_there_yet(PMC->PMC_SR & PMC_SR_LOCKA);
|
||||||
|
|
||||||
/* PMC_MCKR must not be configured within one clock cycle */
|
/* Switch to MCK */
|
||||||
REG_PMC_MCKR = REG_PMC_MCKR_PRES_VAL(1 /* = as fast as it gets */)
|
PMC->PMC_MCKR = (SYS_BOARD_MCKR & ~PMC_MCKR_CSS_Msk) | PMC_MCKR_CSS_MAIN_CLK;
|
||||||
| REG_PMC_MCKR_CSS_VAL(2 /* = PLLA clock */);
|
mom_are_we_there_yet(PMC->PMC_SR & PMC_SR_MCKRDY);
|
||||||
mom_are_we_there_yet(REG_PMC_SR & REG_PMC_SR_MCKRDY_BIT);
|
|
||||||
|
/* Switch to PLLA */
|
||||||
|
PMC->PMC_MCKR = SYS_BOARD_MCKR;
|
||||||
|
mom_are_we_there_yet(PMC->PMC_SR & PMC_SR_MCKRDY);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -97,4 +103,30 @@ void sys_init(void)
|
||||||
*
|
*
|
||||||
* Ardix comes with ABSOLUTELY NO WARRANTY, to the extent
|
* Ardix comes with ABSOLUTELY NO WARRANTY, to the extent
|
||||||
* permitted by applicable law. See the CNPLv6+ for details.
|
* permitted by applicable law. See the CNPLv6+ for details.
|
||||||
|
*
|
||||||
|
* ===========================================================================
|
||||||
|
*
|
||||||
|
* Parts of this file are derived from the Atmel SAM Software Package.
|
||||||
|
* Copyright (c) 2015, Atmel Corporation
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following condition is met:
|
||||||
|
*
|
||||||
|
* - Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the disclaimer below.
|
||||||
|
*
|
||||||
|
* Atmel's name may not be used to endorse or promote products derived from
|
||||||
|
* this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR
|
||||||
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||||
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
|
||||||
|
* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||||
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE
|
||||||
|
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
int arch_watchdog_init(void)
|
int arch_watchdog_init(void)
|
||||||
{
|
{
|
||||||
/* we don't use the watchdog at all for now */
|
/* we don't use the watchdog at all for now */
|
||||||
REG_WDT_MR = REG_WDT_MR_WDDIS_BIT;
|
WDT->WDT_MR = WDT_MR_WDDIS;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
1
contrib/arduino-cmsis
Submodule
1
contrib/arduino-cmsis
Submodule
|
@ -0,0 +1 @@
|
||||||
|
Subproject commit 46ab1021146152a64caf1ddbb837d8181b8faa35
|
1
contrib/cmsis
Submodule
1
contrib/cmsis
Submodule
|
@ -0,0 +1 @@
|
||||||
|
Subproject commit 13b9f72f212688d2306d0d085d87cbb4bf9e5d3f
|
|
@ -13,7 +13,7 @@ struct task; /* see include/ardix/sched.h */
|
||||||
*
|
*
|
||||||
* @param freq: The timer frequency in Hertz.
|
* @param freq: The timer frequency in Hertz.
|
||||||
*/
|
*/
|
||||||
int arch_sched_hwtimer_init(unsigned int freq);
|
int arch_sched_init(unsigned int freq);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialize a new process.
|
* Initialize a new process.
|
||||||
|
|
|
@ -57,7 +57,7 @@ int sched_init(void)
|
||||||
if (i != 0)
|
if (i != 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
i = arch_sched_hwtimer_init(CONFIG_SCHED_FREQ);
|
i = arch_sched_init(CONFIG_SCHED_FREQ);
|
||||||
if (i != 0)
|
if (i != 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue