-
Notifications
You must be signed in to change notification settings - Fork 70
/
Copy pathREADME
238 lines (175 loc) · 9.79 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
===============================================================================
-------------------------------------------------------------------------------
Mupen64plus-ui-console README v2.5
-------------------------------------------------------------------------------
===============================================================================
The latest documentation for this plugin can be found at:
https://mupen64plus.org/wiki/index.php/UIConsoleUsage
-------------------------------------------------------------------------------
Console Options
-------------------------------------------------------------------------------
At startup, the mupen64plus program will look for a user configuration file
called 'mupen64plus.cfg'. If this file does not exist, it will be created and
default settings will be written. If desired, an alternate config directory can
be specified using the --configdir commandline option.
Run 'mupen64plus --help' for a complete list of commandline options:
$ mupen64plus --help
Usage: mupen64plus [parameter(s)] [romfile]
Parameters:
--noosd : disable onscreen display
--osd : enable onscreen display
--fullscreen : use fullscreen display mode
--windowed : use windowed display mode
--resolution (res) : display resolution (640x480, 800x600, 1024x768, etc)
--nospeedlimit : disable core speed limiter (should be used with dummy audio plugin)
--cheats (cheat-spec) : enable or list cheat codes for the given rom file
--corelib (filepath) : use core library (filepath) (can be only filename or full path)
--configdir (dir) : force configation directory to (dir); should contain mupen64plus.cfg
--datadir (dir) : search for shared data files (.ini files, languages, etc) in (dir)
--debug : launch console-based debugger (requires core lib built for debugging)
--plugindir (dir) : search for plugins in (dir)
--sshotdir (dir) : set screenshot directory to (dir)
--gfx (plugin-spec) : use gfx plugin given by (plugin-spec)
--audio (plugin-spec) : use audio plugin given by (plugin-spec)
--input (plugin-spec) : use input plugin given by (plugin-spec)
--rsp (plugin-spec) : use rsp plugin given by (plugin-spec)
--emumode (mode) : set emu mode to: 0=Pure Interpreter 1=Interpreter 2=DynaRec
--savestate (filepath) : savestate loaded at startup
--testshots (list) : take screenshots at frames given in comma-separated (list), then quit
--set (param-spec) : set a configuration variable, format: ParamSection[ParamName]=Value
--gb-rom-{1,2,3,4} : define GB cart rom to load inside transferpak {1,2,3,4}
--gb-ram-{1,2,3,4} : define GB cart ram to load inside transferpak {1,2,3,4}
--dd-ipl-rom : define 64DD IPL rom
--dd-disk : define disk to load into the disk drive
--core-compare-send : use the Core Comparison debugging feature, in data sending mode
--core-compare-recv : use the Core Comparison debugging feature, in data receiving mode
--nosaveoptions : do not save the given command-line options in configuration file
--pif (filepath) : use a binary PIF ROM (filepath) instead of HLE PIF
--verbose : print lots of information
--help : see this help message
(plugin-spec):
(pluginname) : filename (without path) of plugin to find in plugin directory
(pluginpath) : full path and filename of plugin
'dummy' : use dummy plugin
(cheat-spec):
'list' : show all of the available cheat codes
'all' : enable all of the available cheat codes
(codelist) : a comma-separated list of cheat code numbers to enable,
with dashes to use code variables (ex 1-2 to use cheat 1 option 2)
-------------------------------------------------------------------------------
Cheats
-------------------------------------------------------------------------------
To list the available cheats in the rom:
mupen64plus --cheats list "/path/to/my/rom.v64"
If there are cheats in the rom, you will get (in the output console):
UI-Console: 3 cheat code(s) found for ROM 'MY ROM'
0: [Enable All Levels] (This is needed to be able to Play all Levels of the Game)
1: [Enable All Weapons] (This is needed to be able to Play with all Weapons of the Game)
2: etc...
All you have to do to use this cheats is:
mupen64plus --cheats 0,1,2 "/path/to/my/rom.v64"
-------------------------------------------------------------------------------
Debugger
-------------------------------------------------------------------------------
Setup
=====
You must use a mupen64plus core library which was built with the DEBUGGER flag set.
Running
=======
Use the --debug command-line option to enable the console debugger.
The emulator mode should be set to "interpreter", as the dynarec seems to cause
issues when interacting with the debugging API. This can be done with the R4300Emulator
config setting or with the --emumode flag.
Usage
=====
Once the emulator boots, it will be paused by default. You will be presented
with a prompt as follows:
(dbg)
The following commands can be entered:
run
Unpauses the game.
pause
Pauses the game.
step <num-steps>
When paused, instructs the emulator to make a single step, or a series of
steps if num-steps is provided.
regs
Prints out general purpose register values.
pc
Print current value of Program Counter register
pc-1
Print previous value of Program Counter register
asm
Print assembly language instructions. Several forms are supported:
asm Print one instruction at the Program Counter register
asm <addr> Print one instruction at <addr>
asm <addr> <n> Print <n> instructions starting at <addr>
asm <addr> <n> <flags> Print <n> instructions starting at <addr> with flags
- If flags bit-3 is set (i.e. & 0x04): also print binary instruction data
- If flags bit-2 is set: prefix each instruction with its memory address
- If flags bit-1 is set: prefix each instruction with a counter from <addr>
mem
Print memory values. Several forms are supported:
mem <addr> Print one 32-bit word at <addr>
mem /N <addr> Print <N> 32-bit words at <addr>
mem /Nb <addr> Print <N> 8-bit bytes at <addr>
mem /Nh <addr> Print <N> 16-bit half-words at <addr>
mem /Nw <addr> Print <N> 32-bit words at <addr>
mem /Nd <addr> Print <N> 64-bit double-words at <addr>
mem /NxM <addr> Print <N> rows of <M> 32-bit words at <addr>
mem /NxMb <addr> Print <N> rows of <M> 8-bit bytes at <addr>
mem /NxMh <addr> Print <N> rows of <M> 16-bit half-words at <addr>
mem /NxMw <addr> Print <N> rows of <M> 32-bit words at <addr>
mem /NxMd <addr> Print <N> rows of <M> 64-bit double-words at <addr>
write
Write values to memory. Several forms are supported:
write <addr> <value> Write a (1) byte value to <addr>
write <addr> b <value> Write a (1) byte value to <addr>
write <addr> h <value> Write a half-word value (2 bytes) to <addr>
write <addr> w <value> Write a word value (4 bytes) to <addr>
write <addr> d <value> Write a double-word value (8 bytes) to <addr>
dumpmem <addr> <n> <filename>
Dump <n> bytes of RDRAM memory starting at <addr> to <filename>.
translate
Translates virtual memory addresses to physical memory addresses. Memory
read/write breakpoints must operate on physical addresses, in contrast to the
memory read/write commands and execution breakpoints that operate on virtual
addresses.
translate <virtual address> Print the 32-bit physical address for the
provided <virtual address> argument.
bp add
Adds a breakpoint at a given address. Several forms are supported:
bp add pc Add a breakpoint at the Program Counter, triggered
on EXEC, READ, and WRITE.
bp add <addr> Add a breakpoint at <addr>, triggered on EXEC,
READ, and WRITE.
bp add <addr> <n> Add a breakpoint starting at <addr>, extending <n>
bytes, triggered on EXEC, READ, and WRITE.
bp add <addr> <n> <flags> Add a breakpoint starting at <addr>, extending <n>
bytes, with specified trigger flags.
- M64P_BKP_FLAG_READ = 0x02
- M64P_BKP_FLAG_WRITE = 0x04
- M64P_BKP_FLAG_EXEC = 0x08
bp trig
Prints the reason for the most recently activated breakpoint trigger. Memory
read/write breakpoints will indicate the hit address.
bp rm <addr|index>
Removes a breakpoint by address or number.
bp list
Lists all breakpoints.
exit|quit
Stop emulator and quit debugger
-------------------------------------------------------------------------------
64DD Support
-------------------------------------------------------------------------------
Some compatibility with the 64DD disk drive unit has been implemented, but there
are a few small usability issues of which users should be aware.
When using the 64DD, you need to pass a path to a cartridge rom, even if none is
strictly required. The IPL boot rom will execute first and select the disk if
you have one inserted, or just show the boot menu otherwise. We can remove this
requirement at a later time. For now all we need to remember is to use a Japanese
ROM (otherwise some region check will fail) with same features as the 64DD game
you want to play (think RumblePak, TransferPak, otherwise, they won't be available).
There is a sibling issue also with 64DD games in that there are no entries in the
game db (mupen64plus.ini) for them, and the core currently only relies on the cart
ROM loaded to fetch the ROM infos.