Development Support
MPC561/MPC563 Reference Manual, Rev. 1.2
Freescale Semiconductor
23-11
On the fly trap enable programming of the different internal breakpoints using the serial interface
available.
Watchpoints do not change the timing of the machine
Internal breakpoints and watchpoints are detected on the instruction during instruction fetch
Internal breakpoints and watchpoints are detected on the load/store during load/store bus cycles
Both instruction and load/store breakpoints and watchpoints are handled and reported on
retirement. Breakpoints and watchpoints on recovered instructions (as a result of exceptions,
interrupts or miss prediction) are not reported and do not change the timing of the machine.
Instructions with instruction breakpoints are not executed. The machine branches to the breakpoint
exception routine BEFORE it executes the instruction.
Instructions with load/store breakpoints are executed. The machine branches to the breakpoint
exception routine AFTER it executes the instruction. The address of the access is placed in the
BAR (breakpoint address register).
Load/store multiple and string instructions with load/store breakpoints first finish execution (all of
it) and then the machine branches to the breakpoint exception routine.
Load/store data compare is done on the load/store, AFTER swap in store accesses and BEFORE
swap in load accesses (as the data appears on the bus).
Internal breakpoints may operate either in masked mode or in non-masked mode.
Both “go to x” and “continue” working modes are supported for the instruction breakpoints.
23.2.1.1
Restrictions
There are cases when the same watchpoint can be detected more than once during the execution of a single
instruction, e.g. a load/store watchpoint is detected on more than one transfer when executing a load/store
multiple/string or a load/store watchpoint is detected on more than one byte when working in byte mode.
In all these cases only one watchpoint of the same type is reported for a single instruction. Similarly, only
one watchpoint of the same type can be counted in the counters for a single instruction.
Because watchpoint events are reported upon the retirement of the instruction that caused the event, and
more than one instruction can retire from the machine in one clock, consequent events may be reported in
the same clock. Moreover the same event, if detected on more than one instruction (e.g., tight loops, range
detection), in some cases will be reported only once. Note that the internal counters count correctly in these
cases.
Do not put a breakpoint on an mtspr instruction that accesses the ICTRL register when ICTRL[IFM] = 1
because this causes unpredictable behavior.
23.2.1.2
Byte and Half-Word Working Modes
The CPU watchpoints and breakpoints support enables detection of matches on bytes and half-words even
when accessed using a load/store instruction of larger data widths, for example when loading a table of
bytes using a series of load word instructions. In order to use this feature, program the byte mask for each
of the L-data comparators and to write the needed match value to the correct half-word of the data