diff options
author | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2010-03-31 15:13:55 +0000 |
---|---|---|
committer | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2010-03-31 15:13:55 +0000 |
commit | 4bc04c7835daccf943dbe299a7f79f9c33e16032 (patch) | |
tree | 2c4b7bf8166b8553e4e6526d280a50183c72fcf5 /os/ports | |
parent | 77ae91f021782bad36ba0106d65b2e2eb1249a21 (diff) | |
download | ChibiOS-4bc04c7835daccf943dbe299a7f79f9c33e16032.tar.gz ChibiOS-4bc04c7835daccf943dbe299a7f79f9c33e16032.tar.bz2 ChibiOS-4bc04c7835daccf943dbe299a7f79f9c33e16032.zip |
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@1820 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'os/ports')
-rw-r--r-- | os/ports/GCC/ARMCM3/port.dox | 1 | ||||
-rw-r--r-- | os/ports/GCC/ARMCMx/chcore.c | 25 | ||||
-rw-r--r-- | os/ports/GCC/ARMCMx/chcore.h | 109 | ||||
-rw-r--r-- | os/ports/GCC/ARMCMx/chtypes.h | 7 | ||||
-rw-r--r-- | os/ports/GCC/ARMCMx/crt0.s | 4 | ||||
-rw-r--r-- | os/ports/GCC/ARMCMx/nvic.c | 12 | ||||
-rw-r--r-- | os/ports/GCC/ARMCMx/nvic.h | 23 | ||||
-rw-r--r-- | os/ports/GCC/ARMCMx/port.dox | 94 |
8 files changed, 200 insertions, 75 deletions
diff --git a/os/ports/GCC/ARMCM3/port.dox b/os/ports/GCC/ARMCM3/port.dox index fd18ae82d..caaabf24c 100644 --- a/os/ports/GCC/ARMCM3/port.dox +++ b/os/ports/GCC/ARMCM3/port.dox @@ -158,7 +158,6 @@ * - @p _bss_end BSS end location +1.
* .
* @ingroup ARMCM3
- * @file ARMCM3/crt0.s Startup code.
*/
/**
diff --git a/os/ports/GCC/ARMCMx/chcore.c b/os/ports/GCC/ARMCMx/chcore.c index 348aedef7..78ed6d7ad 100644 --- a/os/ports/GCC/ARMCMx/chcore.c +++ b/os/ports/GCC/ARMCMx/chcore.c @@ -19,7 +19,7 @@ /**
* @file ARMCMx/chcore.c
- * @brief ARM Cortex-Mx architecture port code.
+ * @brief ARM Cortex-Mx port code.
*
* @addtogroup ARMCMx_CORE
* @{
@@ -165,14 +165,21 @@ void _port_switch_from_irq(void) { __attribute__((naked))
#endif
void port_switch(Thread *ntp, Thread *otp) {
- register struct intctx *sp_thd asm ("sp");
+ register struct intctx *r13 asm ("r13");
- PUSH_CONTEXT(sp_thd);
+ /* Stack overflow check, if enabled.*/
+#if CH_DBG_ENABLE_STACK_CHECK
+ if ((void *)(r13 - 1) < (void *)(otp + 1))
+ asm volatile ("movs r0, #0 \n\t"
+ "b chDbgPanic");
+#endif /* CH_DBG_ENABLE_STACK_CHECK */
- otp->p_ctx.r13 = sp_thd;
- sp_thd = ntp->p_ctx.r13;
+ PUSH_CONTEXT(r13);
- POP_CONTEXT(sp_thd);
+ otp->p_ctx.r13 = r13;
+ r13 = ntp->p_ctx.r13;
+
+ POP_CONTEXT(r13);
}
/**
@@ -182,9 +189,9 @@ void port_switch(Thread *ntp, Thread *otp) { */
void _port_thread_start(void) {
- asm volatile ("cpsie i \n\t" \
- "mov r0, r5 \n\t" \
- "blx r4 \n\t" \
+ asm volatile ("cpsie i \n\t" \
+ "mov r0, r5 \n\t" \
+ "blx r4 \n\t" \
"bl chThdExit");
}
diff --git a/os/ports/GCC/ARMCMx/chcore.h b/os/ports/GCC/ARMCMx/chcore.h index 57183e162..dd7d2897b 100644 --- a/os/ports/GCC/ARMCMx/chcore.h +++ b/os/ports/GCC/ARMCMx/chcore.h @@ -19,7 +19,7 @@ /**
* @file ARMCMx/chcore.h
- * @brief ARM Cortex-Mx architecture port macros and structures.
+ * @brief ARM Cortex-Mx port macros and structures.
*
* @addtogroup ARMCMx_CORE
* @{
@@ -49,14 +49,16 @@ /* Inclusion of the Cortex-Mx implementation specific parameters.*/
#include "cmparams.h"
-/* Cortex model check, only M0 and M3 right now.*/
+/* Cortex model check, only M0 and M3 supported right now.*/
#if (CORTEX_MODEL == CORTEX_M0) || (CORTEX_MODEL == CORTEX_M3)
+#elif (CORTEX_MODEL == CORTEX_M1) || (CORTEX_MODEL == CORTEX_M4)
+#warning "untested Cortex-M model"
#else
#error "unknown or unsupported Cortex-M model"
#endif
/*===========================================================================*/
-/* Port derived parameters. */
+/* Port statically derived parameters. */
/*===========================================================================*/
/**
@@ -114,8 +116,8 @@ /**
* @brief SYSTICK handler priority.
- * @note The default is calculated as the priority level in the middle
- * of the priority range.
+ * @note The default priority is calculated as the priority level in
+ * the middle of the numeric priorities range.
*/
#ifndef CORTEX_PRIORITY_SYSTICK
#define CORTEX_PRIORITY_SYSTICK (CORTEX_PRIORITY_LEVELS >> 1)
@@ -126,13 +128,67 @@ #endif
#endif
+/**
+ * @brief Priority masking support.
+ * @details The ARMv7-M architecture is capable to mask only interrupt
+ * priorities below or equal to a certain specified priority
+ * mask. If this option is enabled all the priorities above
+ * @p CORTEX_BASEPRI_KERNEL (lower numeric values) are not
+ * affected by the kernel locks and can operate with minimum
+ * latency.<br>
+ * This option makes the kernel code a bit larger and slower, if
+ * your application does not need fast interrups it is recommended
+ * to keep this option disabled.
+ */
+#if CORTEX_SUPPORTS_BASEPRI || defined(__DOXYGEN__)
+#if !defined(CORTEX_USE_BASEPRI) || defined(__DOXYGEN__)
+#define CORTEX_USE_BASEPRI FALSE
+#endif /* !defined(CORTEX_USE_BASEPRI) */
+#else /* !CORTEX_SUPPORTS_BASEPRI */
+#if defined(CORTEX_USE_BASEPRI) && CORTEX_USE_BASEPRI
+#error "BASEPRI priority masking register not supported in this architecture"
+#endif
+#define CORTEX_USE_BASEPRI FALSE
+#endif /* !CORTEX_SUPPORTS_BASEPRI */
+
+#if CORTEX_USE_BASEPRI || defined(__DOXYGEN__)
+/**
+ * @brief BASEPRI user level.
+ * @note This constant is defined only if the @p CORTEX_USE_BASEPRI port
+ * option is enabled.
+ */
+#ifndef CORTEX_BASEPRI_USER
+#define CORTEX_BASEPRI_USER CORTEX_PRIORITY_MASK(0)
+#endif
+
+/**
+ * @brief BASEPRI level within kernel lock.
+ * @details Priority levels higher than this one (lower numeric values) are
+ * unaffected by kernel locks and can be classified as fast
+ * interrupt sources, see @ref interrupt_classes.
+ * @note This constant is defined only if the @p CORTEX_USE_BASEPRI port
+ * option is enabled.
+ * @note The default setting reserves just the highest priority level
+ * (@p CORTEX_MAXIMUM_PRIORITY) for fast interrupts, you may redefine
+ * this setting in order to reserve more levels.
+ */
+#ifndef CORTEX_BASEPRI_KERNEL
+#define CORTEX_BASEPRI_KERNEL CORTEX_PRIORITY_MASK(CORTEX_MAXIMUM_PRIORITY+1)
+#endif
+#endif /* CORTEX_USE_BASEPRI */
+
/*===========================================================================*/
/* Port exported info. */
/*===========================================================================*/
+/**
+ * @brief Macro defining a generic ARM architecture.
+ */
+#define CH_ARCHITECTURE_ARM
+
#if defined(__DOXYGEN__)
/**
- * @brief Macro defining the ARM architecture.
+ * @brief Macro defining the specific ARM architecture.
*/
#define CH_ARCHITECTURE_ARM_vxm
@@ -147,7 +203,7 @@ #define CH_CORE_VARIANT_NAME "Cortex-Mx"
#elif CORTEX_MODEL == CORTEX_M4
#define CH_ARCHITECTURE_ARM_v7M
-#define CH_ARCHITECTURE_NAME "ARMv7-M"
+#define CH_ARCHITECTURE_NAME "ARMv7-ME"
#define CH_CORE_VARIANT_NAME "Cortex-M4"
#elif CORTEX_MODEL == CORTEX_M3
#define CH_ARCHITECTURE_ARM_v7M
@@ -364,17 +420,29 @@ struct context { * @brief Kernel-lock action.
* @details Usually this function just disables interrupts but may perform
* more actions.
- * @note In this port it disables all the interrupt sources.
*/
+#if CORTEX_USE_BASEPRI
+#define port_lock() { \
+ register uint32_t tmp asm ("r3") = CORTEX_BASEPRI_KERNEL; \
+ asm volatile ("msr BASEPRI, %0" : : "r" (tmp)); \
+}
+#else /* !CORTEX_USE_BASEPRI */
#define port_lock() asm volatile ("cpsid i")
+#endif /* !CORTEX_USE_BASEPRI */
/**
* @brief Kernel-unlock action.
* @details Usually this function just disables interrupts but may perform
* more actions.
- * @note In this port it enables all the interrupt sources.
*/
+#if CORTEX_USE_BASEPRI
+#define port_unlock() { \
+ register uint32_t tmp asm ("r3") = CORTEX_BASEPRI_USER; \
+ asm volatile ("msr BASEPRI, %0" : : "r" (tmp)); \
+}
+#else /* !CORTEX_USE_BASEPRI */
#define port_unlock() asm volatile ("cpsie i")
+#endif /* !CORTEX_USE_BASEPRI */
/**
* @brief Kernel-lock action from an interrupt handler.
@@ -390,29 +458,40 @@ struct context { * @details This function is invoked after invoking I-class APIs from interrupt
* handlers. The implementation is architecture dependent, in its
* simplest form it is void.
- * @note Same as @p port_unlock() in this port.
+ * @note Same as @p port_lock() in this port.
*/
#define port_unlock_from_isr() port_unlock()
/**
* @brief Disables all the interrupt sources.
- * @note Of course non maskable interrupt sources are not included.
- * @note In this port it disables all the interrupt sources.
*/
#define port_disable() asm volatile ("cpsid i")
/**
* @brief Disables the interrupt sources below kernel-level priority.
- * @note Interrupt sources above kernel level remains enabled.
- * @note In this port it disables all the interrupt sources.
*/
+#if CORTEX_USE_BASEPRI
+#define port_suspend() { \
+ register uint32_t tmp asm ("r3") = CORTEX_BASEPRI_KERNEL; \
+ asm volatile ("msr BASEPRI, %0 \n\t" \
+ "cpsie i" : : "r" (tmp)); \
+}
+#else /* !CORTEX_USE_BASEPRI */
#define port_suspend() asm volatile ("cpsid i")
+#endif /* !CORTEX_USE_BASEPRI */
/**
* @brief Enables all the interrupt sources.
- * @note In this port it enables all the interrupt sources.
*/
+#if CORTEX_USE_BASEPRI
+#define port_enable() { \
+ register uint32_t tmp asm ("r3") = CORTEX_BASEPRI_USER; \
+ asm volatile ("msr BASEPRI, %0 \n\t" \
+ "cpsie i" : : "r" (tmp)); \
+}
+#else /* !CORTEX_USE_BASEPRI */
#define port_enable() asm volatile ("cpsie i")
+#endif /* !CORTEX_USE_BASEPRI */
/**
* @brief Enters an architecture-dependent IRQ-waiting mode.
diff --git a/os/ports/GCC/ARMCMx/chtypes.h b/os/ports/GCC/ARMCMx/chtypes.h index be89b04bf..ef35d6324 100644 --- a/os/ports/GCC/ARMCMx/chtypes.h +++ b/os/ports/GCC/ARMCMx/chtypes.h @@ -18,8 +18,9 @@ */
/**
- * @file ARMCMx/chtypes.h
- * @brief ARM Cortex-M3 architecture port system types.
+ * @file ARMCMx/chtypes.h
+ * @brief ARM Cortex-Mx port system types.
+ *
* @addtogroup ARMCMx_CORE
* @{
*/
@@ -32,9 +33,7 @@ #define __need_ptrdiff_t
#include <stddef.h>
-#if !defined(_STDINT_H) && !defined(__STDINT_H_)
#include <stdint.h>
-#endif
typedef int32_t bool_t; /**< Fast boolean type. */
typedef uint8_t tmode_t; /**< Thread flags. */
diff --git a/os/ports/GCC/ARMCMx/crt0.s b/os/ports/GCC/ARMCMx/crt0.s index 15aed34a6..51739aa62 100644 --- a/os/ports/GCC/ARMCMx/crt0.s +++ b/os/ports/GCC/ARMCMx/crt0.s @@ -73,7 +73,7 @@ ResetHandler: ldr r3, =_edata
dloop:
cmp r2, r3
-#if CORTEX_MODEL == CORTEX_M0
+#if (CORTEX_MODEL == CORTEX_M0) || (CORTEX_MODEL == CORTEX_M1)
bge enddloop
ldr r0, [r1]
str r0, [r2]
@@ -96,7 +96,7 @@ enddloop: ldr r2, =_bss_end
bloop:
cmp r1, r2
-#if CORTEX_MODEL == CORTEX_M0
+#if (CORTEX_MODEL == CORTEX_M0) || (CORTEX_MODEL == CORTEX_M1)
bge endbloop
str r0, [r1]
adds r1, r1, #4
diff --git a/os/ports/GCC/ARMCMx/nvic.c b/os/ports/GCC/ARMCMx/nvic.c index 67551ec1d..5b0dd9782 100644 --- a/os/ports/GCC/ARMCMx/nvic.c +++ b/os/ports/GCC/ARMCMx/nvic.c @@ -18,8 +18,9 @@ */
/**
- * @file ARMCMx/nvic.c
- * @brief Cortex-Mx NVIC support code.
+ * @file ARMCMx/nvic.c
+ * @brief Cortex-Mx NVIC support code.
+ *
* @addtogroup ARMCMx_NVIC
* @{
*/
@@ -31,7 +32,7 @@ * @brief Sets the priority of an interrupt handler and enables it.
*
* @param n the interrupt number
- * @param prio the interrupt priority
+ * @param prio the interrupt priority mask
*
* @note The parameters are not tested for correctness.
*/
@@ -61,13 +62,14 @@ void NVICDisableVector(uint32_t n) { * @brief Changes the priority of a system handler.
*
* @param handler the system handler number
- * @param prio the system handler priority
+ * @param prio the system handler priority mask
* @note The parameters are not tested for correctness.
*/
void NVICSetSystemHandlerPriority(uint32_t handler, uint32_t prio) {
unsigned sh = (handler & 3) * 8;
- SCB_SHPR(handler >> 2) = (SCB_SHPR(handler >> 2) & ~(0xFF << sh)) | (prio << sh);
+ SCB_SHPR(handler >> 2) = (SCB_SHPR(handler >> 2) &
+ ~(0xFF << sh)) | (prio << sh);
}
/** @} */
diff --git a/os/ports/GCC/ARMCMx/nvic.h b/os/ports/GCC/ARMCMx/nvic.h index 8a9950fcf..196b78fbd 100644 --- a/os/ports/GCC/ARMCMx/nvic.h +++ b/os/ports/GCC/ARMCMx/nvic.h @@ -18,8 +18,9 @@ */
/**
- * @file ARMCMx/nvic.h
- * @brief Cortex-Mx NVIC support macros and structures.
+ * @file ARMCMx/nvic.h
+ * @brief Cortex-Mx NVIC support macros and structures.
+ *
* @addtogroup ARMCMx_NVIC
* @{
*/
@@ -30,21 +31,21 @@ /*
* System vector constants for @p NVICSetSystemHandlerPriority().
*/
-#define HANDLER_MEM_MANAGE 0 /**< MEM MANAGE vector id.*/
-#define HANDLER_BUS_FAULT 1 /**< BUS FAULT vector id.*/
-#define HANDLER_USAGE_FAULT 2 /**< USAGE FAULT vector id.*/
+#define HANDLER_MEM_MANAGE 0 /**< MEM MANAGE vector id. */
+#define HANDLER_BUS_FAULT 1 /**< BUS FAULT vector id. */
+#define HANDLER_USAGE_FAULT 2 /**< USAGE FAULT vector id. */
#define HANDLER_RESERVED_3 3
#define HANDLER_RESERVED_4 4
#define HANDLER_RESERVED_5 5
#define HANDLER_RESERVED_6 6
-#define HANDLER_SVCALL 7 /**< SVCALL vector id.*/
-#define HANDLER_DEBUG_MONITOR 8 /**< DEBUG MONITOR vector id.*/
+#define HANDLER_SVCALL 7 /**< SVCALL vector id. */
+#define HANDLER_DEBUG_MONITOR 8 /**< DEBUG MONITOR vector id. */
#define HANDLER_RESERVED_9 9
-#define HANDLER_PENDSV 10 /**< PENDSV vector id.*/
-#define HANDLER_SYSTICK 11 /**< SYS TCK vector id.*/
+#define HANDLER_PENDSV 10 /**< PENDSV vector id. */
+#define HANDLER_SYSTICK 11 /**< SYS TCK vector id. */
-typedef volatile unsigned char IOREG8; /**< 8 bits I/O register type.*/
-typedef volatile unsigned int IOREG32; /**< 32 bits I/O register type.*/
+typedef volatile uint8_t IOREG8; /**< 8 bits I/O register type. */
+typedef volatile uint32_t IOREG32; /**< 32 bits I/O register type. */
/**
* @brief NVIC ITCR register.
diff --git a/os/ports/GCC/ARMCMx/port.dox b/os/ports/GCC/ARMCMx/port.dox index 6ec32f56f..a47ba1ad5 100644 --- a/os/ports/GCC/ARMCMx/port.dox +++ b/os/ports/GCC/ARMCMx/port.dox @@ -19,17 +19,65 @@ /**
* @defgroup ARMCMx ARM Cortex-Mx
- * @details This port supports the ARM Cortex-Mx architectures, specifically
- * the Cortex-M0 and the Cortex-M3.
+ * @details This port supports the ARMv6-M and ARMv7-M architectures (all the
+ * Cortex-Mx cores).
*
* @section ARMCMx_STATES Mapping of the System States in the ARM Cortex-Mx port
+ * This port supports two IRQ handling modes:
+ * - <b>IRQ disabling</b>. This is the simplest and most efficient way to
+ * implement kernel locks, this is done by globally disabling interrupts.
+ * This mode is available to both the ARMv6-M and ARMv7-M architectures.
+ * - <b>IRQ priority masking</b>. In this mode kernel locks are implemented by
+ * raising the priority mask to the @p CORTEX_BASEPRI_KERNEL level. Using
+ * priority masking it is possible to reserve one or more priority levels
+ * for use as fast interrupt handlers. This mode is slightly less efficient
+ * because the lock/unlock code requires two instructions instead of just
+ * one and is available to the ARMv7-M architecture only (Cortex-M3 and
+ * Cortex-M4). The advantage in this mode is the availability of very low
+ * latency priority levels unaffected by the RTOS activity.
+ * .
+ * The mapping of the @ref system_states changes depending on the chosen IRQ
+ * handling mode.
+ *
+ * @subsection ARMCMx_STATES_A System logical states in IRQ disabling mode
+ * - <b>Init</b>. This state is represented by the startup code and the
+ * initialization code before @p chSysInit() is executed. It has not a
+ * special hardware state associated.
+ * - <b>Normal</b>. This is the state the system has after executing
+ * @p chSysInit(). In this state interrupts are enabled. The processor
+ * is running in thread-privileged mode.
+ * - <b>Suspended</b>. In this state the interrupt sources are globally
+ * disabled. The processor is running in thread-privileged mode. In this
+ * mode this state is not different from the <b>Disabled</b> state.
+ * - <b>Disabled</b>. In this state the interrupt sources are globally
+ * disabled. The processor is running in thread-privileged mode. In this
+ * mode this state is not different from the <b>Suspended</b> state.
+ * - <b>Sleep</b>. This state is entered with the execution of the specific
+ * instruction @p <b>wfi</b>.
+ * - <b>S-Locked</b>. In this state the interrupt sources are globally
+ * disabled. The processor is running in thread-privileged mode.
+ * - <b>I-Locked</b>. In this state the interrupt sources are globally
+ * disabled. The processor is running in exception-privileged mode.
+ * - <b>Serving Regular Interrupt</b>. In this state the interrupt sources are
+ * not globally masked but only interrupts with higher priority can preempt
+ * the current handler. The processor is running in exception-privileged
+ * mode.
+ * - <b>Serving Fast Interrupt</b>. This state is not implemented in this mode.
+ * - <b>Serving Non-Maskable Interrupt</b>. The Cortex-M3 has a specific
+ * asynchronous NMI vector and several synchronous fault vectors that can
+ * be considered belonging to this category.
+ * - <b>Halted</b>. Implemented as an infinite loop after globally masking all
+ * the maskable interrupt sources. The ARM state is whatever the processor
+ * was running when @p chSysHalt() was invoked.
+ *
+ * @subsection ARMCMx_STATES_B System logical states in IRQ priority masking mode
* The ChibiOS/RT logical @ref system_states are mapped as follow in the ARM
- * Cortex-Mx port:
+ * Cortex-M3 port:
* - <b>Init</b>. This state is represented by the startup code and the
* initialization code before @p chSysInit() is executed. It has not a
* special hardware state associated.
* - <b>Normal</b>. This is the state the system has after executing
- * @p chSysInit(). In this state the ARM Cortex-Mx has the BASEPRI register
+ * @p chSysInit(). In this state the ARM Cortex-M3 has the BASEPRI register
* set at @p CORTEX_BASEPRI_USER level, interrupts are not masked. The
* processor is running in thread-privileged mode.
* - <b>Suspended</b>. In this state the interrupt sources are not globally
@@ -50,13 +98,14 @@ * is running in exception-privileged mode.
* - <b>Serving Regular Interrupt</b>. In this state the interrupt sources are
* not globally masked but only interrupts with higher priority can preempt
- * the current handler. The processor is running in exception-privileged mode.
+ * the current handler. The processor is running in exception-privileged
+ * mode.
* - <b>Serving Fast Interrupt</b>. It is basically the same of the SRI state
* but it is not possible to switch to the I-Locked state because fast
* interrupts can preempt the kernel critical zone.
- * - <b>Serving Non-Maskable Interrupt</b>. The Cortex-Mx has a specific
+ * - <b>Serving Non-Maskable Interrupt</b>. The Cortex-M3 has a specific
* asynchronous NMI vector and several synchronous fault vectors that can
- * be considered to be in this category.
+ * be considered belonging to this category.
* - <b>Halted</b>. Implemented as an infinite loop after globally masking all
* the maskable interrupt sources. The ARM state is whatever the processor
* was running when @p chSysHalt() was invoked.
@@ -66,18 +115,8 @@ * - The @p main() function is invoked in thread-privileged mode.
* - Each thread has a private process stack, the system has a single main
* stack where all the interrupts and exceptions are processed.
- * - Only the 4 MSb of the priority level are used, the 4 LSb are assumed
- * to be zero.
- * - The threads are started in thread-privileged mode with BASEPRI level
- * 0x00 (disabled).
- * - The kernel raises its BASEPRI level to @p CORTEX_BASEPRI_KERNEL in order
- * to protect the kernel data structures.
- * - Interrupt nesting and the other advanced NVIC features are supported.
- * - The SVC instruction and vector, with parameter #0, is internally used
- * for commanded context switching.<br>
- * It is possible to share the SVC handler at the cost of slower context
- * switching.
- * - The PendSV vector is internally used for preemption context switching.
+ * - The threads are started in thread-privileged mode.
+ * - Interrupt nesting and the other advanced core/NVIC features are supported.
* .
* @ingroup ports
*/
@@ -85,7 +124,7 @@ /**
* @defgroup ARMCMx_CONF Configuration Options
* @brief ARM Cortex-Mx Configuration Options.
- * @details The ARMCMx port allows some architecture-specific configurations
+ * @details The ARMCM3 port allows some architecture-specific configurations
* settings that can be specified externally, as example on the compiler
* command line:
* - @p INT_REQUIRED_STACK, this value represent the amount of stack space used
@@ -97,18 +136,18 @@ * - @p CORTEX_BASEPRI_USER, this is the @p BASEPRI value for the user threads.
* The default value is @p 0 (disabled).<br>
* Usually there is no need to change this value, please refer to the
- * Cortex-Mx technical reference manual for a detailed description.
+ * Cortex-M3 technical reference manual for a detailed description.
* - @p CORTEX_BASEPRI_KERNEL, this is the @p BASEPRI value for the kernel lock
* code.<br>
* Code running at higher priority levels must not invoke any OS API.<br>
* Usually there is no need to change this value, please refer to the
- * Cortex-Mx technical reference manual for a detailed description.
- * - @p ENABLE_WFI_IDLE, if set to @p 1 enables the use of the @p <b>wfi</b>
- * instruction from within the idle loop. This is defaulted to 0 because
- * it can create problems with some debuggers. Setting this option to 1
- * reduces the system power requirements.
+ * Cortex-M3 technical reference manual for a detailed description.
+ * - @p CORTEX_ENABLE_WFI_IDLE, if set to @p 1 enables the use of the
+ * @p <b>wfi</b> instruction from within the idle loop. This is defaulted to
+ * 0 because it can create problems with some debuggers. Setting this option
+ * to 1 reduces the system power requirements.
* .
- * @ingroup ARMCMx
+ * @ingroup ARMCM3
*/
/**
@@ -159,7 +198,6 @@ * - @p _bss_end BSS end location +1.
* .
* @ingroup ARMCMx
- * @file ARMCMx/crt0.s Startup code.
*/
/**
|