Files
fail/debuggers/openocd/doc/openocd.info-2
Lars Rademacher 83d72a091e debuggers: import openocd-0.7.0
Initial check-in of openocd-0.7.0 as it can be downloaded from
http://sourceforge.net/projects/openocd/files/openocd/0.7.0/

Any modifications will follow.

Change-Id: I6949beaefd589e046395ea0cb80f4e1ab1654d55
2013-12-02 14:53:22 +01:00

2251 lines
116 KiB
Plaintext
Raw Permalink Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This is openocd.info, produced by makeinfo version 5.1 from
openocd.texi.
This User's Guide documents release 0.7.0, dated 4 May 2013, of the Open
On-Chip Debugger (OpenOCD).
* Copyright (C) 2008 The OpenOCD Project
* Copyright (C) 2007-2008 Spencer Oliver <spen@spen-soft.co.uk>
* Copyright (C) 2008-2010 Oyvind Harboe <oyvind.harboe@zylin.com>
* Copyright (C) 2008 Duane Ellis <openocd@duaneellis.com>
* Copyright (C) 2009-2010 David Brownell
Permission is granted to copy, distribute and/or modify this
document under the terms of the GNU Free Documentation License,
Version 1.2 or any later version published by the Free Software
Foundation; with no Invariant Sections, with no Front-Cover Texts,
and with no Back-Cover Texts. A copy of the license is included in
the section entitled "GNU Free Documentation License".
INFO-DIR-SECTION Development
START-INFO-DIR-ENTRY
* OpenOCD: (openocd). OpenOCD User's Guide
END-INFO-DIR-ENTRY

File: openocd.info, Node: Boundary Scan Commands, Next: TFTP, Prev: JTAG Commands, Up: Top
19 Boundary Scan Commands
*************************
One of the original purposes of JTAG was to support boundary scan based
hardware testing. Although its primary focus is to support On-Chip
Debugging, OpenOCD also includes some boundary scan commands.
19.1 SVF: Serial Vector Format
==============================
The Serial Vector Format, better known as "SVF", is a way to represent
JTAG test patterns in text files. In a debug session using JTAG for its
transport protocol, OpenOCD supports running such test files.
-- Command: svf filename ['quiet']
This issues a JTAG reset (Test-Logic-Reset) and then runs the SVF
script from 'filename'. Unless the 'quiet' option is specified,
each command is logged before it is executed.
19.2 XSVF: Xilinx Serial Vector Format
======================================
The Xilinx Serial Vector Format, better known as "XSVF", is a binary
representation of SVF which is optimized for use with Xilinx devices.
In a debug session using JTAG for its transport protocol, OpenOCD
supports running such test files.
Important: Not all XSVF commands are supported.
-- Command: xsvf (tapname|'plain') filename ['virt2'] ['quiet']
This issues a JTAG reset (Test-Logic-Reset) and then runs the XSVF
script from 'filename'. When a TAPNAME is specified, the commands
are directed at that TAP. When 'virt2' is specified, the XRUNTEST
command counts are interpreted as TCK cycles instead of
microseconds. Unless the 'quiet' option is specified, messages are
logged for comments and some retries.
The OpenOCD sources also include two utility scripts for working with
XSVF; they are not currently installed after building the software. You
may find them useful:
* _svf2xsvf_ ... converts SVF files into the extended XSVF syntax
understood by the 'xsvf' command; see notes below.
* _xsvfdump_ ... converts XSVF files into a text output format;
understands the OpenOCD extensions.
The input format accepts a handful of non-standard extensions. These
include three opcodes corresponding to SVF extensions from Lattice
Semiconductor (LCOUNT, LDELAY, LDSR), and two opcodes supporting a more
accurate translation of SVF (XTRST, XWAITSTATE). If _xsvfdump_ shows a
file is using those opcodes, it probably will not be usable with other
XSVF tools.

File: openocd.info, Node: TFTP, Next: GDB and OpenOCD, Prev: Boundary Scan Commands, Up: Top
20 TFTP
*******
If OpenOCD runs on an embedded host(as ZY1000 does), then TFTP can be
used to access files on PCs (either the developer's PC or some other
PC).
The way this works on the ZY1000 is to prefix a filename by "/tftp/ip/"
and append the TFTP path on the TFTP server (tftpd). For example,
load_image /tftp/10.0.0.96/c:\temp\abc.elf
will load c:\temp\abc.elf from the developer pc (10.0.0.96) into memory
as if the file was hosted on the embedded host.
In order to achieve decent performance, you must choose a TFTP server
that supports a packet size bigger than the default packet size (512
bytes). There are numerous TFTP servers out there (free and commercial)
and you will have to do a bit of googling to find something that fits
your requirements.

File: openocd.info, Node: GDB and OpenOCD, Next: Tcl Scripting API, Prev: TFTP, Up: Top
21 GDB and OpenOCD
******************
OpenOCD complies with the remote gdbserver protocol, and as such can be
used to debug remote targets. Setting up GDB to work with OpenOCD can
involve several components:
* The OpenOCD server support for GDB may need to be configured.
*Note GDB Configuration: gdbconfiguration.
* GDB's support for OpenOCD may need configuration, as shown in this
chapter.
* If you have a GUI environment like Eclipse, that also will probably
need to be configured.
Of course, the version of GDB you use will need to be one which has been
built to know about the target CPU you're using. It's probably part of
the tool chain you're using. For example, if you are doing
cross-development for ARM on an x86 PC, instead of using the native x86
'gdb' command you might use 'arm-none-eabi-gdb' if that's the tool chain
used to compile your code.
21.1 Connecting to GDB
======================
Use GDB 6.7 or newer with OpenOCD if you run into trouble. For instance
GDB 6.3 has a known bug that produces bogus memory access errors, which
has since been fixed; see
<http://osdir.com/ml/gdb.bugs.discuss/2004-12/msg00018.html>
OpenOCD can communicate with GDB in two ways:
1. A socket (TCP/IP) connection is typically started as follows:
target remote localhost:3333
This would cause GDB to connect to the gdbserver on the local pc
using port 3333.
It is also possible to use the GDB extended remote protocol as
follows:
target extended-remote localhost:3333
2. A pipe connection is typically started as follows:
target remote | openocd -c "gdb_port pipe; log_output openocd.log"
This would cause GDB to run OpenOCD and communicate using pipes
(stdin/stdout). Using this method has the advantage of GDB
starting/stopping OpenOCD for the debug session. log_output sends
the log output to a file to ensure that the pipe is not saturated
when using higher debug level outputs.
To list the available OpenOCD commands type 'monitor help' on the GDB
command line.
21.2 Sample GDB session startup
===============================
With the remote protocol, GDB sessions start a little differently than
they do when you're debugging locally. Here's an examples showing how
to start a debug session with a small ARM program. In this case the
program was linked to be loaded into SRAM on a Cortex-M3. Most programs
would be written into flash (address 0) and run from there.
$ arm-none-eabi-gdb example.elf
(gdb) target remote localhost:3333
Remote debugging using localhost:3333
...
(gdb) monitor reset halt
...
(gdb) load
Loading section .vectors, size 0x100 lma 0x20000000
Loading section .text, size 0x5a0 lma 0x20000100
Loading section .data, size 0x18 lma 0x200006a0
Start address 0x2000061c, load size 1720
Transfer rate: 22 KB/sec, 573 bytes/write.
(gdb) continue
Continuing.
...
You could then interrupt the GDB session to make the program break, type
'where' to show the stack, 'list' to show the code around the program
counter, 'step' through code, set breakpoints or watchpoints, and so on.
21.3 Configuring GDB for OpenOCD
================================
OpenOCD supports the gdb 'qSupported' packet, this enables information
to be sent by the GDB remote server (i.e. OpenOCD) to GDB. Typical
information includes packet size and the device's memory map. You do
not need to configure the packet size by hand, and the relevant parts of
the memory map should be automatically set up when you declare (NOR)
flash banks.
However, there are other things which GDB can't currently query. You
may need to set those up by hand. As OpenOCD starts up, you will often
see a line reporting something like:
Info : lm3s.cpu: hardware has 6 breakpoints, 4 watchpoints
You can pass that information to GDB with these commands:
set remote hardware-breakpoint-limit 6
set remote hardware-watchpoint-limit 4
With that particular hardware (Cortex-M3) the hardware breakpoints only
work for code running from flash memory. Most other ARM systems do not
have such restrictions.
Another example of useful GDB configuration came from a user who found
that single stepping his Cortex-M3 didn't work well with IRQs and an
RTOS until he told GDB to disable the IRQs while stepping:
define hook-step
mon cortex_m maskisr on
end
define hookpost-step
mon cortex_m maskisr off
end
Rather than typing such commands interactively, you may prefer to save
them in a file and have GDB execute them as it starts, perhaps using a
'.gdbinit' in your project directory or starting GDB using 'gdb -x
filename'.
21.4 Programming using GDB
==========================
By default the target memory map is sent to GDB. This can be disabled by
the following OpenOCD configuration option:
gdb_memory_map disable
For this to function correctly a valid flash configuration must also be
set in OpenOCD. For faster performance you should also configure a valid
working area.
Informing GDB of the memory map of the target will enable GDB to protect
any flash areas of the target and use hardware breakpoints by default.
This means that the OpenOCD option 'gdb_breakpoint_override' is not
required when using a memory map. *Note gdb_breakpoint_override:
gdbbreakpointoverride.
To view the configured memory map in GDB, use the GDB command 'info mem'
All other unassigned addresses within GDB are treated as RAM.
GDB 6.8 and higher set any memory area not in the memory map as
inaccessible. This can be changed to the old behaviour by using the
following GDB command
set mem inaccessible-by-default off
If 'gdb_flash_program enable' is also used, GDB will be able to program
any flash memory using the vFlash interface.
GDB will look at the target memory map when a load command is given, if
any areas to be programmed lie within the target flash area the vFlash
packets will be used.
If the target needs configuring before GDB programming, an event script
can be executed:
$_TARGETNAME configure -event EVENTNAME BODY
To verify any flash programming the GDB command 'compare-sections' can
be used.
21.5 Using OpenOCD SMP with GDB
===============================
For SMP support following GDB serial protocol packet have been defined :
* j - smp status request
* J - smp set request
OpenOCD implements :
* 'jc' packet for reading core id displayed by GDB connection. Reply
is 'XXXXXXXX' (8 hex digits giving core id) or 'E01' for target not
smp.
* 'JcXXXXXXXX' (8 hex digits) packet for setting core id displayed at
next GDB continue (core id -1 is reserved for returning to normal
resume mode). Reply 'E01' for target not smp or 'OK' on success.
Handling of this packet within GDB can be done :
* by the creation of an internal variable (i.e '_core') by mean of
function allocate_computed_value allowing following GDB command.
set $_core 1
#Jc01 packet is sent
print $_core
#jc packet is sent and result is affected in $
* by the usage of GDB maintenance command as described in following
example (2 cpus in SMP with core id 0 and 1 *note Define CPU
targets working in SMP: definecputargetsworkinginsmp.).
# toggle0 : force display of coreid 0
define toggle0
maint packet Jc0
continue
main packet Jc-1
end
# toggle1 : force display of coreid 1
define toggle1
maint packet Jc1
continue
main packet Jc-1
end

File: openocd.info, Node: Tcl Scripting API, Next: FAQ, Prev: GDB and OpenOCD, Up: Top
22 Tcl Scripting API
********************
22.1 API rules
==============
The commands are stateless. E.g. the telnet command line has a concept
of currently active target, the Tcl API proc's take this sort of state
information as an argument to each proc.
There are three main types of return values: single value, name value
pair list and lists.
Name value pair. The proc 'foo' below returns a name/value pair list.
> set foo(me) Duane
> set foo(you) Oyvind
> set foo(mouse) Micky
> set foo(duck) Donald
If one does this:
> set foo
The result is:
me Duane you Oyvind mouse Micky duck Donald
Thus, to get the names of the associative array is easy:
foreach { name value } [set foo] {
puts "Name: $name, Value: $value"
}
Lists returned must be relatively small. Otherwise a range should be
passed in to the proc in question.
22.2 Internal low-level Commands
================================
By low-level, the intent is a human would not directly use these
commands.
Low-level commands are (should be) prefixed with "ocd_", e.g.
'ocd_flash_banks' is the low level API upon which 'flash banks' is
implemented.
* mem2array <VARNAME> <WIDTH> <ADDR> <NELEMS>
Read memory and return as a Tcl array for script processing
* array2mem <VARNAME> <WIDTH> <ADDR> <NELEMS>
Convert a Tcl array to memory locations and write the values
* ocd_flash_banks <DRIVER> <BASE> <SIZE> <CHIP_WIDTH> <BUS_WIDTH>
<TARGET> ['driver options' ...]
Return information about the flash banks
OpenOCD commands can consist of two words, e.g. "flash banks". The
'startup.tcl' "unknown" proc will translate this into a Tcl proc called
"flash_banks".
22.3 OpenOCD specific Global Variables
======================================
Real Tcl has ::tcl_platform(), and platform::identify, and many other
variables. JimTCL, as implemented in OpenOCD creates $ocd_HOSTOS which
holds one of the following values:
* cygwin Running under Cygwin
* darwin Darwin (Mac-OS) is the underlying operating sytem.
* freebsd Running under FreeBSD
* linux Linux is the underlying operating sytem
* mingw32 Running under MingW32
* winxx Built using Microsoft Visual Studio
* other Unknown, none of the above.
Note: 'winxx' was choosen because today (March-2009) no distinction is
made between Win32 and Win64.
Note: We should add support for a variable like Tcl variable
'tcl_platform(platform)', it should be called 'jim_platform'
(because it is jim, not real tcl).

File: openocd.info, Node: FAQ, Next: Tcl Crash Course, Prev: Tcl Scripting API, Up: Top
23 FAQ
******
1. RTCK, also known as: Adaptive Clocking - What is it?
In digital circuit design it is often refered to as "clock
synchronisation" the JTAG interface uses one clock (TCK or TCLK)
operating at some speed, your CPU target is operating at another.
The two clocks are not synchronised, they are "asynchronous"
In order for the two to work together they must be synchronised
well enough to work; JTAG can't go ten times faster than the CPU,
for example. There are 2 basic options:
1. Use a special "adaptive clocking" circuit to change the JTAG
clock rate to match what the CPU currently supports.
2. The JTAG clock must be fixed at some speed that's enough
slower than the CPU clock that all TMS and TDI transitions can
be detected.
Does this really matter? For some chips and some situations, this
is a non-issue, like a 500MHz ARM926 with a 5 MHz JTAG link; the
CPU has no difficulty keeping up with JTAG. Startup sequences are
often problematic though, as are other situations where the CPU
clock rate changes (perhaps to save power).
For example, Atmel AT91SAM chips start operation from reset with a
32kHz system clock. Boot firmware may activate the main oscillator
and PLL before switching to a faster clock (perhaps that 500 MHz
ARM926 scenario). If you're using JTAG to debug that startup
sequence, you must slow the JTAG clock to sometimes 1 to 4kHz.
After startup completes, JTAG can use a faster clock.
Consider also debugging a 500MHz ARM926 hand held battery powered
device that enters a low power "deep sleep" mode, at 32kHz CPU
clock, between keystrokes unless it has work to do. When would
that 5 MHz JTAG clock be usable?
Solution #1 - A special circuit
In order to make use of this, your CPU, board, and JTAG adapter
must all support the RTCK feature. Not all of them support this;
keep reading!
The RTCK ("Return TCK") signal in some ARM chips is used to help
with this problem. ARM has a good description of the problem
described at this link:
<http://www.arm.com/support/faqdev/4170.html> [checked
28/nov/2008]. Link title: "How does the JTAG synchronisation logic
work? / how does adaptive clocking work?".
The nice thing about adaptive clocking is that "battery powered
hand held device example" - the adaptiveness works perfectly all
the time. One can set a break point or halt the system in the deep
power down code, slow step out until the system speeds up.
Note that adaptive clocking may also need to work at the board
level, when a board-level scan chain has multiple chips. Parallel
clock voting schemes are good way to implement this, both within
and between chips, and can easily be implemented with a CPLD. It's
not difficult to have logic fan a module's input TCK signal out to
each TAP in the scan chain, and then wait until each TAP's RTCK
comes back with the right polarity before changing the output RTCK
signal. Texas Instruments makes some clock voting logic available
for free (with no support) in VHDL form; see
<http://tiexpressdsp.com/index.php/Adaptive_Clocking>
Solution #2 - Always works - but may be slower
Often this is a perfectly acceptable solution.
In most simple terms: Often the JTAG clock must be 1/10 to 1/12 of
the target clock speed. But what that "magic division" is varies
depending on the chips on your board. ARM rule of thumb Most ARM
based systems require an 6:1 division; ARM11 cores use an 8:1
division. Xilinx rule of thumb is 1/12 the clock speed.
Note: most full speed FT2232 based JTAG adapters are limited to a
maximum of 6MHz. The ones using USB high speed chips (FT2232H)
often support faster clock rates (and adaptive clocking).
You can still debug the 'low power' situations - you just need to
either use a fixed and very slow JTAG clock rate ... or else
manually adjust the clock speed at every step. (Adjusting is
painful and tedious, and is not always practical.)
It is however easy to "code your way around it" - i.e.: Cheat a
little, have a special debug mode in your application that does a
"high power sleep". If you are careful - 98% of your problems can
be debugged this way.
Note that on ARM you may need to avoid using the _wait for
interrupt_ operation in your idle loops even if you don't otherwise
change the CPU clock rate. That operation gates the CPU clock, and
thus the JTAG clock; which prevents JTAG access. One consequence
is not being able to 'halt' cores which are executing that _wait
for interrupt_ operation.
To set the JTAG frequency use the command:
# Example: 1.234MHz
adapter_khz 1234
2. Win32 Pathnames Why don't backslashes work in Windows paths?
OpenOCD uses Tcl and a backslash is an escape char. Use { and }
around Windows filenames.
> echo \a
> echo {\a}
\a
> echo "\a"
>
3. Missing: cygwin1.dll OpenOCD complains about a missing cygwin1.dll.
Make sure you have Cygwin installed, or at least a version of
OpenOCD that claims to come with all the necessary DLLs. When
using Cygwin, try launching OpenOCD from the Cygwin shell.
4. Breakpoint Issue I'm trying to set a breakpoint using GDB (or a
frontend like Insight or Eclipse), but OpenOCD complains that
"Info: arm7_9_common.c:213 arm7_9_add_breakpoint(): sw breakpoint
requested, but software breakpoints not enabled".
GDB issues software breakpoints when a normal breakpoint is
requested, or to implement source-line single-stepping. On ARMv4T
systems, like ARM7TDMI, ARM720T or ARM920T, software breakpoints
consume one of the two available hardware breakpoints.
5. LPC2000 Flash When erasing or writing LPC2000 on-chip flash, the
operation fails at random.
Make sure the core frequency specified in the 'flash lpc2000' line
matches the clock at the time you're programming the flash. If
you've specified the crystal's frequency, make sure the PLL is
disabled. If you've specified the full core speed (e.g. 60MHz),
make sure the PLL is enabled.
6. Amontec Chameleon When debugging using an Amontec Chameleon in its
JTAG Accelerator configuration, I keep getting "Error:
amt_jtagaccel.c:184 amt_wait_scan_busy(): amt_jtagaccel timed out
while waiting for end of scan, rtck was disabled".
Make sure your PC's parallel port operates in EPP mode. You might
have to try several settings in your PC BIOS (ECP, EPP, and
different versions of those).
7. Data Aborts When debugging with OpenOCD and GDB (plain GDB,
Insight, or Eclipse), I get lots of "Error: arm7_9_common.c:1771
arm7_9_read_memory(): memory read caused data abort".
The errors are non-fatal, and are the result of GDB trying to trace
stack frames beyond the last valid frame. It might be possible to
prevent this by setting up a proper "initial" stack frame, if you
happen to know what exactly has to be done, feel free to add this
here.
Simple: In your startup code - push 8 registers of zeros onto the
stack before calling main(). What GDB is doing is "climbing" the
run time stack by reading various values on the stack using the
standard call frame for the target. GDB keeps going - until one of
2 things happen #1 an invalid frame is found, or #2 some huge
number of stackframes have been processed. By pushing zeros on the
stack, GDB gracefully stops.
Debugging Interrupt Service Routines - In your ISR before you call
your C code, do the same - artifically push some zeros onto the
stack, remember to pop them off when the ISR is done.
Also note: If you have a multi-threaded operating system, they
often do not in the intrest of saving memory waste these few bytes.
Painful...
8. JTAG Reset Config I get the following message in the OpenOCD
console (or log file): "Warning: arm7_9_common.c:679
arm7_9_assert_reset(): srst resets test logic, too".
This warning doesn't indicate any serious problem, as long as you
don't want to debug your core right out of reset. Your .cfg file
specified 'jtag_reset trst_and_srst srst_pulls_trst' to tell
OpenOCD that either your board, your debugger or your target uC
(e.g. LPC2000) can't assert the two reset signals independently.
With this setup, it's not possible to halt the core right out of
reset, everything else should work fine.
9. USB Power When using OpenOCD in conjunction with Amontec JTAGkey
and the Yagarto toolchain (Eclipse, arm-elf-gcc, arm-elf-gdb), the
debugging seems to be unstable. When single-stepping over large
blocks of code, GDB and OpenOCD quit with an error message. Is
there a stability issue with OpenOCD?
No, this is not a stability issue concerning OpenOCD. Most users
have solved this issue by simply using a self-powered USB hub,
which they connect their Amontec JTAGkey to. Apparently, some
computers do not provide a USB power supply stable enough for the
Amontec JTAGkey to be operated.
Laptops running on battery have this problem too...
10. USB Power When using the Amontec JTAGkey, sometimes OpenOCD
crashes with the following error messages: "Error: ft2232.c:201
ft2232_read(): FT_Read returned: 4" and "Error: ft2232.c:365
ft2232_send_and_recv(): couldn't read from FT2232". What does that
mean and what might be the reason for this?
First of all, the reason might be the USB power supply. Try using
a self-powered hub instead of a direct connection to your computer.
Secondly, the error code 4 corresponds to an FT_IO_ERROR, which
means that the driver for the FTDI USB chip ran into some sort of
error - this points us to a USB problem.
11. GDB Disconnects When using the Amontec JTAGkey, sometimes OpenOCD
crashes with the following error message: "Error: gdb_server.c:101
gdb_get_char(): read: 10054". What does that mean and what might
be the reason for this?
Error code 10054 corresponds to WSAECONNRESET, which means that the
debugger (GDB) has closed the connection to OpenOCD. This might be
a GDB issue.
12. LPC2000 Flash In the configuration file in the section where flash
device configurations are described, there is a parameter for
specifying the clock frequency for LPC2000 internal flash devices
(e.g. 'flash bank $_FLASHNAME lpc2000 0x0 0x40000 0 0 $_TARGETNAME
lpc2000_v1 14746 calc_checksum'), which must be specified in
kilohertz. However, I do have a quartz crystal of a frequency that
contains fractions of kilohertz (e.g. 14,745,600 Hz, i.e.
14,745.600 kHz). Is it possible to specify real numbers for the
clock frequency?
No. The clock frequency specified here must be given as an
integral number. However, this clock frequency is used by the
In-Application-Programming (IAP) routines of the LPC2000 family
only, which seems to be very tolerant concerning the given clock
frequency, so a slight difference between the specified clock
frequency and the actual clock frequency will not cause any
trouble.
13. Command Order Do I have to keep a specific order for the commands
in the configuration file?
Well, yes and no. Commands can be given in arbitrary order, yet
the devices listed for the JTAG scan chain must be given in the
right order (jtag newdevice), with the device closest to the
TDO-Pin being listed first. In general, whenever objects of the
same type exist which require an index number, then these objects
must be given in the right order (jtag newtap, targets and flash
banks - a target references a jtag newtap and a flash bank
references a target).
You can use the "scan_chain" command to verify and display the tap
order.
Also, some commands can't execute until after 'init' has been
processed. Such commands include 'nand probe' and everything else
that needs to write to controller registers, perhaps for setting up
DRAM and loading it with code.
14. JTAG TAP Order Do I have to declare the TAPS in some particular
order?
Yes; whenever you have more than one, you must declare them in the
same order used by the hardware.
Many newer devices have multiple JTAG TAPs. For example: ST
Microsystems STM32 chips have two TAPs, a "boundary scan TAP" and
"Cortex-M3" TAP. Example: The STM32 reference manual, Document ID:
RM0008, Section 26.5, Figure 259, page 651/681, the "TDI" pin is
connected to the boundary scan TAP, which then connects to the
Cortex-M3 TAP, which then connects to the TDO pin.
Thus, the proper order for the STM32 chip is: (1) The Cortex-M3,
then (2) The boundary scan TAP. If your board includes an
additional JTAG chip in the scan chain (for example a Xilinx CPLD
or FPGA) you could place it before or after the STM32 chip in the
chain. For example:
* OpenOCD_TDI(output) -> STM32 TDI Pin (BS Input)
* STM32 BS TDO (output) -> STM32 Cortex-M3 TDI (input)
* STM32 Cortex-M3 TDO (output) -> SM32 TDO Pin
* STM32 TDO Pin (output) -> Xilinx TDI Pin (input)
* Xilinx TDO Pin -> OpenOCD TDO (input)
The "jtag device" commands would thus be in the order shown below.
Note:
* jtag newtap Xilinx tap -irlen ...
* jtag newtap stm32 cpu -irlen ...
* jtag newtap stm32 bs -irlen ...
* # Create the debug target and say where it is
* target create stm32.cpu -chain-position stm32.cpu ...
15. SYSCOMP Sometimes my debugging session terminates with an error.
When I look into the log file, I can see these error messages:
Error: arm7_9_common.c:561 arm7_9_execute_sys_speed(): timeout
waiting for SYSCOMP
TODO.

File: openocd.info, Node: Tcl Crash Course, Next: License, Prev: FAQ, Up: Top
24 Tcl Crash Course
*******************
Not everyone knows Tcl - this is not intended to be a replacement for
learning Tcl, the intent of this chapter is to give you some idea of how
the Tcl scripts work.
This chapter is written with two audiences in mind. (1) OpenOCD users
who need to understand a bit more of how Jim-Tcl works so they can do
something useful, and (2) those that want to add a new command to
OpenOCD.
24.1 Tcl Rule #1
================
There is a famous joke, it goes like this:
1. Rule #1: The wife is always correct
2. Rule #2: If you think otherwise, See Rule #1
The Tcl equal is this:
1. Rule #1: Everything is a string
2. Rule #2: If you think otherwise, See Rule #1
As in the famous joke, the consequences of Rule #1 are profound. Once
you understand Rule #1, you will understand Tcl.
24.2 Tcl Rule #1b
=================
There is a second pair of rules.
1. Rule #1: Control flow does not exist. Only commands
For example: the classic FOR loop or IF statement is not a control
flow item, they are commands, there is no such thing as control
flow in Tcl.
2. Rule #2: If you think otherwise, See Rule #1
Actually what happens is this: There are commands that by
convention, act like control flow key words in other languages.
One of those commands is the word "for", another command is "if".
24.3 Per Rule #1 - All Results are strings
==========================================
Every Tcl command results in a string. The word "result" is used
deliberatly. No result is just an empty string. Remember: Rule #1 -
Everything is a string
24.4 Tcl Quoting Operators
==========================
In life of a Tcl script, there are two important periods of time, the
difference is subtle.
1. Parse Time
2. Evaluation Time
The two key items here are how "quoted things" work in Tcl. Tcl has
three primary quoting constructs, the [square-brackets] the
{curly-braces} and "double-quotes"
By now you should know $VARIABLES always start with a $DOLLAR sign.
BTW: To set a variable, you actually use the command "set", as in "set
VARNAME VALUE" much like the ancient BASIC langauge "let x = 1"
statement, but without the equal sign.
* [square-brackets]
[square-brackets] are command substitutions. It operates much like
Unix Shell 'back-ticks'. The result of a [square-bracket]
operation is exactly 1 string. Remember Rule #1 - Everything is a
string. These two statements are roughly identical:
# bash example
X=`date`
echo "The Date is: $X"
# Tcl example
set X [date]
puts "The Date is: $X"
* "double-quoted-things"
"double-quoted-things" are just simply quoted text. $VARIABLES and
[square-brackets] are expanded in place - the result however is
exactly 1 string. Remember Rule #1 - Everything is a string
set x "Dinner"
puts "It is now \"[date]\", $x is in 1 hour"
* {Curly-Braces}
{Curly-Braces} are magic: $VARIABLES and [square-brackets] are
parsed, but are NOT expanded or executed. {Curly-Braces} are like
'single-quote' operators in BASH shell scripts, with the added
feature: {curly-braces} can be nested, single quotes can not.
{{{this is nested 3 times}}} NOTE: [date] is a bad example; at this
writing, Jim/OpenOCD does not have a date command.
24.5 Consequences of Rule 1/2/3/4
=================================
The consequences of Rule 1 are profound.
24.5.1 Tokenisation & Execution.
--------------------------------
Of course, whitespace, blank lines and #comment lines are handled in the
normal way.
As a script is parsed, each (multi) line in the script file is tokenised
and according to the quoting rules. After tokenisation, that line is
immedatly executed.
Multi line statements end with one or more "still-open" {curly-braces}
which - eventually - closes a few lines later.
24.5.2 Command Execution
------------------------
Remember earlier: There are no "control flow" statements in Tcl.
Instead there are COMMANDS that simply act like control flow operators.
Commands are executed like this:
1. Parse the next line into (argc) and (argv[]).
2. Look up (argv[0]) in a table and call its function.
3. Repeat until End Of File.
It sort of works like this:
for(;;){
ReadAndParse( &argc, &argv );
cmdPtr = LookupCommand( argv[0] );
(*cmdPtr->Execute)( argc, argv );
}
When the command "proc" is parsed (which creates a procedure function)
it gets 3 parameters on the command line. 1 the name of the proc
(function), 2 the list of parameters, and 3 the body of the function.
Not the choice of words: LIST and BODY. The PROC command stores these
items in a table somewhere so it can be found by "LookupCommand()"
24.5.3 The FOR command
----------------------
The most interesting command to look at is the FOR command. In Tcl, the
FOR command is normally implemented in C. Remember, FOR is a command
just like any other command.
When the ascii text containing the FOR command is parsed, the parser
produces 5 parameter strings, (If in doubt: Refer to Rule #1) they are:
0. The ascii text 'for'
1. The start text
2. The test expression
3. The next text
4. The body text
Sort of reminds you of "main( int argc, char **argv )" does it not?
Remember Rule #1 - Everything is a string. The key point is this: Often
many of those parameters are in {curly-braces} - thus the variables
inside are not expanded or replaced until later.
Remember that every Tcl command looks like the classic "main( argc, argv
)" function in C. In JimTCL - they actually look like this:
int
MyCommand( Jim_Interp *interp,
int *argc,
Jim_Obj * const *argvs );
Real Tcl is nearly identical. Although the newer versions have
introduced a byte-code parser and intepreter, but at the core, it still
operates in the same basic way.
24.5.4 FOR command implementation
---------------------------------
To understand Tcl it is perhaps most helpful to see the FOR command.
Remember, it is a COMMAND not a control flow structure.
In Tcl there are two underlying C helper functions.
Remember Rule #1 - You are a string.
The first helper parses and executes commands found in an ascii string.
Commands can be seperated by semicolons, or newlines. While parsing,
variables are expanded via the quoting rules.
The second helper evaluates an ascii string as a numerical expression
and returns a value.
Here is an example of how the FOR command could be implemented. The
pseudo code below does not show error handling.
void Execute_AsciiString( void *interp, const char *string );
int Evaluate_AsciiExpression( void *interp, const char *string );
int
MyForCommand( void *interp,
int argc,
char **argv )
{
if( argc != 5 ){
SetResult( interp, "WRONG number of parameters");
return ERROR;
}
// argv[0] = the ascii string just like C
// Execute the start statement.
Execute_AsciiString( interp, argv[1] );
// Top of loop test
for(;;){
i = Evaluate_AsciiExpression(interp, argv[2]);
if( i == 0 )
break;
// Execute the body
Execute_AsciiString( interp, argv[3] );
// Execute the LOOP part
Execute_AsciiString( interp, argv[4] );
}
// Return no error
SetResult( interp, "" );
return SUCCESS;
}
Every other command IF, WHILE, FORMAT, PUTS, EXPR, everything works in
the same basic way.
24.6 OpenOCD Tcl Usage
======================
24.6.1 source and find commands
-------------------------------
Where: In many configuration files
Example: source [find FILENAME]
Remember the parsing rules
1. The 'find' command is in square brackets, and is executed with the
parameter FILENAME. It should find and return the full path to a
file with that name; it uses an internal search path. The RESULT
is a string, which is substituted into the command line in place of
the bracketed 'find' command. (Don't try to use a FILENAME which
includes the "#" character. That character begins Tcl comments.)
2. The 'source' command is executed with the resulting filename; it
reads a file and executes as a script.
24.6.2 format command
---------------------
Where: Generally occurs in numerous places.
Tcl has no command like printf(), instead it has format, which is really
more like sprintf(). Example
set x 6
set y 7
puts [format "The answer: %d" [expr $x * $y]]
1. The SET command creates 2 variables, X and Y.
2. The double [nested] EXPR command performs math
The EXPR command produces numerical result as a string.
Refer to Rule #1
3. The format command is executed, producing a single string
Refer to Rule #1.
4. The PUTS command outputs the text.
24.6.3 Body or Inlined Text
---------------------------
Where: Various TARGET scripts.
#1 Good
proc someproc {} {
... multiple lines of stuff ...
}
$_TARGETNAME configure -event FOO someproc
#2 Good - no variables
$_TARGETNAME confgure -event foo "this ; that;"
#3 Good Curly Braces
$_TARGETNAME configure -event FOO {
puts "Time: [date]"
}
#4 DANGER DANGER DANGER
$_TARGETNAME configure -event foo "puts \"Time: [date]\""
1. The $_TARGETNAME is an OpenOCD variable convention.
$_TARGETNAME represents the last target created, the value changes
each time a new target is created. Remember the parsing rules.
When the ascii text is parsed, the $_TARGETNAME becomes a simple
string, the name of the target which happens to be a TARGET
(object) command.
2. The 2nd parameter to the '-event' parameter is a TCBODY
There are 4 examples:
1. The TCLBODY is a simple string that happens to be a proc name
2. The TCLBODY is several simple commands seperated by semicolons
3. The TCLBODY is a multi-line {curly-brace} quoted string
4. The TCLBODY is a string with variables that get expanded.
In the end, when the target event FOO occurs the TCLBODY is
evaluated. Method #1 and #2 are functionally identical. For
Method #3 and #4 it is more interesting. What is the TCLBODY?
Remember the parsing rules. In case #3, {curly-braces} mean the
$VARS and [square-brackets] are expanded later, when the EVENT
occurs, and the text is evaluated. In case #4, they are replaced
before the "Target Object Command" is executed. This occurs at the
same time $_TARGETNAME is replaced. In case #4 the date will never
change. {BTW: [date] is a bad example; at this writing,
Jim/OpenOCD does not have a date command}
24.6.4 Global Variables
-----------------------
Where: You might discover this when writing your own procs
In simple terms: Inside a PROC, if you need to access a global variable
you must say so. See also "upvar". Example:
proc myproc { } {
set y 0 #Local variable Y
global x #Global variable X
puts [format "X=%d, Y=%d" $x $y]
}
24.7 Other Tcl Hacks
====================
Dynamic variable creation
# Dynamically create a bunch of variables.
for { set x 0 } { $x < 32 } { set x [expr $x + 1]} {
# Create var name
set vn [format "BIT%d" $x]
# Make it a global
global $vn
# Set it.
set $vn [expr (1 << $x)]
}
Dynamic proc/command creation
# One "X" function - 5 uart functions.
foreach who {A B C D E}
proc [format "show_uart%c" $who] { } "show_UARTx $who"
}

File: openocd.info, Node: License, Next: OpenOCD Concept Index, Prev: Tcl Crash Course, Up: Top
Appendix A The GNU Free Documentation License.
**********************************************
Version 1.2, November 2002
Copyright (C) 2000,2001,2002 Free Software Foundation, Inc.
51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
Everyone is permitted to copy and distribute verbatim copies
of this license document, but changing it is not allowed.
0. PREAMBLE
The purpose of this License is to make a manual, textbook, or other
functional and useful document "free" in the sense of freedom: to
assure everyone the effective freedom to copy and redistribute it,
with or without modifying it, either commercially or
noncommercially. Secondarily, this License preserves for the
author and publisher a way to get credit for their work, while not
being considered responsible for modifications made by others.
This License is a kind of "copyleft", which means that derivative
works of the document must themselves be free in the same sense.
It complements the GNU General Public License, which is a copyleft
license designed for free software.
We have designed this License in order to use it for manuals for
free software, because free software needs free documentation: a
free program should come with manuals providing the same freedoms
that the software does. But this License is not limited to
software manuals; it can be used for any textual work, regardless
of subject matter or whether it is published as a printed book. We
recommend this License principally for works whose purpose is
instruction or reference.
1. APPLICABILITY AND DEFINITIONS
This License applies to any manual or other work, in any medium,
that contains a notice placed by the copyright holder saying it can
be distributed under the terms of this License. Such a notice
grants a world-wide, royalty-free license, unlimited in duration,
to use that work under the conditions stated herein. The
"Document", below, refers to any such manual or work. Any member
of the public is a licensee, and is addressed as "you". You accept
the license if you copy, modify or distribute the work in a way
requiring permission under copyright law.
A "Modified Version" of the Document means any work containing the
Document or a portion of it, either copied verbatim, or with
modifications and/or translated into another language.
A "Secondary Section" is a named appendix or a front-matter section
of the Document that deals exclusively with the relationship of the
publishers or authors of the Document to the Document's overall
subject (or to related matters) and contains nothing that could
fall directly within that overall subject. (Thus, if the Document
is in part a textbook of mathematics, a Secondary Section may not
explain any mathematics.) The relationship could be a matter of
historical connection with the subject or with related matters, or
of legal, commercial, philosophical, ethical or political position
regarding them.
The "Invariant Sections" are certain Secondary Sections whose
titles are designated, as being those of Invariant Sections, in the
notice that says that the Document is released under this License.
If a section does not fit the above definition of Secondary then it
is not allowed to be designated as Invariant. The Document may
contain zero Invariant Sections. If the Document does not identify
any Invariant Sections then there are none.
The "Cover Texts" are certain short passages of text that are
listed, as Front-Cover Texts or Back-Cover Texts, in the notice
that says that the Document is released under this License. A
Front-Cover Text may be at most 5 words, and a Back-Cover Text may
be at most 25 words.
A "Transparent" copy of the Document means a machine-readable copy,
represented in a format whose specification is available to the
general public, that is suitable for revising the document
straightforwardly with generic text editors or (for images composed
of pixels) generic paint programs or (for drawings) some widely
available drawing editor, and that is suitable for input to text
formatters or for automatic translation to a variety of formats
suitable for input to text formatters. A copy made in an otherwise
Transparent file format whose markup, or absence of markup, has
been arranged to thwart or discourage subsequent modification by
readers is not Transparent. An image format is not Transparent if
used for any substantial amount of text. A copy that is not
"Transparent" is called "Opaque".
Examples of suitable formats for Transparent copies include plain
ASCII without markup, Texinfo input format, LaTeX input format,
SGML or XML using a publicly available DTD, and standard-conforming
simple HTML, PostScript or PDF designed for human modification.
Examples of transparent image formats include PNG, XCF and JPG.
Opaque formats include proprietary formats that can be read and
edited only by proprietary word processors, SGML or XML for which
the DTD and/or processing tools are not generally available, and
the machine-generated HTML, PostScript or PDF produced by some word
processors for output purposes only.
The "Title Page" means, for a printed book, the title page itself,
plus such following pages as are needed to hold, legibly, the
material this License requires to appear in the title page. For
works in formats which do not have any title page as such, "Title
Page" means the text near the most prominent appearance of the
work's title, preceding the beginning of the body of the text.
A section "Entitled XYZ" means a named subunit of the Document
whose title either is precisely XYZ or contains XYZ in parentheses
following text that translates XYZ in another language. (Here XYZ
stands for a specific section name mentioned below, such as
"Acknowledgements", "Dedications", "Endorsements", or "History".)
To "Preserve the Title" of such a section when you modify the
Document means that it remains a section "Entitled XYZ" according
to this definition.
The Document may include Warranty Disclaimers next to the notice
which states that this License applies to the Document. These
Warranty Disclaimers are considered to be included by reference in
this License, but only as regards disclaiming warranties: any other
implication that these Warranty Disclaimers may have is void and
has no effect on the meaning of this License.
2. VERBATIM COPYING
You may copy and distribute the Document in any medium, either
commercially or noncommercially, provided that this License, the
copyright notices, and the license notice saying this License
applies to the Document are reproduced in all copies, and that you
add no other conditions whatsoever to those of this License. You
may not use technical measures to obstruct or control the reading
or further copying of the copies you make or distribute. However,
you may accept compensation in exchange for copies. If you
distribute a large enough number of copies you must also follow the
conditions in section 3.
You may also lend copies, under the same conditions stated above,
and you may publicly display copies.
3. COPYING IN QUANTITY
If you publish printed copies (or copies in media that commonly
have printed covers) of the Document, numbering more than 100, and
the Document's license notice requires Cover Texts, you must
enclose the copies in covers that carry, clearly and legibly, all
these Cover Texts: Front-Cover Texts on the front cover, and
Back-Cover Texts on the back cover. Both covers must also clearly
and legibly identify you as the publisher of these copies. The
front cover must present the full title with all words of the title
equally prominent and visible. You may add other material on the
covers in addition. Copying with changes limited to the covers, as
long as they preserve the title of the Document and satisfy these
conditions, can be treated as verbatim copying in other respects.
If the required texts for either cover are too voluminous to fit
legibly, you should put the first ones listed (as many as fit
reasonably) on the actual cover, and continue the rest onto
adjacent pages.
If you publish or distribute Opaque copies of the Document
numbering more than 100, you must either include a machine-readable
Transparent copy along with each Opaque copy, or state in or with
each Opaque copy a computer-network location from which the general
network-using public has access to download using public-standard
network protocols a complete Transparent copy of the Document, free
of added material. If you use the latter option, you must take
reasonably prudent steps, when you begin distribution of Opaque
copies in quantity, to ensure that this Transparent copy will
remain thus accessible at the stated location until at least one
year after the last time you distribute an Opaque copy (directly or
through your agents or retailers) of that edition to the public.
It is requested, but not required, that you contact the authors of
the Document well before redistributing any large number of copies,
to give them a chance to provide you with an updated version of the
Document.
4. MODIFICATIONS
You may copy and distribute a Modified Version of the Document
under the conditions of sections 2 and 3 above, provided that you
release the Modified Version under precisely this License, with the
Modified Version filling the role of the Document, thus licensing
distribution and modification of the Modified Version to whoever
possesses a copy of it. In addition, you must do these things in
the Modified Version:
A. Use in the Title Page (and on the covers, if any) a title
distinct from that of the Document, and from those of previous
versions (which should, if there were any, be listed in the
History section of the Document). You may use the same title
as a previous version if the original publisher of that
version gives permission.
B. List on the Title Page, as authors, one or more persons or
entities responsible for authorship of the modifications in
the Modified Version, together with at least five of the
principal authors of the Document (all of its principal
authors, if it has fewer than five), unless they release you
from this requirement.
C. State on the Title page the name of the publisher of the
Modified Version, as the publisher.
D. Preserve all the copyright notices of the Document.
E. Add an appropriate copyright notice for your modifications
adjacent to the other copyright notices.
F. Include, immediately after the copyright notices, a license
notice giving the public permission to use the Modified
Version under the terms of this License, in the form shown in
the Addendum below.
G. Preserve in that license notice the full lists of Invariant
Sections and required Cover Texts given in the Document's
license notice.
H. Include an unaltered copy of this License.
I. Preserve the section Entitled "History", Preserve its Title,
and add to it an item stating at least the title, year, new
authors, and publisher of the Modified Version as given on the
Title Page. If there is no section Entitled "History" in the
Document, create one stating the title, year, authors, and
publisher of the Document as given on its Title Page, then add
an item describing the Modified Version as stated in the
previous sentence.
J. Preserve the network location, if any, given in the Document
for public access to a Transparent copy of the Document, and
likewise the network locations given in the Document for
previous versions it was based on. These may be placed in the
"History" section. You may omit a network location for a work
that was published at least four years before the Document
itself, or if the original publisher of the version it refers
to gives permission.
K. For any section Entitled "Acknowledgements" or "Dedications",
Preserve the Title of the section, and preserve in the section
all the substance and tone of each of the contributor
acknowledgements and/or dedications given therein.
L. Preserve all the Invariant Sections of the Document, unaltered
in their text and in their titles. Section numbers or the
equivalent are not considered part of the section titles.
M. Delete any section Entitled "Endorsements". Such a section
may not be included in the Modified Version.
N. Do not retitle any existing section to be Entitled
"Endorsements" or to conflict in title with any Invariant
Section.
O. Preserve any Warranty Disclaimers.
If the Modified Version includes new front-matter sections or
appendices that qualify as Secondary Sections and contain no
material copied from the Document, you may at your option designate
some or all of these sections as invariant. To do this, add their
titles to the list of Invariant Sections in the Modified Version's
license notice. These titles must be distinct from any other
section titles.
You may add a section Entitled "Endorsements", provided it contains
nothing but endorsements of your Modified Version by various
parties--for example, statements of peer review or that the text
has been approved by an organization as the authoritative
definition of a standard.
You may add a passage of up to five words as a Front-Cover Text,
and a passage of up to 25 words as a Back-Cover Text, to the end of
the list of Cover Texts in the Modified Version. Only one passage
of Front-Cover Text and one of Back-Cover Text may be added by (or
through arrangements made by) any one entity. If the Document
already includes a cover text for the same cover, previously added
by you or by arrangement made by the same entity you are acting on
behalf of, you may not add another; but you may replace the old
one, on explicit permission from the previous publisher that added
the old one.
The author(s) and publisher(s) of the Document do not by this
License give permission to use their names for publicity for or to
assert or imply endorsement of any Modified Version.
5. COMBINING DOCUMENTS
You may combine the Document with other documents released under
this License, under the terms defined in section 4 above for
modified versions, provided that you include in the combination all
of the Invariant Sections of all of the original documents,
unmodified, and list them all as Invariant Sections of your
combined work in its license notice, and that you preserve all
their Warranty Disclaimers.
The combined work need only contain one copy of this License, and
multiple identical Invariant Sections may be replaced with a single
copy. If there are multiple Invariant Sections with the same name
but different contents, make the title of each such section unique
by adding at the end of it, in parentheses, the name of the
original author or publisher of that section if known, or else a
unique number. Make the same adjustment to the section titles in
the list of Invariant Sections in the license notice of the
combined work.
In the combination, you must combine any sections Entitled
"History" in the various original documents, forming one section
Entitled "History"; likewise combine any sections Entitled
"Acknowledgements", and any sections Entitled "Dedications". You
must delete all sections Entitled "Endorsements."
6. COLLECTIONS OF DOCUMENTS
You may make a collection consisting of the Document and other
documents released under this License, and replace the individual
copies of this License in the various documents with a single copy
that is included in the collection, provided that you follow the
rules of this License for verbatim copying of each of the documents
in all other respects.
You may extract a single document from such a collection, and
distribute it individually under this License, provided you insert
a copy of this License into the extracted document, and follow this
License in all other respects regarding verbatim copying of that
document.
7. AGGREGATION WITH INDEPENDENT WORKS
A compilation of the Document or its derivatives with other
separate and independent documents or works, in or on a volume of a
storage or distribution medium, is called an "aggregate" if the
copyright resulting from the compilation is not used to limit the
legal rights of the compilation's users beyond what the individual
works permit. When the Document is included in an aggregate, this
License does not apply to the other works in the aggregate which
are not themselves derivative works of the Document.
If the Cover Text requirement of section 3 is applicable to these
copies of the Document, then if the Document is less than one half
of the entire aggregate, the Document's Cover Texts may be placed
on covers that bracket the Document within the aggregate, or the
electronic equivalent of covers if the Document is in electronic
form. Otherwise they must appear on printed covers that bracket
the whole aggregate.
8. TRANSLATION
Translation is considered a kind of modification, so you may
distribute translations of the Document under the terms of section
4. Replacing Invariant Sections with translations requires special
permission from their copyright holders, but you may include
translations of some or all Invariant Sections in addition to the
original versions of these Invariant Sections. You may include a
translation of this License, and all the license notices in the
Document, and any Warranty Disclaimers, provided that you also
include the original English version of this License and the
original versions of those notices and disclaimers. In case of a
disagreement between the translation and the original version of
this License or a notice or disclaimer, the original version will
prevail.
If a section in the Document is Entitled "Acknowledgements",
"Dedications", or "History", the requirement (section 4) to
Preserve its Title (section 1) will typically require changing the
actual title.
9. TERMINATION
You may not copy, modify, sublicense, or distribute the Document
except as expressly provided for under this License. Any other
attempt to copy, modify, sublicense or distribute the Document is
void, and will automatically terminate your rights under this
License. However, parties who have received copies, or rights,
from you under this License will not have their licenses terminated
so long as such parties remain in full compliance.
10. FUTURE REVISIONS OF THIS LICENSE
The Free Software Foundation may publish new, revised versions of
the GNU Free Documentation License from time to time. Such new
versions will be similar in spirit to the present version, but may
differ in detail to address new problems or concerns. See
<http://www.gnu.org/copyleft/>.
Each version of the License is given a distinguishing version
number. If the Document specifies that a particular numbered
version of this License "or any later version" applies to it, you
have the option of following the terms and conditions either of
that specified version or of any later version that has been
published (not as a draft) by the Free Software Foundation. If the
Document does not specify a version number of this License, you may
choose any version ever published (not as a draft) by the Free
Software Foundation.
ADDENDUM: How to use this License for your documents
====================================================
To use this License in a document you have written, include a copy of
the License in the document and put the following copyright and license
notices just after the title page:
Copyright (C) YEAR YOUR NAME.
Permission is granted to copy, distribute and/or modify this document
under the terms of the GNU Free Documentation License, Version 1.2
or any later version published by the Free Software Foundation;
with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
Texts. A copy of the license is included in the section entitled ``GNU
Free Documentation License''.
If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts,
replace the "with...Texts." line with this:
with the Invariant Sections being LIST THEIR TITLES, with
the Front-Cover Texts being LIST, and with the Back-Cover Texts
being LIST.
If you have Invariant Sections without Cover Texts, or some other
combination of the three, merge those two alternatives to suit the
situation.
If your document contains nontrivial examples of program code, we
recommend releasing these examples in parallel under your choice of free
software license, such as the GNU General Public License, to permit
their use in free software.

File: openocd.info, Node: OpenOCD Concept Index, Next: Command and Driver Index, Prev: License, Up: Top
OpenOCD Concept Index
*********************
[index]
* Menu:
* about: About. (line 6)
* adaptive clocking: Debug Adapter Configuration.
(line 661)
* adaptive clocking <1>: FAQ. (line 6)
* Architecture Specific Commands: Architecture and Core Commands.
(line 6)
* ARM: Architecture and Core Commands.
(line 244)
* ARM semihosting: OpenOCD Project Setup.
(line 313)
* ARM semihosting <1>: Architecture and Core Commands.
(line 285)
* ARM11: Architecture and Core Commands.
(line 585)
* ARM7: Architecture and Core Commands.
(line 305)
* ARM720T: Architecture and Core Commands.
(line 343)
* ARM9: Architecture and Core Commands.
(line 305)
* ARM9 <1>: Architecture and Core Commands.
(line 359)
* ARM920T: Architecture and Core Commands.
(line 379)
* ARM926ej-s: Architecture and Core Commands.
(line 414)
* ARM966E: Architecture and Core Commands.
(line 428)
* ARMv4: Architecture and Core Commands.
(line 298)
* ARMv5: Architecture and Core Commands.
(line 298)
* ARMv6: Architecture and Core Commands.
(line 581)
* ARMv7: Architecture and Core Commands.
(line 618)
* at91sam3: Flash Commands. (line 290)
* at91sam4: Flash Commands. (line 345)
* autoprobe: TAP Declaration. (line 316)
* board config file: Config File Guidelines.
(line 256)
* breakpoint: General Commands. (line 309)
* CFI: Flash Commands. (line 210)
* command line options: Running. (line 6)
* commands: General Commands. (line 6)
* Common Flash Interface: Flash Commands. (line 210)
* config command: Daemon Configuration.
(line 13)
* config file, board: Config File Guidelines.
(line 256)
* config file, interface: Debug Adapter Configuration.
(line 6)
* config file, overview: OpenOCD Project Setup.
(line 138)
* config file, target: Config File Guidelines.
(line 483)
* config file, user: OpenOCD Project Setup.
(line 138)
* configuration stage: Daemon Configuration.
(line 13)
* Connecting to GDB: GDB and OpenOCD. (line 27)
* Core Specific Commands: Architecture and Core Commands.
(line 6)
* Cortex-M: Architecture and Core Commands.
(line 653)
* CPU type: CPU Configuration. (line 82)
* CPU variant: CPU Configuration. (line 82)
* DAP: Architecture and Core Commands.
(line 622)
* DCC: Architecture and Core Commands.
(line 321)
* DCC <1>: Architecture and Core Commands.
(line 703)
* Debug Access Port: Architecture and Core Commands.
(line 622)
* developers: Developers. (line 6)
* directory search: Running. (line 6)
* disassemble: Architecture and Core Commands.
(line 255)
* dongles: Debug Adapter Hardware.
(line 6)
* dotted name: TAP Declaration. (line 97)
* ETB: Architecture and Core Commands.
(line 14)
* ETM: Architecture and Core Commands.
(line 14)
* event, reset-init: Config File Guidelines.
(line 372)
* events: Reset Configuration. (line 226)
* events <1>: TAP Declaration. (line 215)
* events <2>: CPU Configuration. (line 363)
* faq: FAQ. (line 6)
* flash configuration: Flash Commands. (line 36)
* flash erasing: Flash Commands. (line 87)
* flash programming: Flash Commands. (line 87)
* flash protection: Flash Commands. (line 178)
* flash reading: Flash Commands. (line 87)
* flash writing: Flash Commands. (line 87)
* FPGA: PLD/FPGA Commands. (line 6)
* FTDI: Debug Adapter Hardware.
(line 6)
* GDB: Daemon Configuration.
(line 131)
* GDB <1>: GDB and OpenOCD. (line 6)
* GDB configuration: Daemon Configuration.
(line 131)
* GDB server: Daemon Configuration.
(line 91)
* GDB target: CPU Configuration. (line 6)
* halt: General Commands. (line 77)
* image dumping: General Commands. (line 261)
* image loading: General Commands. (line 261)
* initialization: Daemon Configuration.
(line 6)
* init_board procedure: Config File Guidelines.
(line 437)
* init_targets procedure: Config File Guidelines.
(line 706)
* interface config file: Debug Adapter Configuration.
(line 6)
* Jim-Tcl: About Jim-Tcl. (line 6)
* jrc: TAP Declaration. (line 253)
* JTAG: About. (line 15)
* JTAG <1>: Debug Adapter Configuration.
(line 580)
* JTAG autoprobe: TAP Declaration. (line 316)
* JTAG Commands: JTAG Commands. (line 6)
* JTAG Route Controller: TAP Declaration. (line 253)
* libdcc: Architecture and Core Commands.
(line 703)
* Linux-ARM DCC support: Architecture and Core Commands.
(line 703)
* logfile: Running. (line 6)
* lpcspifi: Flash Commands. (line 241)
* memory access: General Commands. (line 228)
* message level: General Commands. (line 54)
* mFlash commands: Flash Commands. (line 839)
* mFlash Configuration: Flash Commands. (line 823)
* NAND: NAND Flash Commands. (line 6)
* NAND configuration: NAND Flash Commands. (line 61)
* NAND erasing: NAND Flash Commands. (line 141)
* NAND other commands: NAND Flash Commands. (line 232)
* NAND programming: NAND Flash Commands. (line 141)
* NAND programming <1>: NAND Flash Commands. (line 154)
* NAND programming <2>: NAND Flash Commands. (line 207)
* NAND reading: NAND Flash Commands. (line 108)
* NAND verification: NAND Flash Commands. (line 207)
* NAND writing: NAND Flash Commands. (line 154)
* NXP SPI Flash Interface: Flash Commands. (line 241)
* object command: CPU Configuration. (line 257)
* PLD: PLD/FPGA Commands. (line 6)
* port: Daemon Configuration.
(line 81)
* printer port: Debug Adapter Hardware.
(line 6)
* profiling: General Commands. (line 341)
* Programming using GDB: GDB and OpenOCD. (line 126)
* reset: General Commands. (line 77)
* Reset Configuration: Reset Configuration. (line 6)
* reset-init handler: Config File Guidelines.
(line 372)
* RTCK: Debug Adapter Hardware.
(line 6)
* RTCK <1>: Debug Adapter Configuration.
(line 661)
* RTCK <2>: FAQ. (line 6)
* scan chain: TAP Declaration. (line 28)
* security: Daemon Configuration.
(line 81)
* Serial Peripheral Interface: Debug Adapter Configuration.
(line 604)
* Serial Vector Format: Boundary Scan Commands.
(line 13)
* Serial Wire Debug: Debug Adapter Configuration.
(line 589)
* server: Daemon Configuration.
(line 81)
* SMI: Flash Commands. (line 258)
* SMP: Config File Guidelines.
(line 610)
* SMP <1>: GDB and OpenOCD. (line 164)
* SPI: Debug Adapter Configuration.
(line 604)
* SPIFI: Flash Commands. (line 241)
* STMicroelectronics Serial Memory Interface: Flash Commands. (line 258)
* stmsmi: Flash Commands. (line 258)
* str9xpec: Flash Commands. (line 741)
* SVF: Boundary Scan Commands.
(line 13)
* SWD: Debug Adapter Configuration.
(line 589)
* TAP: About. (line 15)
* TAP configuration: TAP Declaration. (line 6)
* TAP declaration: TAP Declaration. (line 6)
* TAP events: TAP Declaration. (line 215)
* TAP naming convention: TAP Declaration. (line 128)
* TAP state names: JTAG Commands. (line 142)
* target config file: Config File Guidelines.
(line 483)
* target events: CPU Configuration. (line 363)
* target initialization: General Commands. (line 77)
* target type: CPU Configuration. (line 82)
* target, current: CPU Configuration. (line 18)
* target, list: CPU Configuration. (line 18)
* tcl: About Jim-Tcl. (line 6)
* Tcl: Tcl Crash Course. (line 6)
* Tcl Scripting API: Tcl Scripting API. (line 6)
* Tcl scripts: Tcl Scripting API. (line 5)
* TCP port: Daemon Configuration.
(line 81)
* TFTP: TFTP. (line 6)
* tracing: Architecture and Core Commands.
(line 14)
* tracing <1>: Architecture and Core Commands.
(line 703)
* translation: Config File Guidelines.
(line 787)
* Transport: Debug Adapter Configuration.
(line 563)
* USB Adapter: Debug Adapter Hardware.
(line 6)
* user config file: OpenOCD Project Setup.
(line 138)
* variable names: Config File Guidelines.
(line 340)
* vector_catch: OpenOCD Project Setup.
(line 212)
* vector_catch <1>: Architecture and Core Commands.
(line 364)
* vector_catch <2>: Architecture and Core Commands.
(line 554)
* vector_catch <3>: Architecture and Core Commands.
(line 607)
* vector_catch <4>: Architecture and Core Commands.
(line 672)
* vector_table: Architecture and Core Commands.
(line 569)
* watchpoint: General Commands. (line 309)
* wiggler: Debug Adapter Hardware.
(line 6)
* Xilinx Serial Vector Format: Boundary Scan Commands.
(line 25)
* XScale: Architecture and Core Commands.
(line 442)
* XSVF: Boundary Scan Commands.
(line 25)
* zy1000: Debug Adapter Hardware.
(line 6)

File: openocd.info, Node: Command and Driver Index, Prev: OpenOCD Concept Index, Up: Top
Command and Driver Index
************************
[index]
* Menu:
* $target_name arp_examine: CPU Configuration. (line 282)
* $target_name arp_halt: CPU Configuration. (line 283)
* $target_name arp_poll: CPU Configuration. (line 284)
* $target_name arp_reset: CPU Configuration. (line 285)
* $target_name arp_waitstate: CPU Configuration. (line 286)
* $target_name array2mem: CPU Configuration. (line 291)
* $target_name cget: CPU Configuration. (line 309)
* $target_name configure: CPU Configuration. (line 206)
* $target_name curstate: CPU Configuration. (line 332)
* $target_name eventlist: CPU Configuration. (line 337)
* $target_name invoke-event: CPU Configuration. (line 341)
* $target_name mdb: CPU Configuration. (line 348)
* $target_name mdh: CPU Configuration. (line 347)
* $target_name mdw: CPU Configuration. (line 346)
* $target_name mem2array: CPU Configuration. (line 292)
* $target_name mwb: CPU Configuration. (line 356)
* $target_name mwh: CPU Configuration. (line 355)
* $target_name mww: CPU Configuration. (line 354)
* adapter_khz: Debug Adapter Configuration.
(line 644)
* adapter_name: Debug Adapter Configuration.
(line 54)
* adapter_nsrst_assert_width: Reset Configuration. (line 121)
* adapter_nsrst_delay: Reset Configuration. (line 126)
* add_script_search_dir: General Commands. (line 71)
* aduc702x: Flash Commands. (line 280)
* amt_jtagaccel: Debug Adapter Configuration.
(line 63)
* append_file: General Commands. (line 189)
* arm core_state: Architecture and Core Commands.
(line 248)
* arm disassemble: Architecture and Core Commands.
(line 254)
* arm mcr: Architecture and Core Commands.
(line 268)
* arm mrc: Architecture and Core Commands.
(line 274)
* arm reg: Architecture and Core Commands.
(line 280)
* arm semihosting: Architecture and Core Commands.
(line 284)
* arm-jtag-ew: Debug Adapter Configuration.
(line 76)
* arm11 memwrite burst: Architecture and Core Commands.
(line 585)
* arm11 memwrite error_fatal: Architecture and Core Commands.
(line 595)
* arm11 step_irq_enable: Architecture and Core Commands.
(line 601)
* arm11 vcr: Architecture and Core Commands.
(line 606)
* arm720t cp15: Architecture and Core Commands.
(line 348)
* arm7_9 dbgrq: Architecture and Core Commands.
(line 310)
* arm7_9 dcc_downloads: Architecture and Core Commands.
(line 320)
* arm7_9 fast_memory_access: Architecture and Core Commands.
(line 331)
* arm9 vector_catch: Architecture and Core Commands.
(line 363)
* arm920t cache_info: Architecture and Core Commands.
(line 384)
* arm920t cp15: Architecture and Core Commands.
(line 389)
* arm920t cp15i: Architecture and Core Commands.
(line 395)
* arm920t read_cache: Architecture and Core Commands.
(line 405)
* arm920t read_mmu: Architecture and Core Commands.
(line 408)
* arm926ejs cache_info: Architecture and Core Commands.
(line 422)
* arm966e cp15: Architecture and Core Commands.
(line 432)
* armjtagew_info: Debug Adapter Configuration.
(line 80)
* at91rm9200: Debug Adapter Configuration.
(line 83)
* at91sam3: Flash Commands. (line 289)
* at91sam3 gpnvm: Flash Commands. (line 321)
* at91sam3 gpnvm clear: Flash Commands. (line 322)
* at91sam3 gpnvm set: Flash Commands. (line 323)
* at91sam3 gpnvm show: Flash Commands. (line 324)
* at91sam3 info: Flash Commands. (line 330)
* at91sam3 slowclk: Flash Commands. (line 340)
* at91sam4: Flash Commands. (line 344)
* at91sam7: Flash Commands. (line 349)
* at91sam7 gpnvm: Flash Commands. (line 382)
* at91sam9: NAND Flash Commands. (line 273)
* at91sam9 ale: NAND Flash Commands. (line 287)
* at91sam9 ce: NAND Flash Commands. (line 298)
* at91sam9 cle: NAND Flash Commands. (line 284)
* at91sam9 rdy_busy: NAND Flash Commands. (line 293)
* avr: Flash Commands. (line 390)
* bp: General Commands. (line 313)
* cat: General Commands. (line 194)
* cfi: Flash Commands. (line 209)
* cortex_m maskisr: Architecture and Core Commands.
(line 653)
* cortex_m reset_config: Architecture and Core Commands.
(line 687)
* cortex_m vector_catch: Architecture and Core Commands.
(line 671)
* cp: General Commands. (line 197)
* dap apcsw: Architecture and Core Commands.
(line 646)
* dap apid: Architecture and Core Commands.
(line 626)
* dap apsel: Architecture and Core Commands.
(line 630)
* dap baseaddr: Architecture and Core Commands.
(line 633)
* dap info: Architecture and Core Commands.
(line 637)
* dap memaccess: Architecture and Core Commands.
(line 641)
* davinci: NAND Flash Commands. (line 304)
* debug_level: General Commands. (line 53)
* drscan: JTAG Commands. (line 42)
* dummy: Debug Adapter Configuration.
(line 87)
* dummy <1>: Architecture and Core Commands.
(line 190)
* dump_image: General Commands. (line 261)
* echo: General Commands. (line 62)
* efm32: Flash Commands. (line 394)
* ep93xx: Debug Adapter Configuration.
(line 90)
* etb: Architecture and Core Commands.
(line 198)
* etb config: Architecture and Core Commands.
(line 201)
* etb trigger_percent: Architecture and Core Commands.
(line 204)
* etm analyze: Architecture and Core Commands.
(line 166)
* etm config: Architecture and Core Commands.
(line 63)
* etm dump: Architecture and Core Commands.
(line 170)
* etm image: Architecture and Core Commands.
(line 173)
* etm info: Architecture and Core Commands.
(line 89)
* etm load: Architecture and Core Commands.
(line 176)
* etm start: Architecture and Core Commands.
(line 179)
* etm status: Architecture and Core Commands.
(line 95)
* etm stop: Architecture and Core Commands.
(line 182)
* etm tracemode: Architecture and Core Commands.
(line 100)
* etm trigger_debug: Architecture and Core Commands.
(line 119)
* etm_dummy config: Architecture and Core Commands.
(line 195)
* exit: General Commands. (line 30)
* fast_load: General Commands. (line 265)
* fast_load_image: General Commands. (line 269)
* flash bank: Flash Commands. (line 36)
* flash banks: Flash Commands. (line 67)
* flash erase_address: Flash Commands. (line 120)
* flash erase_check: Flash Commands. (line 178)
* flash erase_sector: Flash Commands. (line 114)
* flash fillb: Flash Commands. (line 133)
* flash fillh: Flash Commands. (line 132)
* flash fillw: Flash Commands. (line 131)
* flash info: Flash Commands. (line 182)
* flash list: Flash Commands. (line 72)
* flash probe: Flash Commands. (line 77)
* flash protect: Flash Commands. (line 187)
* flash write_bank: Flash Commands. (line 143)
* flash write_image: Flash Commands. (line 148)
* flush_count: JTAG Commands. (line 70)
* fm3: Flash Commands. (line 729)
* ft2232: Debug Adapter Configuration.
(line 94)
* ft2232_channel: Debug Adapter Configuration.
(line 171)
* ft2232_device_desc: Debug Adapter Configuration.
(line 104)
* ft2232_latency: Debug Adapter Configuration.
(line 160)
* ft2232_layout: Debug Adapter Configuration.
(line 118)
* ft2232_serial: Debug Adapter Configuration.
(line 110)
* ft2232_vid_pid: Debug Adapter Configuration.
(line 154)
* ftdi: Debug Adapter Configuration.
(line 183)
* ftdi_channel: Debug Adapter Configuration.
(line 241)
* ftdi_device_desc: Debug Adapter Configuration.
(line 228)
* ftdi_layout_init: Debug Adapter Configuration.
(line 246)
* ftdi_layout_signal: Debug Adapter Configuration.
(line 256)
* ftdi_serial: Debug Adapter Configuration.
(line 233)
* ftdi_set_signal: Debug Adapter Configuration.
(line 285)
* ftdi_vid_pid: Debug Adapter Configuration.
(line 222)
* gdb_breakpoint_override: Daemon Configuration.
(line 136)
* gdb_flash_program: Daemon Configuration.
(line 143)
* gdb_memory_map: Daemon Configuration.
(line 147)
* gdb_port: Daemon Configuration.
(line 90)
* gdb_report_data_abort: Daemon Configuration.
(line 155)
* gw16012: Debug Adapter Configuration.
(line 355)
* halt: General Commands. (line 115)
* help: General Commands. (line 33)
* hla: Debug Adapter Configuration.
(line 522)
* hla_device_desc: Debug Adapter Configuration.
(line 529)
* hla_layout: Debug Adapter Configuration.
(line 535)
* hla_serial: Debug Adapter Configuration.
(line 532)
* hla_vid_pid: Debug Adapter Configuration.
(line 538)
* init: Daemon Configuration.
(line 47)
* init_reset: Reset Configuration. (line 257)
* interface: Debug Adapter Configuration.
(line 42)
* interface transports: Debug Adapter Configuration.
(line 48)
* interface_list: Debug Adapter Configuration.
(line 45)
* ip: General Commands. (line 200)
* irscan: JTAG Commands. (line 81)
* jlink: Debug Adapter Configuration.
(line 365)
* jlink caps: Debug Adapter Configuration.
(line 382)
* jlink config: Debug Adapter Configuration.
(line 390)
* jlink config ip: Debug Adapter Configuration.
(line 398)
* jlink config kickstart: Debug Adapter Configuration.
(line 392)
* jlink config mac_address: Debug Adapter Configuration.
(line 395)
* jlink config reset: Debug Adapter Configuration.
(line 405)
* jlink config save: Debug Adapter Configuration.
(line 407)
* jlink config usb_address: Debug Adapter Configuration.
(line 402)
* jlink hw_jtag: Debug Adapter Configuration.
(line 387)
* jlink info: Debug Adapter Configuration.
(line 384)
* jlink pid: Debug Adapter Configuration.
(line 410)
* jtag arp_init: Reset Configuration. (line 275)
* jtag arp_init-reset: Reset Configuration. (line 285)
* jtag cget: TAP Declaration. (line 201)
* jtag configure: TAP Declaration. (line 202)
* jtag names: TAP Declaration. (line 80)
* jtag newtap: TAP Declaration. (line 120)
* jtag tapdisable: TAP Declaration. (line 296)
* jtag tapenable: TAP Declaration. (line 301)
* jtag tapisenabled: TAP Declaration. (line 306)
* jtag_init: Daemon Configuration.
(line 65)
* jtag_ntrst_assert_width: Reset Configuration. (line 133)
* jtag_ntrst_delay: Reset Configuration. (line 138)
* jtag_rclk: Debug Adapter Configuration.
(line 660)
* jtag_reset: JTAG Commands. (line 98)
* load_image: General Commands. (line 280)
* log_output: General Commands. (line 67)
* lpc2000: Flash Commands. (line 403)
* lpc2000 part_id: Flash Commands. (line 438)
* lpc288x: Flash Commands. (line 442)
* lpc2900: Flash Commands. (line 450)
* lpc2900 password: Flash Commands. (line 506)
* lpc2900 read_custom: Flash Commands. (line 495)
* lpc2900 secure_jtag: Flash Commands. (line 541)
* lpc2900 secure_sector: Flash Commands. (line 527)
* lpc2900 signature: Flash Commands. (line 486)
* lpc2900 write_custom: Flash Commands. (line 516)
* lpc3180: NAND Flash Commands. (line 317)
* lpc3180 select: NAND Flash Commands. (line 320)
* lpcspifi: Flash Commands. (line 240)
* ls: General Commands. (line 203)
* mac: General Commands. (line 206)
* mdb: General Commands. (line 240)
* mdh: General Commands. (line 239)
* mdw: General Commands. (line 238)
* meminfo: General Commands. (line 209)
* mflash bank: Flash Commands. (line 823)
* mflash config boot: Flash Commands. (line 846)
* mflash config pll: Flash Commands. (line 839)
* mflash config storage: Flash Commands. (line 850)
* mflash dump: Flash Commands. (line 854)
* mflash probe: Flash Commands. (line 858)
* mflash write: Flash Commands. (line 861)
* mwb: General Commands. (line 251)
* mwh: General Commands. (line 250)
* mww: General Commands. (line 249)
* mx3: NAND Flash Commands. (line 330)
* mxc: NAND Flash Commands. (line 334)
* mxc biswap: NAND Flash Commands. (line 342)
* nand check_bad_blocks: NAND Flash Commands. (line 232)
* nand device: NAND Flash Commands. (line 64)
* nand dump: NAND Flash Commands. (line 107)
* nand erase: NAND Flash Commands. (line 140)
* nand info: NAND Flash Commands. (line 244)
* nand list: NAND Flash Commands. (line 87)
* nand probe: NAND Flash Commands. (line 97)
* nand raw_access: NAND Flash Commands. (line 249)
* nand verify: NAND Flash Commands. (line 206)
* nand write: NAND Flash Commands. (line 153)
* ocl: Flash Commands. (line 548)
* oocd_trace: Architecture and Core Commands.
(line 222)
* oocd_trace config: Architecture and Core Commands.
(line 231)
* oocd_trace resync: Architecture and Core Commands.
(line 235)
* oocd_trace status: Architecture and Core Commands.
(line 238)
* opendous: Debug Adapter Configuration.
(line 545)
* orion: NAND Flash Commands. (line 346)
* parport: Debug Adapter Configuration.
(line 414)
* parport_cable: Debug Adapter Configuration.
(line 420)
* parport_port: Debug Adapter Configuration.
(line 68)
* parport_port <1>: Debug Adapter Configuration.
(line 359)
* parport_port <2>: Debug Adapter Configuration.
(line 449)
* parport_toggling_time: Debug Adapter Configuration.
(line 459)
* parport_write_on_exit: Debug Adapter Configuration.
(line 493)
* pathmove: JTAG Commands. (line 115)
* peek: General Commands. (line 213)
* pic32mx: Flash Commands. (line 553)
* pic32mx pgm_word: Flash Commands. (line 561)
* pic32mx unlock: Flash Commands. (line 564)
* pld device: PLD/FPGA Commands. (line 23)
* pld devices: PLD/FPGA Commands. (line 28)
* pld load: PLD/FPGA Commands. (line 31)
* poke: General Commands. (line 216)
* poll: Daemon Configuration.
(line 195)
* power: Debug Adapter Configuration.
(line 557)
* presto: Debug Adapter Configuration.
(line 505)
* presto_serial: Debug Adapter Configuration.
(line 507)
* profile: General Commands. (line 341)
* program: Flash Commands. (line 194)
* rbp: General Commands. (line 323)
* reg: General Commands. (line 83)
* remote_bitbang: Debug Adapter Configuration.
(line 294)
* remote_bitbang_host: Debug Adapter Configuration.
(line 306)
* remote_bitbang_port: Debug Adapter Configuration.
(line 302)
* reset: General Commands. (line 154)
* reset halt: General Commands. (line 156)
* reset init: General Commands. (line 157)
* reset run: General Commands. (line 155)
* reset_config: Reset Configuration. (line 143)
* resume: General Commands. (line 145)
* rlink: Debug Adapter Configuration.
(line 510)
* rm: General Commands. (line 219)
* rtck: Debug Adapter Configuration.
(line 72)
* runtest: JTAG Commands. (line 123)
* rwp: General Commands. (line 326)
* s3c2410: NAND Flash Commands. (line 354)
* s3c2412: NAND Flash Commands. (line 355)
* s3c2440: NAND Flash Commands. (line 356)
* s3c2443: NAND Flash Commands. (line 357)
* s3c6400: NAND Flash Commands. (line 358)
* scan_chain: TAP Declaration. (line 88)
* shutdown: General Commands. (line 49)
* sleep: General Commands. (line 43)
* soft_reset_halt: General Commands. (line 172)
* stellaris: Flash Commands. (line 568)
* stellaris recover bank_id: Flash Commands. (line 577)
* step: General Commands. (line 150)
* stlink_api: Debug Adapter Configuration.
(line 541)
* stm32f1x: Flash Commands. (line 590)
* stm32f1x lock: Flash Commands. (line 611)
* stm32f1x options_read: Flash Commands. (line 619)
* stm32f1x options_write: Flash Commands. (line 624)
* stm32f1x unlock: Flash Commands. (line 615)
* stm32f2x: Flash Commands. (line 629)
* stm32f2x lock: Flash Commands. (line 644)
* stm32f2x unlock: Flash Commands. (line 648)
* stm32lx: Flash Commands. (line 652)
* stmsmi: Flash Commands. (line 257)
* str7x: Flash Commands. (line 664)
* str7x disable_jtag: Flash Commands. (line 672)
* str9x: Flash Commands. (line 676)
* str9x flash_config: Flash Commands. (line 685)
* str9xpec: Flash Commands. (line 774)
* str9xpec disable_turbo: Flash Commands. (line 782)
* str9xpec enable_turbo: Flash Commands. (line 785)
* str9xpec lock: Flash Commands. (line 789)
* str9xpec options_cmap: Flash Commands. (line 796)
* str9xpec options_lvdsel: Flash Commands. (line 799)
* str9xpec options_lvdthd: Flash Commands. (line 802)
* str9xpec options_lvdwarn: Flash Commands. (line 805)
* str9xpec options_read: Flash Commands. (line 808)
* str9xpec options_write: Flash Commands. (line 811)
* str9xpec part_id: Flash Commands. (line 793)
* str9xpec unlock: Flash Commands. (line 814)
* svf: Boundary Scan Commands.
(line 17)
* swd newdap: Debug Adapter Configuration.
(line 594)
* swd wcr trn prescale: Debug Adapter Configuration.
(line 597)
* target count: CPU Configuration. (line 37)
* target create: CPU Configuration. (line 183)
* target current: CPU Configuration. (line 50)
* target names: CPU Configuration. (line 53)
* target number: CPU Configuration. (line 59)
* target types: CPU Configuration. (line 99)
* targets: CPU Configuration. (line 68)
* target_request debugmsgs: Architecture and Core Commands.
(line 742)
* tcl_port: Daemon Configuration.
(line 114)
* telnet_port: Daemon Configuration.
(line 121)
* test_image: General Commands. (line 294)
* tms470: Flash Commands. (line 694)
* tms470 flash_keyset: Flash Commands. (line 701)
* tms470 osc_mhz: Flash Commands. (line 705)
* tms470 plldis: Flash Commands. (line 708)
* trace history: Architecture and Core Commands.
(line 752)
* trace point: Architecture and Core Commands.
(line 758)
* transport list: Debug Adapter Configuration.
(line 566)
* transport select: Debug Adapter Configuration.
(line 570)
* trunc: General Commands. (line 222)
* ulink: Debug Adapter Configuration.
(line 548)
* usbprog: Debug Adapter Configuration.
(line 513)
* usb_blaster: Debug Adapter Configuration.
(line 325)
* usb_blaster <1>: Debug Adapter Configuration.
(line 345)
* usb_blaster_device_desc: Debug Adapter Configuration.
(line 331)
* usb_blaster_vid_pid: Debug Adapter Configuration.
(line 337)
* verify_image: General Commands. (line 300)
* verify_ircapture: JTAG Commands. (line 128)
* verify_jtag: JTAG Commands. (line 134)
* version: General Commands. (line 346)
* virt2phys: General Commands. (line 349)
* virtex2: PLD/FPGA Commands. (line 42)
* virtex2 read_stat: PLD/FPGA Commands. (line 48)
* virtual: Flash Commands. (line 712)
* vsllink: Debug Adapter Configuration.
(line 516)
* wait_halt: General Commands. (line 116)
* wp: General Commands. (line 329)
* xscale analyze_trace: Architecture and Core Commands.
(line 514)
* xscale cache_clean_address: Architecture and Core Commands.
(line 517)
* xscale cache_info: Architecture and Core Commands.
(line 520)
* xscale cp15: Architecture and Core Commands.
(line 523)
* xscale dcache: Architecture and Core Commands.
(line 530)
* xscale debug_handler: Architecture and Core Commands.
(line 527)
* xscale dump_trace: Architecture and Core Commands.
(line 533)
* xscale icache: Architecture and Core Commands.
(line 536)
* xscale mmu: Architecture and Core Commands.
(line 539)
* xscale trace_buffer: Architecture and Core Commands.
(line 542)
* xscale trace_image: Architecture and Core Commands.
(line 547)
* xscale vector_catch: Architecture and Core Commands.
(line 553)
* xscale vector_table: Architecture and Core Commands.
(line 568)
* xsvf: Boundary Scan Commands.
(line 32)
* ZY1000: Debug Adapter Configuration.
(line 551)