Mspdebug Launchpad
Mspdebug Launchpad
Mspdebug Launchpad
MSPDebug (here, debug for short) is a command-line tool, tive loop: it repeatedly prompts the user for a command,
designed and mantained by Daniel Beer, for programming which it then executes.
and debugging the msp430 family of microcontroller units Batch mode. A variant of the above command line has
(mcus). It supports a number of msp430 development tools the form
as well as a simulation mode. debug can also be used as mspdebug rf2500 commands
a remote stub (a software interface adapter) for gdb—the The commands that appear as arguments at the end of
multiplatform gnu debugger. this line are all executed by debug as a batch right after
debug belongs to a rich cultural environment and is well connecting to the LaunchPad, and then the progam exits—
supported. It works on Linux, Mac OS/X, and Windows. the interactive prompt never appears.
For downloading and documentation, see mspdebug.sourceforge. One of debug’s commands is read, which reads and exe-
net. Installation and configuration details may be found in
cutes commands, in a line-by-line fashion, from a given file;
mspdebug.sourceforge.net/faq.html.
in this way, a commonly used sequence of debug command
When started with appropriate options, debug attempts can be “canned” and then issued with a single command.
to connect to the target development hardware (such as On startup, debug will look for a file called .mspdebug in
a TI LaunchPad) and identify the device under test (the the user’s home directory. If this file exists, debug performs
mcu to be programmed and debugged); once connected, it a read on it before starting the interactive loop; in this
iteratively prompts for commands. There are commands for way, the command loop can be run within a customized
reflashing the device, inspecting and modifying memory and enviroment.
registers, and controlling the cpu (single step, run, stop, debug’s commands—which are its raison d’être—will
run to breakpoint, and reset and halt). be listed and described first, in §2. Insofar as they are
Besides dealing directly with machine language, debug of concern to the LaunchPad, options inserted between
has substantial high-level smarts. It can disassemble ma- the mspdebug command proper and the driver argument
chine code present in a given area of memory. When pro- rf2500 in the above command-line examples, as well as
vided with a symbol table (an assignment of meaningful driver arguments other than rf2500, mostly deal with set-
names to specific memory address and data values), it can and-forget parameters of a technical nature, and will dis-
make use of these names as convenient mnemonic han- cussed in later sections (§4 and §5).
dles for the values themselves, as well as deal with (under-
stand or generate) memory addresses and values expressed
in terms of such names. As mentioned, it can even run and 2 Commands
debug a program on a simulation of an msp430 mcu.
debug commands take arguments separated by spaces (an
This user guide is a reasoned and annotated expansion argument itself containing spaces must be enclosed in dou-
of debug’s man page. Our chief target audience is the TI ble quotation marks; within a quoted string, the usual C-
LaunchPad user. To avoid clutter, we only include discus- style backslash substitutions can be used). A numerical ar-
sion of command-line options and device options that con- gument may be given in the form of an address expression,
cern the LaunchPad, omitting information about oulandish as detailed in §2.2.
(and mostly obsolete) msp430 development hardware; for Any command can be specified by giving just enough of
those, please refer to debug’s official man page. the first few characters to make the specification unambigu-
ous. Some commands support automatic repeat; for these,
Enter at the prompt will cause repeat execution.
1 A bird’s eye view Some aspects of debug’s behaviour can be configured by
The operation of debug consists in processing a sequence setting global options, with the command opt.
of commands specific to it—which are listed and discussed Once a piece of machine code is loaded into a micro-
in the next section (§2). Command-line options and other computer’s memory, many of debug’s commands can make
device drivers are discussed in §4 and §5. good use of a symbol table which provides mnemonic han-
Interactive mode. For the LaunchPad, debug is typi- dles for numerical addresses and values which appear in
cally called from the command line as follows that code. These symbolic names may be introduced dur-
mspdebug rf2500 ing compilation/assembly by explicit define, set, equ, =
where rf2500 is the device driver to be used for the Launch- and similar directives, or simply in the form of instruction
Pad1 When launched in this way, debug enters an interac- labels. This human-readable information is of no use to the
1 Some recent versions of the LaunchPad—such as the MSP430
computer and may ultimately be discarded, but is invalu-
FR4133 LaunchPad Development Kit—use a different driver. This
able for debugging and may be retained in some form for
driver is available as a stopgap patch for the current version of de- this purpose by some of the binary output files produced
bug, but should appear as a standard feature in future releases. by the compilation/assembly, such as .elf and .hex files.
1
To be useable by debug, this mnemonic information has exit Exit from debug.
to be made available in the form of a symbol table (§2.1), gdb [port] Start a gdb remote stub, optionally specifying
which debug may at a later time augment or edit as de- a tcp port to listen on. If no port is given, the default port
sired, with the sym command and its subcommands. is 2000. debug will wait for a connection on this port, and
then act as a gdb remote stub until gdb disconnects.
List of commands gdb’s monitor command can be used to issue debug
commands via the gdb interface. Supplied commands are
= expression Evaluate an address expression and show executed noninteractively, and the output is sent back to
both its value and the result when that value is reverse be displayed by gdb.
looked up in the current symbol table. This result is of
the form symbol+offset, where symbol is the name of the help [command] Show a brief listing of available com-
nearest symbol not past the address in question. See §2.2 mands. If an argument is specified, show the syntax for the
for more information on the syntax of expressions. given command. The help text shown when no argument is
given is also shown by debug at start-up.
alias [name [command]] The alias command allows one
to use shortcuts for commonly used long commands. By it- hexout address length filename Read the specified mem-
self, alias show a list of defined command aliases. Followed ory range of the device and save it to an Intel hex file. The
by just a name, it removes a previously defined command address and length arguments may both be address expres-
alias having that name. sions. If the specified file already exists it will be overwrit-
With both the name and command arguments, it defines ten. If you need to dump memory from several disjoint
(or redefines) a command alias. The command text will memory regions you can do this by saving each section to a
be substituted for name when looking up commands. If the separate file. The resulting files can then be concatenated
command in this text is followed by arguments, then the en- to form a single valid hex file.
tire text must be wrapped in quotes when defining the alias. isearch address length [options . . . ] Search over the
To avoid alias substitution when interpreting commands, given memory range (from address for length) for an in-
prefix the command with “\” (a backslash character). struction which matches the specified search criteria. The
break Show a list of active breakpoints. Breakpoints can search may be narrowed by specifying one or more match
be added and removed with the setbreak and delbreak options, detailed in §2.3.
commands. Breakpoints are numbered starting from 0. load filename Program the device under test using the
Their maximum number depends on the target chip (and is binary file supplied. This command is like prog, but it does
reported by debug at start-up). not load symbols or erase the device before programming.
cgraph address length [address] Construct the call graph The cpu is reset and halted before and after programming.
of all functions contained or referenced in the given memory locka [set|clear] Show or change the status of the
range. If a particular function is specified, then details for locka bit in the chip’s memory controller. The locka bit
that node of the graph are displayed; otherwise, a summary is set on power-on reset (por) and acts as a write-protect
of all nodes is displayed. bit for info segment A, containing factory-configured cali-
Information from the symbol table is used for hinting at bration data which under normal circumstances should not
the possible locations of function starts. Any symbol which be changed; however, writing to info segment A becomes
does not contain a ‘.’ is considered a possible function start. possible if the locka bit is cleared. The locka bit affects
Caller and callee names are shown prefixed by a ‘*’ when in a similar way the behaviour of the erase all command:
their connection is a tail call (see en.wikepedia.org/wiki/Tail_call). if locka is set (this is the default setting), only main mem-
delbreak [index] Delete breakpoints. If an index is given, ory is erased; but if locka is cleared, both main and info
the selected breakpoint is deleted; otherwise, all break- memory are erased.
points are cleared. md address [length] (“memory display” or “memory
dis address [length] Dissassemble a section of memory. dump”) Read the specified section of device memory and
Both arguments may be address expressions. If no length display it as a canonical-style hex dump. Both arguments
is specified, a default length of 64 bytes is disassembled and may be address expressions. If no length is specified, a
shown. If symbols are available, then all addresses used as default-length (64 bytes) section is shown.
operands are translated into symbol+offset form. The output is split into three columns. The first column
This command supports repeat execution. If repeated, it shows the starting address for the line. The second column
continues to disassemble another block of memory following lists the hexadecimal values of the bytes. The final column
that last printed. shows the ascii characters corresponding to printable bytes,
erase [all|segment] [address] Erase the device under and ‘.’ for non-printing characters.
test. With no arguments, all code memory is erased (but This command supports repeat execution. If repeated, it
not information or boot memory). With the argument all, continues to print another block of memory following that
a mass erase is performed (the results may depend on the last printed.
state of the locka bit in the flash memory controller). To to erase individual small chunks of memory rather than erasing all code
erase an individual flash segment,2 specify segment and give memory or the whole chip including information and boot memory.
the segment’s starting address. Segment sizes vary from chip to chip; a typical size is 128 bytes. Note
that segment size for information memory may be different from that
2 Segments are the erase-unit size for flash memory when one wants of main memory.
2
mw address bytes . . . (“memory write”) Write a sequence setbreak address [index] Add a new breakpoint. The
of bytes at the given memory address. The address given breakpoint location is an address expression. An optional
may be an address expression. Byte values are two-digit index may be specified, indicating that this new breakpoint
hexadecimal numbers separated by spaces. should overwrite an existing slot. If no index is specified,
opt [name [value]] Query, set, or list debug’s global op- then the breakpoint will be stored in the next unused slot.
tions. With no arguments, this command displays all avail- simio subcommand [parameters] Through various sub-
able options. With just an option name as its argument, it commands, add, remove, or give info about peripherals im-
displays the current value of that option. The option names plemented by the simulator. The simulator and its subcom-
and their possible values are as follows: mands are described in §3.
step [count] Step the cpu through one or more instruc-
color [boolean] If true, debug will colorize debugging
tions. After stepping, the new register values are displayed
output.
together with a disassembly of the instruction at the address
gdb loop [boolean] Automatically restart the gdb server specified by the program counter.
after disconnection. If this option is set, then the gdb
An optional count can be given, to make debug step
server keeps running until an error occurs or the user
that many times. If no argument is given, the cpu steps
interrupts with Ctrl+C.
just once. This command supports repeat execution.
iradix [numeric] Default input radix (an integer greater
than 1) for address expressions. For address values sym operation Perform on the symbol table one of the
with no radix specifier, this value gives the input radix, following operations:
which is 10 (decimal) as initial default. (For iradix
clear Clear the symbol table, deleting all symbols.
values larger than sixteen, letters following f are used
in alphabetic order as additional digits past the ordi- set name value Set or alter the value of a symbol. The
nary sixteen hexadecimal digits.) value given may be an address expression.
quiet [boolean] If set, debug will suppress most of its del name Delete the given symbol from the symbol ta-
debug-related output. This option defaults to ‘false’, ble.
but can be set to ‘true’ on startup by the command-line import filename Load symbols from the specified file into
option -q . the symbol table. The file format will be auto-detected.
debug supports a number of commonly used symbol-
prog filename Erase and reprogram the device under test table styles, among which elf32, Intel hex, and bsd
using the binary file supplied. Supported file types are hex, (such as the output produced by nm(1) ).
TI-Text, srec, elf, S-19, and coff; the file format will import+ filename This command is similar to sym
be auto-detected. In the case of a file containing symbols, import, except that the symbol table is not cleared
symbols will be automatically loaded from the file into the first. In this way, symbols from multiple sources can
symbol table, discarding any pre-existing ones. The cpu is be combined.
reset and halted before and after programming. export filename Save to the given file all symbols cur-
Often prog is run as the only task of a debug batch run, rently defined. The symbols are saved as a bsd-style
as with the line mspdebug prog "proj.hex" , which simply burns symbol table. Note that symbol types are not stored
the machine-code memory image proj.hex of a developed by debug; all symbols are saved as type ‘t’ (denoting
project onto the mcu’s flash rom. “text,” as opposed to “data”).
read filename Read commands line-by-line from the given find [regex] Search for symbols. If a regular expression
file and process them in that order. (Any line whose first is given, then all symbols matching the expression are
non-space character is # is ignored.) If an error occurs while printed. If no expression is specified, then the entire
processing a command, the rest of the file is not processed. symbol table is listed.
regs Show the current value of all cpu registers in the rename regex string Rename symbols by searching for
device under test. those matching the given regular expression and substi-
tuting the given string for the matched portion. The
reset Reset (and halt) the cpu of the device under test. renamed symbols are displayed and their number re-
run Start running the cpu. The interactive command ported.
loop is blocked when the cpu is started and the prompt will
not appear again until the cpu halts. The cpu will halt if it
encounters a breakpoint or if Ctrl-C is pressed by the user.
2.1 Symbol table
After the cpu halts, the current register values are shown To preserve in the final elf file (the one containing the
together with a disassembly of the first few instructions at machine code image ready to be loaded into the micropro-
the address specified by the program counter. cessor’s rom, prom, or flash memory) the symbolic names
set register value Alter the value of a register. A register and associated values encountered in a compilation, the lat-
is specified as numbers from 0 through 15 . Any leading ter must be run with an appropriate option (e.g., -g in the
non-numeric characters are ignored (so a register may be gcc toolchain). To extract from a file base.elf the symbol
specified as, for example, R12 ). The value argument is an table in bsd format, use the Linux command
address expression. nm -a base.elf > base.bsd
3
(typically issued by Makefile). To import this table into list of recognized modes. This option implies that no-
debug, use the command sym import base.bsd . argument instructions are not matched. For single-
operand instructions, the operand is considered to be
the destination operand.
2.2 Address expressions
An address expression consists of an algebraic combination For the sake of expressing instruction mode in the above
of values. An address value may be either a symbol name, match options, the seven addressing modes used by the
a hex value preceeded by the specifier 0x , a decimal value msp430 are represented by single characters as follows:
preceeded by the specifier 0d , or a number in the default R Register mode
input radix, without a specifier (for more information on I Indexed mode
input radix, see the global option iradix in command opt). S Symbolic mode
The operators recognized are the usual algebraic opera- & Absolute mode
tors + - * / \ % ( ) . Operator precedence is the same as in @ Register-indirect mode
C-like languages, and the - operator may be used as a unary + Register-indirect mode with auto-increment
negation operator. The following are valid examples of ad- # Immediate mode
dress expressions
2+2 3 The msp430 simulator
table_start + (elem_size + elem_pad)*4
main+0x3f debug provides, as a virtual msp430 device, a simulation
__bss_end-__bss_start mode intended for testing changes to debug and for aiding
in the disassembly of msp430 binaries (as all binary and
symbol-table formats are still usable in this mode).
2.3 Match options
A 64k buffer is allocated to simulate the device mem-
Here is a list of match options that can be use to qualify ory. (While the instructions of the msp430X architecture
the scope of the isearch command. are recognized by the the disassembler, this architecture
is not currently simulated by debug.) During simulation,
opcode Match the specified opcode. Byte/word speci- addresses below 0200 are assumed to be i/o memory. Pro-
fiers are not recognised, as they are specified with other grammed i/o writes to and from i/o memory are handled by
options. the i/o simulator, described below, which can be configured
byte Match only byte operations. and controlled with the simio command.
word Match only word operations. For i/o memory locations not covered by simio com-
mands, the default behavior is as follows. When data is
aword Match only address-word (20-bit) operations,
written to an i/o memory address, a message is displayed
available in the msp430X (“eXtended”)architecture.
on the console showing the program counter location, ad-
jump Match only jump instructions (conditional and un- dress written to, and data. The data value is also written
conditional jumps, but not instructions such as br to simulated ram at the relevant address. When data is
which load the program counter explicitly). read from i/o memory, the user is notified similarly and
single Match only single-operand instructions. prompted to supply the data. At this prompt, address ex-
double Match only double-operand instructions. pressions can be entered. If no value is entered, the value
noarg Match only instructions with no arguments. is read from simulated ram. The user can press Ctrl+C to
src address Match instructions with the specified value abort an i/o request and stop execution.
in the source operand; this value may be given as an ad- The subcommands of the simio command are
dress expression. Specifying this option implies match- add class name [args . . . ] Add a new peripheral to
ing of only double-operand instructions. the i/o simulator. The class parameter may be any
dst address Match instructions with the specified value of the peripheral types named in the output of the
in the destination operand. This option implies that simio classes command. The name parameter is a
no-argument instructions are not matched. unique name assigned by the user to this peripheral
srcreg register Match instructions using the specified instance, and is used with other commands to refer to
register in the source operand. This option implies this instance of the peripheral.
matching of only double-operand instructions. Some peripheral classes take arguments upon creation.
dstreg register Match instructions using the specified These are documented in the output to the simio help
register in the destination operand. This option implies command.
that no-argument instructions are not matched. classes List the names of the different types of periph-
srcmode mode Match instructions using the specified erals which may be added to the simulator. You can
mode in the source operand. See below for a list of use the simio help command to obtain more informa-
modes recognised. This option implies matching of tion about each peripheral type.
only double-operand instructions. config name parameter [args . . . ] Configure or perform
dstmode mode Match instructions using the specified some action on a peripheral instance. The param argu-
mode in the destination operand. See below for a ment is specific to the peripheral type. A list of valid
4
configuration commands can be obtained by using the number of such registers may not be less than 2, or greater
simio help command. than 7. The i/o addresses and irqs used are config-
del name Remove a previously added peripheral in- urable. The default i/o addresses used are those specified
stance. The name argument should be the name of a for Timer A in the msp430 hardware documentation.
peripheral that was assigned with the simio add com-
base address Alter the base i/o address. By default, this
mand.
is 0x0160 . By setting this to 0x0180 , a Timer B module
devices List all peripheral instances currently attached may be simu- lated.
to the simulator, along with their types and interrupt
status. You can obtain more detailed information for irq0 number Set the TACCR 0 interrupt vector number. By
each instance with the simio info command. default, this is interrupt vector 9. This interrupt is
help class Obtain more information about a peripheral self-clearing, and higher priority than the TACCR 1/ TAIFG
class. The documentation given will list constructor vector.
arguments and configuration parameters for the device irq1 number Set the TACCR 1/ TAIFG interrupt vector. By
type. default, this is interrupt vector 8.
info name Display detailed status information for a par-
ticular peripheral. The type of information displayed iv address Alter the address of the interrupt vector regis-
is specific to each type of peripheral. ter. By default, this is 0x012e . By setting this to 0x011e ,
a Timer B module may be simulated.
3.1 Simulator’s IO subsystem set channel value When Timer A is used in capture
mode, the CCI bit in each capture register reflects the
The simulator’s IO subsystem consists of a database of de-
state of the corresponding input pin, and can’t be al-
vice classes, and a list of instances of those classes. Each
tered in software. This configuration command can be
device class has a different set of constructor arguments,
used to simulate changes in input pin state, and will
configuration parameters and information which may be
trigger the corresponding interrupts if the peripheral is
displayed. This section describes the operation of the avail-
so configured.
able device classes in detail.
In the list below, each device class is listed, followed by tracer history-size The tracer peripheral is a debugging
its constructor arguments. device. It can be used to investigate and record the i/o ac-
gpio Digital IO port simulator. This device simulates any tivity of a running program, to benchmark execution time,
of the digital ports with or without interrupt capability. It and to simulate interrupts. The information displayed by
has the following configuration parameters: the tracer gives a running count of clock cycles from each of
the system clocks, and an instruction count. A list of the n
base address Set the base address for this port. Note most recent i/o events is also displayed (this is configurable
that for ports without interrupt capability, the resistor via the history-size argument of the constructor). Each i/o
enable port has a special address which is computable event is timestamped by the number of MLCLK cycles that
from the base address. have elapsed since the last reset of the device’s counter.
irq vector Enable interrupt functionality for this port The i/o events that it records consist of programmed i/o
by specifying an interrupt vector number. reads and writes, interrupt acceptance, and system resets.
As well as keeping the i/o events in a rotating buffer, the
noirq Disable interrupt functionality for this port. tracer can be configured to display the events as they occur.
Note that since clock cycles don’t advance while the cpu
verbose Print a state change message every time the isn’t running, this peripheral can be used to calculate ex-
port output changes. ecution times for blocks of code. This can be achieved by
setting a breakpoint at the end of the code block, setting
quiet Don’t print anything when the port state changes
the program counter to the start of the code block, clearing
(the default).
the tracer and running the code. After the breakpoint is
set pin value Set the input pin state for the given pin reached, the information displayed by the tracer will con-
on this port. The pin parameter should be an index tain a count of MLCLK cycles elapsed during the last run.
between 0 and 7. The value should be either zero (for The configuration parameters for this device class are:
a low state) or non-zero (for a high state). verbose Start displaying i/o events as they occur, as well
as recording them in the rotating buffer.
hwmult This peripheral simulates the hardware multiplier.
It has no constructor or configuration parameters, and does quiet Stop displaying i/o events as they occur, and just
not provide any extended information. record them in the buffer.
timer size This peripheral simulates Timer A modules, trigger irq Signal an interrupt request to the cpu. This
and can be used to simulate Timer B modules provided request will remain raised until accepted by the cpu or
that the extended features aren’t required. The construc- cleared by the user.
tor takes a size argument specifying the number of cap-
ture/compare registers in this peripheral instance. The untrigger Clear a signalled interrupt request.
5
clear Reset the clock cycle and instruction counts to 0, 5 Drivers
and clear the i/o event history.
The driver used for the LaunchPad must appear in the
wdt This peripheral simulates the Watchdog Timer+, command line. For the LaunchPad, in (??) we call for the
which can be used in software either as a watchdog or as an rf2500 driver. Another driver of interest is that which uses
interval timer. It has no constructor arguments. The simu- as “hardware” a simulator of the msp430 architecture (§3).
lated state of the nmi/rst# pin can be controlled through a Drivers for other msp430 development hardware are not dis-
configuration parameter. Note that if this pin state is held cussed here.
low with the pin mode selected as a reset (the default), the
cpu will not run.
The extended information for this peripheral shows all 6 USB port
register states, including the hidden counter register. Con-
The usb port in which a LaunchPad may be plugged will
figuration parameters are:
be accessible to debug if the latter is run with root per-
nmi state Set the nmi/rst# pin state. The argument missions. However, if debug is run by a normal user, one
should be zero to indicate a low state or non-zero for a would typically get an error like
high state. Trying to open interface 1 on 007
rf2500: can't claim interface: Operation not permitted
irq irq Select the interrupt vector for interval timer That is, the user needs to be given permission to use the
mode. The default is to use interrupt vector 10. usb bus for the desired kind of device. For this purpose,
create in the folder /etc/udev/rules.d/ a Linux udev rule file
that will give to users belonging to a certain group—say,
Appendices plug—access to the usb port used by LaunchPad. This file
(which may be named, for instance, 91-msp430.rules (where
we used 91 for a number between 00 and 99 indicating in
4 Command-line options which order the file will be taken into consideration within
the folder) shall contain a line like
Most of these options have to do with configuring debug ATTRS{idVendor}=="0451",`ATTRS{idProduct}=="f432",MODE="0660",GROUP="plug"
for a particular development tool—especially arcane and
where the attributes idVendor and idProduct can be discovered
legacy ones. Here, we only discuss those options that are
through the lsusb command, which should print a line like
meaningful with the LaunchPad.
Bus 003 Device 007: ID 0451:f432 TI Inc. eZ430 Development Tool
-q Start in quiet mode (see global variable quiet in com- one of which shows 04b3 and 301b as respectively vendor and
mand opt). product of my LaunchPad. Then restart the udev service.
If during all this your usb tool is still plugged in, it has to
-U bus:device Specify a particular usb device to connect
be unplugged and plugged in afresh for the new udev rule
to (by default, the first usb device of the appropriate type
to take hold.
is opened). This option may become necessary if one has
Also insure that users are members of plug. After you
to choose among more LaunchPads plugged into the same
add a user to a group, the user will have to log out and then
host, or if during a computer session accidents cause a
log in again to enjoy the new membership without having
LaunchPad to be relocated to a different usb port than
to wait for a reboot.
the initial one (see end of §6).
Note that a group plug may not exist, or a user may not
-n Do not process the startup file ( ~/.mspdebug ). be member of it. Also, a user may not have permission to
--help Display a brief help message and exit. join that group or to create it if it does not exist. A sensible
--fet-list Display a list of msp430 devices supported policy is for the administrator to choose for GROUP in the
by the driver ( rf2500 ) used for the lauchpad. udev rule a group which the users are likely to already be
members of, such as the group users.
--fet-force-id string When using a fet device, force
the connected chip to be recognised by debug as one of the Occasionally, the usb slot in which debug automatically
given type during initialization; this overrides the device id discovered a LaunchPad is for some reason abandoned with-
returned by the fet. The given string should be a chip out closing it (e.g., faulty chip or LaunchPad—perhaps the
name in long form, for example “MSP430F2274.” LaunchPad misbehaved and debug had to be forcefully
--fet-skip-close When using a fet device, skip the aborted); in this case, on reinsertion of a LaunchPad, the
jtag close procedure when disconnecting. With some latter may turn out to have been have been assigned to a
boards, this removes the need to replug the debugger af- different usb slot while debug may still look for it at the
ter use. original usb address. The new bus:device address can be
found by mean of the Linux command lsusb and passed on
--usb-list List available usb devices and exit. to debug through the -U option (e.g., -U 0451:f432 ).
--force-reset When using an fet device, always send
a reset during initialization. By default, an initialization
without reset will be tried first.
--version Show version and copyright information.
6