Memory Debugger Commands¶
- dasm
disassemble code to a file
- find
search emulated memory for data
- fill
fill emulated memory with specified pattern
- dump
dump emulated memory to a file as text
- strdump
dump delimited strings from emulated memory to a file
- save
save binary data from emulated memory to a file
- saver
save binary data from a memory region to a file
- load
load binary data from a file to emulated memory
- loadr
load binary data from a file to a memory region
- map
map a logical address to the corresponding physical address and handler
- memdump
dump current memory maps to a file
dasm¶
dasm <filename>,<address>,<length>[,<opcodes>[,<CPU>]]
Disassembles program memory to the file specified by the <filename> parameter. The <address> parameter specifies the address to start disassembling from, and the <length> parameter specifies how much memory to disassemble. The range <address> through <address>+<length>-1, inclusive, will be disassembled to the file. By default, raw opcode data is output with each line. The optional <opcodes> parameter is a Boolean that enables disables this feature. By default, program memory for the visible CPU is disassembled. To disassemble program memory for a different CPU, specify it using the optional fifth parameter (see Specifying devices and address spaces for details).
Examples:
dasm venture.asm,0,10000
Disassembles addresses 0-ffff for the visible CPU, including raw opcode data, to the file venture.asm.
dasm harddriv.asm,3000,1000,0,2
Disassembles addresses 3000-3fff for the third CPU in the system (zero-based index), without raw opcode data, to the file harddriv.asm.
Back to Memory Debugger Commands
find¶
f[ind][{d|i|o}] <address>[:<space>],<length>[,<data>[,…]]
Search through memory for the specified sequence of data. The
<address> is the address to begin searching from, optionally
followed by a device and/or address space (see
Specifying devices and address spaces for details); the <length> specifies
how much memory to search. If an address space is not specified, the
command suffix sets the address space: find
defaults to the first
address space exposed by the device, findd
defaults to the space
with index 1 (data), findi
default to the space with index 2 (I/O),
and findo
defaults to the space with index 3 (opcodes).
The <data> can either be a quoted string, a numeric value or
expression, or the wildcard character ?
. By default, strings imply
a byte-sized search; by default non-string data is searched using the
native word size of the address space. To override the search size for
non-string data, you can prefix values with b.
to force byte-sized
search, w.
for word-sized search, d.
for double word-sized
search, and q.
for quadruple word-sized search. Overrides propagate
to subsequent values, so if you want to search for a sequence of words,
you need only prefix the first value with w.
. Also note that you
can intermix sizes to perform more complex searches.
The entire range <address> through <address>+<length>-1, inclusive, will be searched for the sequence, and all occurrences will be displayed.
Examples:
find 0,10000,"HIGH SCORE",0
Searches the address range 0-ffff in the program space of the visible CPU for the string “HIGH SCORE” followed by a 0 byte.
find 300:tms9918a,100,w.abcd,4567
Searches the address range 300-3ff in the first address space exposed by the device with the absolute tag
:tms9918a
for the word-sized value abcd followed by the word-sized value 4567.find 0,8000,"AAR",d.0,"BEN",w.0
Searches the address range 0000-7fff for the string “AAR” followed by a dword-sized 0 followed by the string “BEN”, followed by a word-sized 0.
Back to Memory Debugger Commands
fill¶
fill[{d|i|o}] <address>[:<space>],<length>[,<data>[,…]]
Overwrite a block of memory with copies of the supplied data sequence.
The <address> specifies the address to begin writing at, optionally
followed by a device and/or address space (see
Specifying devices and address spaces for details); the <length> specifies how
much memory to fill. If an address space is not specified, the command
suffix sets the address space: fill
defaults to the first
address space exposed by the device, filld
defaults to the space
with index 1 (data), filli
default to the space with index 2 (I/O),
and fillo
defaults to the space with index 3 (opcodes).
The <data> can either be a quoted string, or a numeric value or
expression. By default, non-string data is written using the native
word size of the address space. To override the data size for non-string
data, you can prefix values with b.
to force byte-sized fill, w.
for word-sized fill, d.
for double word-sized fill, and q.
for
quadruple word-sized fill. Overrides propagate to subsequent values, so
if you want to fill with a series of words, you need only prefix the
first value with w.
. Also note that you can intermix sizes to
perform more complex fills. The fill operation may be truncated if a
page fault occurs or if part of the sequence or string would fall beyond
<address>+<length>-1.
Back to Memory Debugger Commands
dump¶
dump[{d|i|o}] <filename>,<address>[:<space>],<length>[,<group>[,<ascii>[,<rowsize>]]]
Dump memory to the text file specified by the <filename> parameter.
The <address> specifies the address to start dumping from,
optionally followed by a device and/or address space (see
Specifying devices and address spaces for details); the <length> specifies how
much memory to dump. If an address space is not specified, the command
suffix sets the address space: dump
defaults to the first
address space exposed by the device, dumpd
defaults to the space
with index 1 (data), dumpi
default to the space with index 2 (I/O),
and dumpo
defaults to the space with index 3 (opcodes).
The range <address> through <address>+<length>-1, inclusive, will be output to the file. By default, the data will be output using the native word size of the address space. You can override this by specifying the <group> parameter, which can be used to group the data in 1-, 2-, 4- or 8-byte chunks. The optional <ascii> parameter is a Boolean value used to enable or disable output of ASCII characters on the right of each line (enabled by default). The optional <rowsize> parameter specifies the amount of data on each line in address units (defaults to 16 bytes).
Examples:
dump venture.dmp,0,10000
Dumps addresses 0-ffff from the program space of the visible CPU in 1-byte chunks, including ASCII data, to the file venture.dmp.
dumpd harddriv.dmp,3000:3,1000,4,0
Dumps data memory addresses 3000-3fff from the fourth CPU in the system (zero-based index) in 4-byte chunks, without ASCII data, to the file harddriv.dmp.
dump vram.dmp,0:sms_vdp:videoram,4000,1,false,8
Dumps
videoram
space addresses 0000-3fff from the device with the absolute tag path:sms_vdp
in 1-byte chunks, without ASCII data, with 8 bytes per line, to the file vram.dmp.
Back to Memory Debugger Commands
strdump¶
strdump[{d|i|o}] <filename>,<address>[:<space>],<length>[,<term>]
Dump memory to the text file specified by the <filename> parameter.
The <address> specifies the address to start dumping from,
optionally followed by a device and/or address space (see
Specifying devices and address spaces for details); the <length> specifies how
much memory to dump. If an address space is not specified, the command
suffix sets the address space: strdump
defaults to the first
address space exposed by the device, strdumpd
defaults to the space
with index 1 (data), strdumpi
default to the space with index 2
(I/O), and strdumpo
defaults to the space with index 3 (opcodes).
By default, the data will be interpreted as a series of NUL-terminated (ASCIIZ) strings, the dump will have one string per line, and C-style escapes sequences will be used for bytes that do not represent printable ASCII characters. The optional <term> parameter can be used to specify a different string terminator character.
Back to Memory Debugger Commands
save¶
save[{d|i|o}] <filename>,<address>[:<space>],<length>
Save raw memory to the binary file specified by the <filename>
parameter. The <address> specifies the address to start saving
from, optionally followed by a device and/or address space (see
Specifying devices and address spaces for details); the <length> specifies how
much memory to save. If an address space is not specified, the command
suffix sets the address space: save
defaults to the first address
space exposed by the device, saved
defaults to the space with index
1 (data), savei
default to the space with index 2 (I/O), and
saveo
defaults to the space with index 3 (opcodes).
The range <address> through <address>+<length>-1, inclusive, will be output to the file.
Examples:
save venture.bin,0,10000
Saves addresses 0-ffff from the program space of the current CPU to the binary file venture.bin
saved harddriv.bin,3000:3,1000
Saves data memory addresses 3000-3fff from the fourth CPU in the system (zero-based index) to the binary file harddriv.bin.
save vram.bin,0:sms_vdp:videoram,4000
Saves
videoram
space addresses 0000-3fff from the device with the absolute tag path:sms_vdp
to the binary file vram.bin.
Back to Memory Debugger Commands
saver¶
saver <filename>,<address>,<length>,<region>
Save raw content of memory region specified by the <region> parameter to the binary file specified by the <filename> parameter. Regions tags follow the same rules as device tags (see Specifying devices and address spaces). The <address> specifies the address to start saving from, and the <length> specifies how much memory to save. The range <address> through <address>+<length>-1, inclusive, will be output to the file.
Examples:
saver data.bin,200,100,:monitor
Saves
:monitor
region addresses 200-2ff to the binary file data.bin.saver cpurom.bin,1000,400,.
Saves addresses 1000-13ff from the memory region with the same tag as the visible CPU to the binary file cpurom.bin.
Back to Memory Debugger Commands
load¶
load[{d|i|o}] <filename>,<address>[:<space>][,<length>]
Load raw memory from the binary file specified by the <filename>
parameter. The <address> specifies the address to start loading to,
optionally followed by a device and/or address space (see
Specifying devices and address spaces for details); the <length> specifies how
much memory to load. If an address space is not specified, the command
suffix sets the address space: load
defaults to the first address
space exposed by the device, loadd
defaults to the space with index
1 (data), loadi
default to the space with index 2 (I/O), and
loado
defaults to the space with index 3 (opcodes).
The range <address> through <address>+<length>-1, inclusive, will be read in from the file. If the <length> is omitted, if it is zero, or if it is greater than the total length of the file, the entire contents of the file will be loaded but no more.
Note that this has the same effect as writing to the address space from
a debugger memory view, or using the b@
, w@
, d@
or q@
memory accessors in debugger expressions. Read-only memory will not be
overwritten, and writing to I/O addresses may have effects beyond
setting register values.
Examples:
load venture.bin,0,10000
Loads addresses 0-ffff in the program space for the visible CPU from the binary file venture.bin.
loadd harddriv.bin,3000,1000,3
Loads data memory addresses 3000-3fff in the program space for the fourth CPU in the system (zero-based index) from the binary file harddriv.bin.
load vram.bin,0:sms_vdp:videoram
Loads the
videoram
space for the device with the absolute tag path:sms_vdp
starting at address 0000 with the entire content of the binary file vram.bin.
Back to Memory Debugger Commands
loadr¶
loadr <filename>,<address>,<length>,<region>
Load memory in the memory region specified by the <region> with raw data from the binary file specified by the <filename> parameter. Regions tags follow the same rules as device tags (see Specifying devices and address spaces). The <address> specifies the address to start loading to, and the <length> specifies how much memory to load. The range <address> through <address>+<length>-1, inclusive, will be read in from the file. If the <length> is zero, or is greater than the total length of the file, the entire contents of the file will be loaded but no more.
Examples:
loadr data.bin,200,100,:monitor
Loads
:monitor
region addresses 200-2ff from the binary file data.bin.loadr cpurom.bin,1000,400,.
Loads addresses 1000-13ff in the memory region with the same tag as the visible CPU from the binary file cpurom.bin.
Back to Memory Debugger Commands
map¶
map[{d|i|o}] <address>[:<space>]
Map a logical memory address to the corresponding physical address, as
well as reporting the handler name. The address may optionally be
followed by a colon and device and/or address space (see
Specifying devices and address spaces for details). If an address space is not
specified, the command suffix sets the address space: map
defaults
to the first address space exposed by the device, mapd
defaults to
the space with index 1 (data), mapi
default to the space with index
2 (I/O), and mapo
defaults to the space with index 3 (opcodes).
Examples:
map 152d0
Gives the physical address and handler name for logical address 152d0 in program memory for the visible CPU.
map 107:sms_vdp
Gives the physical address and handler name for logical address 107 in the first address space for the device with the absolute tag path
:sms_vdp
.
Back to Memory Debugger Commands
memdump¶
memdump [<filename>,[<device>]]
Dumps the current memory maps to the file specified by <filename>, or memdump.log if omitted. If <device> is specified (see Specifying devices and address spaces), only memory maps for the part of the device tree rooted at this device will be dumped.
Examples:
memdump mylog.log
Dumps memory maps for all devices in the system to the file mylog.log.
memdump
Dumps memory maps for all devices in the system to the file memdump.log.
memdump audiomaps.log,audiopcb
Dumps memory maps for the device with the absolute tag path
:audiopcb
and all its child devices to the file audiomaps.log.memdump mylog.log,1
Dumps memory maps for the second CPU device in the system (zero-based index) and all its child devices to the file mylog.log.
Back to Memory Debugger Commands