48
JN-DS-JN5142 1v0
© NXP Laboratories UK 2012
14 JTAG Debug Interface
The JN5142 includes an IEEE1149.1 compliant JTAG port for the sole purpose of software code debug with the
Software Development Kit. The JTAG interface is disabled by default and is enabled under software control.
Therefore, debugging is only possible if enabled by the application. Once enabled, the application executes as
normal until the external debugger controller initiates debug activity.
The Debugger supports breakpoints and watchpoints based on four comparisons between any of program counter,
load/store effective address and load/store data.
There is the ability to chain the comparisons together. There is also
the ability, under debugger control to perform the following commands: go, stop, reset, step over/into/out/next, run to
cursor and breakpoints. In addition, under control of the debugger, it is possible to:
Read and write registers on the wishbone bus
Read ROM and RAM, and write to RAM
Read and write CPU internal registers
The Debugger interface is accessed, depending upon the configuration, through the standard or alternative pins used
for UART0. This is enabled under software control and is dealt with in [4]. The following table details which DIO are
used for the JTAG interface depending upon the configuration.
Signal
DIO Assignment
Standard pins
Alternative pins
clock (TCK)
26
36
control (TMS)
27
37
data out (TDO)
28
38
data in (TDI)
29
40
Table 7: Hardware Debugger IO
If doze mode is active when debugging is started, the processor will be woken and then respond to debugger
commands. It is not possible to wake the device from sleep using the debug interface and debugging is not available
while the device is sleeping.
When using the debug interface, program execution is halted, and control of the CPU is handed to the debugger. The
watchdog, tick timer and the timers described in Section 11 are stalled while the debugger is in control of the CPU.
When control is handed from the CPU to the debugger or back a small number of CPU clock cycles are taken
flushing or reloading the CPU pipeline. Because of this, when a program is halted by the debugger and then restarted
again, a small number of tick timer cycles will elapse.
It is possible to prevent all hardware debugging by blowing the relevant Efuse bit. For further information on how to
program the eFuse, please contact technical support via the on-line tech-support system.
The JTAG interface does not support boundary scan testing. It is recommended that the JN5142 is not connected as
part of the board scan chain.