General Debugger Commands¶
- help
displays built-in help in the console
- do
evaluates the given expression
- symlist
lists registered symbols
- softreset
executes a soft reset
- hardreset
executes a hard reset
prints one or more <item>s to the console
- printf
prints one or more <item>s to the console using <format>
- logerror
outputs one or more <item>s to the error.log
- tracelog
outputs one or more <item>s to the trace file using <format>
- tracesym
outputs one or more <item>s to the trace file
- history
displays recently visited PC addresses and opcodes
- trackpc
visually track visited opcodes
- trackmem
record which PC writes to each memory address
- pcatmem
query which PC wrote to a given memory address
- rewind
go back in time by loading the most recent rewind state
- statesave
save a state file for the emulated system
- stateload
load a state file for the emulated system
- snap
save a screen snapshot
- source
read commands from file and executes them one by one
- time
prints the current machine time to the console
- quit
exit the debugger and end the emulation session
help¶
help [<topic>]
Displays built-in debugger help in the debugger console. If no <topic> is specified, top-level topics are listed. Most debugger commands have correspondingly named help topics.
Examples:
help
Lists top-level help topics.
help expressions
Displays built-in help for debugger expression syntax.
help wpiset
Displays built-in help for the wpiset command.
Back to General Debugger Commands
do¶
do <expression>
The do command simply evaluates the supplied expression. This is often used to set or modify device state variable (e.g. CPU registers), or to write to memory. See Debugger expression syntax for details about expression syntax.
Examples:
do pc = 0
Sets the register pc to 0.
Back to General Debugger Commands
symlist¶
symlist [<cpu>]
Lists registered symbols and their values. If <cpu> is not specified, symbols in the global symbol table are displayed; otherwise, symbols specific to the device <cpu> are displayed. Symbols are listed alphabetically. Read-only symbols are noted. See Specifying devices and address spaces for details on how to specify a CPU.
Examples:
symlist
Displays the global symbol table.
symlist 2
Displays the symbols for the third CPU in the system (zero-based index).
symlist audiocpu
Displays symbols for the CPU with the absolute tag
:audiocpu
.
Back to General Debugger Commands
softreset¶
softreset
Executes a soft reset. This calls the reset member functions of all the devices in the system (by default, pressing F3 during emulation has the same effect).
Examples:
softreset
Executes a soft reset.
Back to General Debugger Commands
hardreset¶
hardreset
Executes a hard reset. This tears down the emulation session and starts another session with the same system and options (by default, pressing Shift+F3 during emulation has the same effect). Note that this will lose history in the debugger console and error log.
Examples:
hardreset
Executes a hard reset.
Back to General Debugger Commands
print¶
print <item>[,…]
The print command prints the results of one or more expressions to the debugger console as hexadecimal numbers.
Examples:
print pc
Prints the value of the pc register the console as a hex number.
print a,b,a+b
Prints a, b, and the value of a+b to the console as hex numbers.
Back to General Debugger Commands
printf¶
printf <format>[,<argument>[,…]]
Prints a C-style formatted message to the debugger console. Only a very limited subset of format specifiers and escape sequences are available:
- %c
Prints the corresponding argument as an 8-bit character.
- %[-][0][<n>]d
Prints the corresponding argument as a decimal number with optional left justification, zero fill and minimum field width.
- %[-][0][<n>]o
Prints the corresponding argument as an octal number with optional left justification, zero fill and minimum field width.
- %[-][0][<n>]x
Prints the corresponding argument as a lowercase hexadecimal number with optional left justification, zero fill and minimum field width.
- %[-][0][<n>]X
Prints the corresponding argument as an uppercase hexadecimal number with optional left justification, zero fill and minimum field width.
- %[-][<n>][.[<n>]]s
Prints a null-terminated string of 8-bit characters from the address and address space given by the corresponding argument, with optional left justification, minimum and maximum field widths.
- %%
Prints a literal percent symbol.
- \n
Prints a line break.
- \\
Prints a literal backslash.
All other format specifiers are ignored.
Examples:
printf "PC=%04X",pc
Prints
PC=<pcval>
where <pcval> is the hexadecimal value of the pc register with a minimum of four digits and zero fill.printf "A=%d, B=%d\\nC=%d",a,b,a+b
Prints
A=<aval>, B=<bval>
on one line, andC=<a+bval>
on a second line.
Back to General Debugger Commands
logerror¶
logerror <format>[,<argument>[,…]]
Prints a C-style formatted message to the error log. See printf for details about the limited set of supported format specifiers and escape sequences.
Examples:
logerror "PC=%04X",pc
Logs
PC=<pcval>
where <pcval> is the hexadecimal value of the pc register with a minimum of four digits and zero fill.logerror "A=%d, B=%d\\nC=%d",a,b,a+b
Logs
A=<aval>, B=<bval>
on one line, andC=<a+bval>
on a second line.
Back to General Debugger Commands
tracelog¶
tracelog <format>[,<argument>[,…]]
Prints a C-style formatted message to the currently open trace file (see trace for more information). If no trace file is open, this command has no effect. See printf for details about the limited set of supported format specifiers and escape sequences.
Examples:
tracelog "PC=%04X",pc
Outputs
PC=<pcval>
where <pcval> is the hexadecimal value of the pc register with a minimum of four digits and zero fill if a trace log file is open.tracelog "A=%d, B=%d\\nC=%d",a,b,a+b
Outputs
A=<aval>, B=<bval>
on one line, andC=<a+bval>
on a second line if a trace log file is open.
Back to General Debugger Commands
tracesym¶
tracesym <item>[,…]
Prints the specified symbols to the currently open trace file (see trace for more information). If no trace file is open, this command has no effect.
Examples:
tracesym pc
Outputs
PC=<pcval>
where <pcval> is the value of the pc register in its default format if a trace log file is open.
Back to General Debugger Commands
history¶
history [<CPU>[,<length>]]
Displays recently visited PC addresses, and disassembly of the instructions at those addresses. If present, the first argument selects the CPU (see Specifying devices and address spaces for details); if no CPU is specified, the visible CPU is assumed. The second argument, if present, limits the maximum number of addresses shown. Addresses are shown in order from least to most recently visited.
Examples:
history ,5
Displays up to five most recently visited PC addresses and instructions for the visible CPU.
history 3
Displays recently visited PC addresses and instructions for the fourth CPU in the system (zero-based index).
history audiocpu,1
Displays the most recently visited PC address and instruction for the CPU with the absolute tag
:audiocpu
.
trackpc¶
trackpc [<enable>[,<CPU>[,<clear>]]]
Turns visited PC address tracking for disassembly views on or off. Instructions at addresses visited while tracking is on are highlighted in debugger disassembly views. The first argument is a Boolean specifying whether tracking should be turned on or off (defaults to on). The second argument specifies the CPU to enable or disable tracking for (see Specifying devices and address spaces for details); if no CPU is specified, the visible CPU is assumed. The third argument is a Boolean specifying whether existing data should be cleared (defaults to false).
Examples:
trackpc 1
Begin or tracking the current CPU’s PC.
trackpc 1,0,1
Begin or continue tracking PC on the first CPU in the system (zero-based index), but clear the history tracked so far.
Back to General Debugger Commands
trackmem¶
trackmem [<enable>,[<CPU>,[<clear>]]]
Enables or disables logging the PC address each time a memory address is written to. The first argument is a Boolean specifying whether tracking should be enabled or disabled (defaults to enabled). The second argument specifies the CPU to enable or disable tracking for (see Specifying devices and address spaces for details); if no CPU is specified, the visible CPU is assumed. The third argument is a Boolean specifying whether existing data should be cleared (defaults to false).
Use pcatmem to retrieve this data. Right-clicking a debugger memory view will also display the logged PC value for the given address in some configurations.
Examples:
trackmem
Begin or continue tracking memory writes for the visible CPU.
trackmem 1,0,1
Begin or continue tracking memory writes for the first CPU in the system (zero-based index), but clear existing tracking data.
Back to General Debugger Commands
pcatmem¶
pcatmem[{d|i|o}] <address>[:<space>]
Returns the PC value at the time the specified address was most recently written to. The argument is the requested address, optionally followed by a colon and a CPU and/or address space (see Specifying devices and address spaces for details). The optional d, i or o suffix controls the default address space for the command.
Tracking must be enabled for the data this command uses to be recorded (see trackmem). Right-clicking a debugger memory view will also display the logged PC value for the given address in some configurations.
Examples:
pcatmem 400000
Print the PC value when location 400000 in the visible CPU’s program space was most recently written.
pcatmem 3bc:io
Print the PC value when location 3bc in the visible CPU’s
io
space was most recently written.pcatmem 1400:audiocpu
Print the PC value when location 1400 in the CPU
:audiocpu
’s program space was most recently written.
Back to General Debugger Commands
rewind¶
rewind
Loads the most recent RAM-based saved state. When enabled, rewind
states are saved when step,
over and out commands
are used, storing the machine state as of the moment before stepping.
May be abbreviated to rw
.
Consecutively loading rewind states can work like reverse execution. Depending on which steps forward were taken previously, the behavior can be similar to GDB's reverse-stepi and reverse-next commands. All output for this command is currently echoed into the running machine window.
Previous memory and PC tracking statistics are cleared. Actual reverse execution does not occur.
Examples:
rewind
Load the previous RAM-based save state.
rw
Abbreviated form of the command.
Back to General Debugger Commands
statesave¶
statesave <filename>
Creates a save state at the current moment in emulated time. The state
file is written to the configured save state directory (see the
state_directory option), and
the .sta extension is automatically appended to the specified file
name. May be abbreviates to ss
.
All output from this command is currently echoed into the running machine window.
Examples:
statesave foo
Saves the emulated machine state to the file foo.sta in the configured save state directory.
ss bar
Abbreviated form of the command – saves the emulated machine state to bar.sta.
Back to General Debugger Commands
stateload¶
stateload <filename>
Restores a saved state file from disk. The specified state file is read
from the configured save state directory (see the
state_directory option), and the
.sta extension is automatically appended to the specified file name.
May be abbreviated to sl
.
All output for this command is currently echoed into the running machine window. Previous memory and PC tracking statistics are cleared.
Examples:
stateload foo
Loads state from file foo.sta to the configured save state directory.
sl bar
Abbreviated form of the command – loads the file bar.sta.
Back to General Debugger Commands
snap¶
snap [<filename>[,<scrnum>]]
Takes a snapshot of the emulated video display and saves it to the configured snapshot directory (see the snapshot_directory option). If a file name is specified, a single screenshot for the specified screen is saved using the specified filename (or the first emulated screen in the system if a screen is not specified). If a file name is not specified, the configured snapshot view and file name pattern are used (see the snapview and snapname options).
If a file name is specified, the .png extension is automatically appended. The screen number is specified as a zero-based index, as seen in the names of automatically-generated single-screen views in MAME’s video options menus.
Examples:
snap
Takes a snapshot using the configured snapshot view and file name options.
snap shinobi
Takes a snapshot of the first emulated video screen and saves it as shinobi.png in the configured snapshot directory.
Back to General Debugger Commands
source¶
source <filename>
Reads the specified file in text mode and executes each line as a debugger command. This is similar to running a shell script or batch file.
Examples:
source break_and_trace.cmd
Reads and executes debugger commands from break_and_trace.cmd.
Back to General Debugger Commands
time¶
Prints the total elapsed emulated time to the debugger console.
Examples:
time
Prints the elapsed emulated time.
Back to General Debugger Commands
quit¶
quit
Closes the debugger and ends the emulation session immediately. Either exits MAME or returns to the system selection menu, depending on whether the system was specified on the command line when starting MAME.
Examples:
quit
Exits the emulation session immediately.
Back to General Debugger Commands