Programming Model
1578
SPRUH22I – April 2012 – Revised November 2019
Copyright © 2012–2019, Texas Instruments Incorporated
Cortex-M3 Processor
24.4.4.9 Control Register (CONTROL)
The CONTROL register controls the stack used and the privilege level for software execution when the
processor is in Thread mode. This register is only accessible in privileged mode.
Handler mode always uses MSP, so the processor ignores explicit writes to the ASP bit of the CONTROL
register when in Handler mode. The exception entry and return mechanisms automatically update the
CONTROL register based on the EXC_RETURN value (see
). In an OS environment, threads
running in Thread mode should use the process stack and the kernel and exception handlers should use
the main stack. By default, Thread mode uses MSP. To switch the stack pointer used in Thread mode to
PSP, either use the MSR instruction to set the ASP bit, as detailed in the
Cortex-M3 Instruction Set
Technical User's Manual
, or perform an exception return to thread mode with the appropriate
EXC_RETURN value, as shown in
.
Note:
When changing the stack pointer, software must use an ISB instruction immediately after the MSR
instruction, ensuring that instructions after the ISB execute use the new stack pointer. See the
Cortex-M3
Instruction Set Technical User's Manual
.
Figure 24-11. Control Register (CONTROL)
31
1
0
Reserved
ASP
TMPL
R-0
R/W-0
R/W-0
LEGEND: R/W = Read/Write; R = Read only; -
n
= value after reset
Table 24-12. Control Register (CONTROL) Field Descriptions
Bit
Field
Value
Description
31-2
Reserved
Reserved
0
ASP
Active Stack Pointer
0
MSP is the current stack pointer
1
PSP is the current stack pointer.
In Handler mode, this bit reads as zero and ignores writes. The processor updates this bit
automatically on exception return.
TMPL
Thread mode privilege level
0
Only privileged software can be executed in thread mode.
1
Unprivileged software can be executed in thread mode.
24.4.5 Exceptions and Interrupts
The processor supports interrupts and system exceptions. The processor and the Nested Vectored
Interrupt Controller (NVIC) prioritize and handle all exceptions. An exception changes the normal flow of
software control. The processor uses handler mode to handle all exceptions except for reset. See
for more information.
The NVIC registers control interrupt handling. See Nested Vectored Interrupt Controller (NVIC) in the
Cortex-M3 Peripherals
chapter for more information.
24.4.6 Data Types
The processor supports 32-bit words, 16-bit halfwords, and 8-bit bytes. It also supports 64-bit data transfer
instructions. All instruction and data memory accesses are little endian. See
for more
information.
24.5 Memory Model
This section describes the behavior of memory accesses and the bit-banding features. The memory map
for the controller is provided in the data manual.
The regions for SRAM and peripherals include bit-band regions. Bit-banding provides atomic operations to
bit data (see