Debug in depth
C-26
Copyright 2000 ARM Limited. All rights reserved.
ARM DDI 0165B
C.8.5
Debug request
Entry into debug state through a debug request is similar to a breakpoint. Entry to debug
state adds four addresses to the PC, and every instruction executed in debug state adds
one address.
For example, the following sequence handles a situation in which the user has invoked
a debug request, and then decides to return to program execution immediately:
0 EAFFFFFB; B -5 addresses (2’s complement)
1 E1A00000; NOP (MOV R0, R0), SYSSPEED bit is set
This code restores the PC, and restarts the program from the next instruction.
C.8.6
System speed access
When a system speed access is performed during debug state, the value of the PC
increases by five addresses. System speed instructions access the memory system, and
so it is possible for aborts to take place. If an abort occurs during a system speed
memory access, the ARM9E-S enters Abort mode before returning to debug state.
This scenario is similar to an aborted watchpoint, but the problem is much harder to fix
because the abort is not caused by an instruction in the main program, and so the PC
does not point to the instruction that caused the abort. An abort handler usually looks at
the PC to determine the instruction that caused the abort, and the abort address. In this
case, the value of the PC is invalid, but because the debugger can determine which
location was being accessed, you can write the debugger to help the abort handler fix
the memory system.
C.8.7
Summary of return address calculations
The calculation of the branch return address can be summarized as:
-(4+N+5S)
where N is the number of debug speed instructions executed (including the final
branch), and S is the number of system speed instructions executed.