Programming Model
1573
SPRUH22I – April 2012 – Revised November 2019
Copyright © 2012–2019, Texas Instruments Incorporated
Cortex-M3 Processor
24.4.4.3 Link Register (LR)
The link register (LR) is register R14, and it stores the return information for subroutines, function calls,
and exceptions. LR can be accessed from either privileged or unprivileged mode.
EXC_RETURN is loaded into LR on exception entry. See
for the values and description.
Figure 24-5. Link Register
31
0
LINK
R/W
LEGEND: R/W = Read/Write; R = Read only; -
n
= value after reset
Table 24-5. Link Register Field Descriptions
Bit
Field
Value
Description
31-0
LINK
Return address
24.4.4.4 Program Counter (PC)
The program counter (PC) is register R15, and it contains the current program address. On reset, the
processor loads the PC with the value of the reset vector, which is at address 0x0000.0004. Bit 0 of the
reset vector is loaded into the THUMB bit of the EPSR at reset and must be 1. The PC register can be
accessed in either privileged or unprivileged mode.
Figure 24-6. Program Counter Register
31
0
PC
R/W
LEGEND: R/W = Read/Write; R = Read only; -
n
= value after reset
Table 24-6. Program Counter Register Field Descriptions
Bit
Field
Value
Description
31-0
PC
Current program address
24.4.4.5 Program Status Register (PSR)
The program status register (PSR) has three functions, and the register bits are assigned to the different
functions:
•
Application Program Status Register (APSR), bits 31:27,
•
Execution Program Status Register (EPSR), bits 26:24, 15:10
•
Interrupt Program Status Register (IPSR), bits 6:0
The PSR, IPSR, and EPSR registers can only be accessed in privileged mode; the APSR register can be
accessed in either privileged or unprivileged mode.
APSR contains the current state of the condition flags from previous instruction executions.
EPSR contains the Thumb state bit and the execution state bits for the If-Then (IT) instruction or the
Interruptible-Continuable Instruction (ICI) field for an interrupted load multiple or store multiple instruction.
Attempts to read the EPSR directly through application software using the MSR instruction always return
zero. Attempts to write the EPSR using the MSR instruction in application software are always ignored.
Fault handlers can examine the EPSR value in the stacked PSR to determine the operation that faulted
(see
IPSR contains the exception type number of the current Interrupt Service Routine (ISR).