Debug
ARM DDI 0301H
Copyright © 2004-2009 ARM Limited. All rights reserved.
13-27
ID012310
Non-Confidential, Unrestricted Access
Use of R15 in all other MRC instructions that Table 13-19 on page 13-26 lists, sets all four flags
to Unpredictable values.
Instructions that follow the MRC instruction can be conditioned to these CPSR flags.
13.5.1
Executing CP14 debug instructions
If the core is in Debug state, see
Debug state
on page 13-37, you can execute any CP14 debug
instruction regardless of the processor mode.
If the processor tries to execute a CP14 debug instruction that either is not in Table 13-19 on
page 13-26, or is targeted to a reserved register, such as a non-implemented BVR, the Undefined
instruction exception is taken.
You can access the DCC, read DIDR, read DSCR and read/write DTR, in User mode. All other
CP14 debug instructions are privileged. If the processor tries to execute one of these in User
mode, the Undefined instruction exception is taken.
If the User mode access to DCC disable bit, DSCR[12], is set, all CP14 debug instructions are
considered as privileged, and all attempted User mode accesses to CP14 debug registers
generate an Undefined instruction exception.
When DSCR bit 14 is set, Halting debug-mode selected and enabled, if the software running on
the processor tries to access any register other than the DIDR, the DSCR, or the DTR, the core
takes the Undefined instruction exception. The same thing happens if the core is not in any
Debug mode, DSCR[15:14]=b00. This lockout mechanism ensures that the software running on
the core cannot modify the settings of a debug event programmed by the DBGTAP debugger.
Table 13-20 lists the results of executing CP14 debug instructions.
Table 13-20 Debug instruction execution
State when executing CP14 debug instruction:
Results of CP14 debug instruction execution:
Processor
mode
Debug
state
DSCR[15:14],
Mode enabled
and selected
DSCR[12],
DCC User
accesses
disabled
Read DIDR,
read DSCR
and read/
write DTR
Write
DSCR
Read/write
other debug
registers
x
Yes
xx
x
Proceed
Proceed
Proceed
User
No
xx
0
Proceed
Undefined
exception
Undefined
exception
User
No
xx
1
Undefined
exception
Undefined
exception
Undefined
exception
Privileged
No
b00, None
x
Proceed
Proceed
Undefined
exception
Privileged
No
b01, Halting
x
Proceed
Proceed
Undefined
exception
Privileged
No
b10, Monitor
x
Proceed
Proceed
Proceed
Privileged
No
b11, Halting
x
Proceed
Proceed
Undefined
exception