Universal Command-line Options¶
This section contains configuration options that are applicable to all MAME configurations (including both SDL and Windows native).
Commands and Verbs¶
Commands include mame itself as well as various tools included with the MAME distribution such as romcmp and srcclean.
Verbs are actions to take upon something with the command (e.g. mame -validate pacman has mame as a command and -validate as a verb)
Patterns¶
Many verbs support the use of patterns, which are either a system or device short name (e.g. a2600, zorba_kbd) or a glob pattern that matches either (e.g. zorba_*).
Depending on the command you're using the pattern with, pattern matching may match systems or systems and devices. It is advised to put quotes around your patterns to avoid having your shell try to expand them against filenames (e.g. mame -validate "pac*").
File Names and Directory Paths¶
A number of options for specifying directories support multiple paths (for
example to search for ROMs in multiple locations). MAME expects multiple
paths to be separated with semicolons ( ;
).
MAME expands environment variable expressions in paths. The syntax used depends
on your operating system. On Windows, %
(percent) syntax is used. For
example %APPDATA%\mame\cfg
will expand the application data path for the
current user's roaming profile. On UNIX-like system (including macOS and
Linux), Bourne shell syntax is used, and a leading ~
expands to the current
user's home directory. For example, ~/.mame/${HOSTNAME}/cfg
expands to
a host-specific path inside the .mame
directory in the current user's home
directory. Note that only simple variable substitutions are supported; more
complex expressions supported by Bash, ksh or zsh are not recognized by MAME.
Relative paths are resolved relative to the current working directory. If you
start MAME by double-clicking it in Windows Explorer, the working directory is
set to the folder containing the MAME executable. If you start MAME by
double-clicking it in the macOS Finder, it will open a Terminal window with the
working directory is set to your home directory (usually /Users/<username>
)
and start MAME.
If you want behaviour similar to what Windows Explorer provides on macOS, create
a script file containing these lines in the directory containing the MAME
executable (for example you could call it mame-here
):
#!/bin/sh
cd "`dirname "$0"`"
exec ./mame
You should be able to use any text editor. If you have a choice of file format
or line ending style, choose UNIX. This assumes you're using a 64-bit release
build of MAME, but if you aren't you just need to change mame
to the name
of your MAME executable (e.g. mamed, mamep, mamedp). Once you've created the
file, you need to mark it as executable. You can do this by opening a Terminal
window, typing chmod a+x followed by a space, dragging the file you created
onto the window (this causes Terminal to insert the full escaped path to the
file), and then ensuring the Terminal window is active and hitting Return
(or Enter) on your keyboard. You can close the Terminal window after doing
this. Now if you double-click the script in the Finder, it will open a
Terminal window, set the working directory to the location of the script
(i.e. the folder containing MAME), and then start MAME.
Core Verbs¶
Tip
Examples that have the output abbreviated for space reasons will show "..." in the output where needed. For instance: .. code-block:: bash
A B C ... Z
-help / -h / -?
Displays current MAME version and copyright notice.
- Example:
mame -help
-validate / -valid [<pattern>]
Performs internal validation on one or more drivers and devices in the system. Run this before submitting changes to ensure that you haven't violated any of the core system rules.
If a pattern is specified, it will validate systems matching the pattern, otherwise it will validate all systems and devices. Note that if a pattern is specified, it will be matched against systems only (not other devices), and no device type validation will be performed.
- Example:
mame -validate Driver ace100 (file apple2.cpp): 1 errors, 0 warnings Errors: Software List device 'flop525_orig': apple2_flop_orig.xml: Errors parsing software list: apple2_flop_orig.xml(126.2): Unknown tag: year apple2_flop_orig.xml(126.8): Unexpected content apple2_flop_orig.xml(127.2): Unknown tag: publisher apple2_flop_orig.xml(127.13): Unexpected content apple2_flop_orig.xml(128.2): Unknown tag: info apple2_flop_orig.xml(129.2): Unknown tag: sharedfeat apple2_flop_orig.xml(132.2): Unknown tag: part apple2_flop_orig.xml(133.3): Tag dataarea found outside of software context apple2_flop_orig.xml(134.4): Tag rom found outside of part context apple2_flop_orig.xml(137.3): mismatched tag
Configuration Verbs¶
-createconfig / -cc
Creates the default
mame.ini
file. All the configuration options (not verbs) described below can be permanently changed by editing this configuration file.
- Example:
mame -createconfig
-showconfig / -sc
Displays the current configuration settings. If you route this to a file, you can use it as an INI file.
- Example:
mame -showconfig > mame.iniThis example is equivalent to -createconfig.
-showusage / -su
Displays a summary of all the command line options. For options that are not mentioned here, the short summary given by "mame -showusage" is usually a sufficient description.
Frontend Verbs¶
Note: By default, all the '-list' verbs below write info to the standard output (usually the terminal/command window where you typed the command). If you wish to write the info to a text file instead, add this to the end of your command:
> filename
where filename is the name of the file to save the output in (e.g.
list.txt
). Note that if this file already exists, it will be completely
overwritten.
- Example:
mame -listcrc puckman > list.txtThis creates (or overwrites the existing file if already there)
list.txt
and fills the file with the results of -listcrc puckman. In other words, the list of each ROM used in Puckman and the CRC for that ROM are written into that file.
-listxml / -lx [<pattern>...]
List comprehensive details for all of the supported systems and devices in XML format. The output is quite long, so it is usually better to redirect this into a file. By default all systems are listed; however, you can limit this list by specifying one or more patterns after the -listxml verb.
This XML output is typically imported into other tools (like graphical front-ends and ROM managers), or processed with scripts query detailed information.
- Example:
mame galaxian -listxml <?xml version="1.0"?> <!DOCTYPE mame [ <!ELEMENT mame (machine+)> <!ATTLIST mame build CDATA #IMPLIED> <!ATTLIST mame debug (yes|no) "no"> <!ATTLIST mame mameconfig CDATA #REQUIRED> <!ELEMENT machine (description, year?, manufacturer?, biosset*, rom*, disk*, device_ref*, sample*, chip*, display*, sound?, input?, dipswitch*, configuration*, port*, adjuster*, driver?, feature*, device*, slot*, softwarelist*, ramoption*)> <!ATTLIST machine name CDATA #REQUIRED> <!ATTLIST machine sourcefile CDATA #IMPLIED> ... <mame build="0.216 (mame0216-154-gabddfb0404c-dirty)" debug="no" mameconfig="10"> <machine name="galaxian" sourcefile="galaxian.cpp"> <description>Galaxian (Namco set 1)</description> <year>1979</year> <manufacturer>Namco</manufacturer> ... <machine name="z80" sourcefile="src/devices/cpu/z80/z80.cpp" isdevice="yes" runnable="no"> <description>Zilog Z80</description> </machine> </mame>
Tip
Output from this command is typically more useful if redirected to
an output file. For instance, doing
mame -listxml galaxian > galax.xml will make galax.xml
or
overwrite any existing data in the file with the results of
-listxml; this will allow you to view it in a text editor or parse
it with external tools.
-listfull / -ll [<pattern>...]
- Example:
mame -listfull galaxian* Name: Description: galaxian "Galaxian (Namco set 1)" galaxiana "Galaxian (Namco set 2)" galaxianbl "Galaxian (bootleg, set 2)" galaxianbl2 "Galaxian (bootleg, set 4)" galaxiani "Galaxian (Irem)" galaxianm "Galaxian (Midway set 1)" galaxianmo "Galaxian (Midway set 2)" galaxiant "Galaxian (Taito)" galaxian_sound "Galaxian Custom Sound"Displays a list of system driver names and descriptions. By default all systems and devices are listed; however, you can limit this list by specifying one or more patterns after the -listfull verb.
-listsource / -ls [<pattern>...]
Displays a list of system drivers/devices and the names of the source files where they are defined. Useful for finding which driver a system runs on in order to fix bugs. By default all systems and devices are listed; however, you can limit this list by specifying one or more pattern after the -listsource verb.
- Example:
mame galaga -listsource galaga galaga.cpp
-listclones / -lc [<pattern>]
Displays a list of clones. By default all clones are listed; however, you can limit this list by specifying a pattern after the -listsource verb. If a pattern is specified, MAME will list clones of systems that match the pattern, as well as clones that match the pattern themselves.
- Example 1:
mame pacman -listclones Name: Clone of: pacman puckman- Example 2:
mame puckman -listclones Name: Clone of: abscam puckman bucaner puckman crockman puckman crockmnf puckman ... puckmod puckman titanpac puckman
-listbrothers / -lb [<pattern>]
Displays a list of brothers, i.e. other systems that are defined in the same source file as a system that matches the specified pattern.
- Example:
mame galaxian -listbrothers Source file: Name: Parent: galaxian.cpp amidar galaxian.cpp amidar1 amidar galaxian.cpp amidarb amidar ... galaxian.cpp zigzagb galaxian.cpp zigzagb2 zigzagb
-listcrc [<pattern>...]
Displays a full list of CRCs and names of all ROM images referenced by systems and devices matching the specified pattern(s). If no patterns are specified, ROMs referenced by all supported systems and devices will be included.
- Example:
mame playch10 -listcrc d52fa07a pch1-c__8t_e-2.8t playch10 PlayChoice-10 BIOS 503ee8b1 pck1-c.8t playch10 PlayChoice-10 BIOS 123ffa37 pch1-c_8te.8t playch10 PlayChoice-10 BIOS 0be8ceb4 pck1-c_fix.8t playch10 PlayChoice-10 BIOS 9acffb30 pch1-c__8k.8k playch10 PlayChoice-10 BIOS c1232eee pch1-c__8m_e-1.8m playch10 PlayChoice-10 BIOS 30c15e23 pch1-c__8p_e-1.8p playch10 PlayChoice-10 BIOS 9acffb30 pch1-c__8k.8k playch10 PlayChoice-10 BIOS c1232eee pch1-c__8m_e-1.8m playch10 PlayChoice-10 BIOS 30c15e23 pch1-c__8p_e-1.8p playch10 PlayChoice-10 BIOS 9acffb30 pch1-c__8k.8k playch10 PlayChoice-10 BIOS 83ebc7a3 pch1-c_8m.8m playch10 PlayChoice-10 BIOS 90e1b80c pch1-c_8p-8p playch10 PlayChoice-10 BIOS 9acffb30 pch1-c__8k.8k playch10 PlayChoice-10 BIOS c1232eee pch1-c__8m_e-1.8m playch10 PlayChoice-10 BIOS 30c15e23 pch1-c__8p_e-1.8p playch10 PlayChoice-10 BIOS e5414ca3 pch1-c-6f.82s129an.6f playch10 PlayChoice-10 BIOS a2625c6e pch1-c-6e.82s129an.6e playch10 PlayChoice-10 BIOS 1213ebd4 pch1-c-6d.82s129an.6d playch10 PlayChoice-10 BIOS 48de65dc rp2c0x.pal playch10 PlayChoice-10 BIOS
-listroms / -lr [<pattern>...]
Displays a list of ROM images referenced by supported systems/devices that match the specified pattern(s). If no patterns are specified, the results will include all supported systems and devices.
- Example:
mame neogeo -listroms ROMs required for driver "neogeo". Name Size Checksum sp-s2.sp1 131072 CRC(9036d879) SHA1(4f5ed7105b7128794654ce82b51723e16e389543) sp-s.sp1 131072 CRC(c7f2fa45) SHA1(09576ff20b4d6b365e78e6a5698ea450262697cd) sp-45.sp1 524288 CRC(03cc9f6a) SHA1(cdf1f49e3ff2bac528c21ed28449cf35b7957dc1) ... sm1.sm1 131072 CRC(94416d67) SHA1(42f9d7ddd6c0931fd64226a60dc73602b2819dcf) 000-lo.lo 131072 CRC(5a86cff2) SHA1(5992277debadeb64d1c1c64b0a92d9293eaf7e4a) sfix.sfix 131072 CRC(c2ea0cfd) SHA1(fd4a618cdcdbf849374f0a50dd8efe9dbab706c3)
-listsamples [<pattern>]
Displays a list of samples referenced by the specified pattern of system or device names. If no pattern is specified, the results will be all systems and devices.
- Example:
mame armorap -listsamples Samples required for driver "armorap". loexp jeepfire hiexp tankfire tankeng beep chopper
-verifyroms [<pattern>]
Checks for invalid or missing ROM images. By default all drivers that have valid ZIP files or directories in the rompath are verified; however, you can limit this list by specifying a pattern after the -verifyroms command.
- Example:
mame gradius -verifyroms romset gradius [nemesis] is good 1 romsets found, 1 were OK.
-verifysamples [<pattern>]
Checks for invalid or missing samples. By default all drivers that have valid ZIP files or directories in the samplepath are verified; however, you can limit this list by specifying a pattern after the -verifyroms command.
- Example:
mame armorap -verifysamples sampleset armorap [armora] is good 1 samplesets found, 1 were OK.
-romident [path/to/romstocheck.zip]
Attempts to identify ROM files, if they are known to MAME, in the specified .zip file or directory. This command can be used to try and identify ROM sets taken from unknown boards. On exit, the errorlevel is returned as one of the following:
0: means all files were identified
7: means all files were identified except for 1 or more "non-ROM" files
8: means some files were identified
9: means no files were identified
- Example:
mame unknown.rom -romident Identifying unknown.rom.... unknown.rom = 456-a07.17l gradius Gradius (Japan, ROM version)
-listdevices / -ld [<pattern>]
Displays a list of all devices known to be hooked up to a system. The ":" is considered the system itself with the devices list being attached to give the user a better understanding of what the emulation is using.
If slots are populated with devices, any additional slots those devices provide will be visible with -listdevices as well. For instance, installing a floppy controller into a PC will expose the disk drive slots.
- Example:
mame apple2e -listdevices Driver apple2e (Apple //e): <root> Apple //e a2bus Apple II Bus a2common Apple II Common Components @ 14.31 MHz a2video Apple II video @ 14.31 MHz aux Apple IIe AUX Slot ext80 Apple IIe Extended 80-Column Card auxbus Apple IIe AUX Bus ay3600 AY-5-3600 Keyboard Encoder ... speaker Filtered 1-bit DAC tape Cassette
-listslots / -lslot [<pattern>]
Show available slots and options for each slot (if available). Primarily used for MAME to allow control over internal plug-in cards, much like PCs needing video, sound and other expansion cards.
If slots are populated with devices, any additional slots those devices provide will be visible with -listslots as well. For instance, installing a floppy controller into a PC will expose the disk drive slots.
The slot name (e.g. ctrl1) can be used from the command line (-ctrl1 in this case)
- Example:
mame apple2e -listslots SYSTEM SLOT NAME SLOT OPTIONS SLOT DEVICE NAME ---------------- ---------------- ---------------- ---------------------------- apple2e sl1 4play 4play Joystick Card (rev. B) ... aevm80 Applied Engineering Viewmaster 80 alfam2 ALF MC1 / Apple Music II ... zipdrive Zip Technologies ZipDrive ... aux ext80 Apple IIe Extended 80-Column Card rw3 Applied Engineering RamWorks III std80 Apple IIe Standard 80-Column Card gameio compeyes Digital Vision ComputerEyes joy Apple II analog joysticks paddles Apple II paddles
-listbios [<pattern>]
Show available BIOS options for a system (if available). BIOS options may be available for the system or any devices selected as slot options.
If no pattern is specified, the results will include all supported systems.
- Example:
mamed -listbios apple2 -sl2 grapplus -sl4 videoterm BIOS options for system Apple ][ (apple2): default Original Monitor autostart Autostart Monitor BIOS options for device Orange Micro Grappler+ Printer Interface (-sl2 grapplus): v30 ROM 3.0 v32 ROM 3.2 BIOS options for device Videx Videoterm 80 Column Display (-sl4 videoterm): v24_60hz Firmware v2.4 (60 Hz) v24_50hz Firmware v2.4 (50 Hz)
-listmedia / -lm [<pattern>]
List available media that the chosen system allows to be used. This includes media types (cartridge, cassette, diskette and more) as well as common file extensions which are supported.
- Example:
mame coco3 -listmedia SYSTEM MEDIA NAME (brief) IMAGE FILE EXTENSIONS SUPPORTED ---------------- --------------------------- ------------------------------- coco3 cassette (cass) .wav .cas printout (prin) .prn cartridge (cart) .ccc .rom floppydisk1 (flop1) .dmk .jvc .dsk .vdk .sdf .os9 .d77 .d88 .1dd .dfi .hfe .imd .ipf .mfi .mfm .td0 .cqm .cqi floppydisk2 (flop2) .dmk .jvc .dsk .vdk .sdf .os9 .d77 .d88 .1dd .dfi .hfe .imd .ipf .mfi .mfm .td0 .cqm .cqi harddisk1 (hard1) .vhd harddisk2 (hard2) .vhd
-listsoftware / -lsoft [<pattern>]
Displays the contents of all software lists that can be used by the system or systems represented by pattern.
- Example:
mame coco3 -listsoftware <?xml version="1.0"?> <!DOCTYPE softwarelists [ <!ELEMENT softwarelists (softwarelist*)> <!ELEMENT softwarelist (software+)> <!ATTLIST softwarelist name CDATA #REQUIRED> <!ATTLIST softwarelist description CDATA #IMPLIED> <!ELEMENT software (description, year, publisher, info*, sharedfeat*, part*)> ... <softwarelists> <softwarelist name="coco_cart" description="Tandy Radio Shack Color Computer cartridges"> <software name="7cardstd"> <description>7 Card Stud</description> <year>1983</year> <publisher>Tandy</publisher> <info name="developer" value="Intelligent Software"/> <info name="serial" value="26-3074"/> <part name="cart" interface="coco_cart"> <dataarea name="rom" size="8192"> <rom name="7 card stud (1983) (26-3074) (intelligent software).rom" size="8192" crc="f38d8c97" sha1="5cfcb699ce09840dbb52714c8d91b3d86d3a86c3"/> </dataarea> </part> </software> ...
-verifysoftware / -vsoft [<pattern>]
Checks for invalid or missing ROM images in your software lists. By default all drivers that have valid ZIP files or directories in the rompath are verified; however, you can limit this list by specifying a specific driver name or pattern after the -verifysoftware command.
- Example:
mame coco3 -verifysoftware romset coco_cart:7cardstd is good coco_cart:amazing: a mazing world of malcom mortar (1987)(26-3160)(zct systems).rom (16384 bytes) - NEEDS REDUMP romset coco_cart:amazing is best available coco_cart:amazing1: a mazing world of malcom mortar (1987)(26-3160)(zct systems)[a].rom (16384 bytes) - NEEDS REDUMP romset coco_cart:amazing1 is best available romset coco_cart:androne is good ...
-getsoftlist / -glist [<pattern>]
Displays the contents of a specific softlist with the filename represented by pattern.
- Example:
mame -getsoftlist apple2_flop_orig <?xml version="1.0"?> <!DOCTYPE softwarelists [ <!ELEMENT softwarelists (softwarelist*)> <!ELEMENT softwarelist (software+)> <!ATTLIST softwarelist name CDATA #REQUIRED> <!ATTLIST softwarelist description CDATA #IMPLIED> <!ELEMENT software (description, year, publisher, info*, sharedfeat*, part*)> <!ATTLIST software name CDATA #REQUIRED> <!ATTLIST software cloneof CDATA #IMPLIED> <!ATTLIST software supported (yes|partial|no) "yes"> <!ELEMENT description (#PCDATA)> <!ELEMENT year (#PCDATA)> <!ELEMENT publisher (#PCDATA)> <!ELEMENT info EMPTY> <!ATTLIST info name CDATA #REQUIRED> <!ATTLIST info value CDATA #IMPLIED> <!ELEMENT sharedfeat EMPTY> <!ATTLIST sharedfeat name CDATA #REQUIRED> <!ATTLIST sharedfeat value CDATA #IMPLIED> ...
-verifysoftlist / -vlist [softwarelistname]
Checks a specified software list for missing ROM images if files exist for issued softwarelistname. By default, all drivers that have valid ZIP files or directories in the rompath are verified; however, you can limit this list by specifying a specific softwarelistname (without .XML) after the -verifysoftlist command.
- Example:
mame -verifysoftlist apple2_flop_orig romset apple2_flop_orig:agentusa is good romset apple2_flop_orig:airheart is good romset apple2_flop_orig:aplpanic is good romset apple2_flop_orig:alambush is good romset apple2_flop_orig:ankh is good romset apple2_flop_orig:aplcdspd is good romset apple2_flop_orig:agalxian is good romset apple2_flop_orig:aquatron is good romset apple2_flop_orig:archon is good romset apple2_flop_orig:archon2 is good romset apple2_flop_orig:ardyardv is good romset apple2_flop_orig:autobahn is good ...
OSD Command-Line Verbs¶
-listmidi
List available MIDI I/O devices for use with emulation.
- Example:
mame -listmidi MIDI input ports: MIDI output ports: Microsoft MIDI Mapper (default) Microsoft GS Wavetable Synth
-listnetwork
List available network adapters for use with emulation.
- Example 1:
mame -listnetwork No network adapters were found- Example 2:
mame -listnetwork Available network adapters: Local Area Connection
Tip
On Windows, you'll need the TAP driver from OpenVPN for MAME to see any network adapters.
OSD Output Options¶
-output
Chooses how MAME will handle processing of output notifiers. These are used to connect external outputs such as the LED lights for the Player 1/2 start buttons on certain arcade machines.
You can choose from:
auto
,none
,console
ornetwork
Note that network port is fixed at 8000.
- Example:
mame asteroid -output console led0 = 1 led0 = 0 ... led0 = 1 led0 = 0
Configuration Options¶
-[no]readconfig / -[no]rc
Enables or disables the reading of the config files. When enabled (which is the default), MAME reads the following config files in order:
mame.ini
debug.ini
(if the debugger is enabled)
source/
<driver>.ini
(based on the source filename of the driver)
vertical.ini
(for systems with vertical monitor orientation)
horizont.ini
(for systems with horizontal monitor orientation)
arcade.ini
(for systems in source added withGAME()
macro)
console.ini
(for systems in source added withCONS()
macro)
computer.ini
(for systems in source added withCOMP()
macro)
othersys.ini
(for systems in source added withSYST()
macro)
vector.ini
(for vector systems only)<parent>
.ini
(for clones only, may be called recursively)<systemname>
.ini
(See Order of Config Loading for further details)
The settings in the later INIs override those in the earlier INIs. So, for example, if you wanted to disable overlay effects in the vector systems, you can create a
vector.ini
with lineeffect none
in it, and it will override whatevereffect
value you have in yourmame.ini
.The default is ON (-readconfig).
- Example:
mame apple2ee -noreadconfig -sl6 diskii -sl7 cffa2 -hard1 TotalReplay.2mg
Core Search Path Options¶
-homepath <path>
Specifies a path for Lua plugins to store data.
The default is
.
(that is, in the current working directory).
- Example:
mame -homepath C:\mame\lua
-rompath / -rp <path>
Specifies one or more paths within which to find ROM or disk images. Multiple paths can be specified by separating them with semicolons.
The default is
roms
(that is, a directoryroms
in the current working directory).
- Example:
mame -rompath C:\mame\roms;C:\roms\another
-hashpath / -hash_directory / -hash <path>
Specifies one or more paths within which to find software definition files. Multiple paths can be specified by separating them with semicolons.
The default is
hash
(that is, a directoryhash
in the current working directory).
- Example:
mame -hashpath C:\mame\hash;C:\roms\softlists
-samplepath / -sp <path>
Specifies one or more paths within which to find audio sample files. Multiple paths can be specified by separating them with semicolons.
The default is
samples
(that is, a directorysamples
in the current working directory).
- Example:
mame -samplepath C:\mame\samples;C:\roms\samples
-artpath <path>
Specifies one or more paths within which to find external layout and artwork files. Multiple paths can be specified by separating them with semicolons.
The default is
artwork
(that is, a directoryartwork
in the current working directory).
- Example:
mame -artpath C:\mame\artwork;C:\emu\shared-artwork
-ctrlrpath <path>
Specifies one or more paths within which to find controller configuration files. Multiple paths can be specified by separating them with semicolons. Used in conjunction with the
-ctrlr
option.The default is
ctrlr
(that is, a directoryctrlr
in the current working directory).
- Example:
mame -ctrlrpath C:\mame\ctrlr;C:\emu\controllers
-inipath <path>
Specifies one or more paths within which to find INI files. Multiple paths can be specified by separating them with semicolons.
On Windows, the default is
.;ini;ini/presets
(that is, search in the current directory first, then in the directoryini
in the current working directory, and finally the directorypresets
inside that directory).On macOS, the default is
$HOME/Library/Application Support/mame;$HOME/.mame;.;ini
(that is, search themame
folder inside the current user's Application Support folder, followed by the.mame
folder in the current user's home directory, then the current working directory, and finally the directoryini
in the current working directory).On other platforms (including Linux), the default is
$HOME/.mame;.;ini
(that is search the.mame
directory in the current user's home directory, followed by the current working directory, and finally the directoryini
in the current working directory).
- Example:
mame -inipath C:\Users\thisuser\documents\mameini
-fontpath <path>
Specifies one or more paths within which to find BDF (Adobe Glyph Bitmap Distribution Format) font files. Multiple paths can be specified by separating them with semicolons.
The default is
.
(that is, search in the current working directory).
- Example:
mame -fontpath C:\mame\;C:\emu\artwork\mamefonts
-cheatpath <path>
Specifies one or more paths within which to find XML cheat files. Multiple paths can be specified by separating them with semicolons.
The default is
cheat
(that is, a folder calledcheat
located in the current working directory).
- Example:
mame -cheatpath C:\mame\cheat;C:\emu\cheats
-crosshairpath <path>
Specifies one or more paths within which to find crosshair image files. Multiple paths can be specified by separating them with semicolons.
The default is
crsshair
(that is, a directorycrsshair
in the current working directory).
- Example:
mame -crosshairpath C:\mame\crsshair;C:\emu\artwork\crosshairs
-pluginspath <path>
Specifies one or more paths within which to find Lua plugins for MAME.
The default is
plugins
(that is, a directoryplugins
in the current working directory).
- Example:
mame -pluginspath C:\mame\plugins;C:\emu\lua
-languagepath <path>
Specifies one or more paths within which to find language files for localized UI text.
The default is
language
(that is, a directorylanguage
in the current working directory).
- Example:
mame -languagepath C:\mame\language;C:\emu\mame-languages
-swpath <path>
Specifies the default path from which to load loose software image files.
The default is
sofware
(that is, a directorysoftware
in the current working directory).
- Example:
mame -swpath C:\mame\software;C:\emu\mydisks
Core Output Directory Options¶
-cfg_directory <path>
Specifies the directory where configuration files are stored. Configuration files are read when starting MAME or when starting an emulated machine, and written on exit. Configuration files preserve settings including input assignment, DIP switch settings, bookkeeping statistics, and debugger window arrangement.
The default is
cfg
(that is, a directorycfg
in the current working directory). If this directory does not exist, it will be created automatically.
- Example:
mame -cfg_directory C:\mame\cfg
-nvram_directory <path>
Specifies the directory where NVRAM files are stored. NVRAM files store the contents of EEPROM, non-volatile RAM (NVRAM), and other programmable devices for systems that used this type of hardware. This data is read when starting an emulated machine and written on exit.
The default is
nvram
(that is, a directorynvram
in the current working directory)). If this directory does not exist, it will be created automatically.
- Example:
mame -nvram_directory C:\mame\nvram
-input_directory <path>
Specifies the directory where input recording files are stored. Input recordings are created using the -record option and played back using the -playback option.
The default is
inp
(that is, a directoryinp
in the current working directory). If this directory does not exist, it will be created automatically.
- Example:
mame -input_directory C:\mame\inp
-state_directory <path>
Specifies the directory where save state files are stored. Save state files are read and written either upon user request, or when using the -autosave option.
The default is
sta
(that is, a directorysta
in the current working directory). If this directory does not exist, it will be created automatically.
- Example:
mame -state_directory C:\mame\sta
-snapshot_directory <path>
Specifies the directory where screen snapshots and video recordings are stored when requested by the user.
The default is
snap
(that is, a directorysnap
in the current working directory). If this directory does not exist, it will be created automatically.
- Example:
mame -snapshot_directory C:\mame\snap
-diff_directory <path>
Specifies the directory where hard drive difference files are stored. Hard drive difference files store data that is written back to an emulated hard disk, in order to preserve the original image file. The difference files are created when starting an emulated system with a compressed hard disk image.
The default is
diff
(that is, a directorydiff
in the current working directory). If this directory does not exist, it will be created automatically.
- Example:
mame -diff_directory C:\mame\diff
-comment_directory <path>
Specifies a directory where debugger comment files are stored. Debugger comment files are written by the debugger when comments are added to the disassembly for a system.
The default is
comments
(that is, a directorycomments
in the current working directory). If this directory does not exist, it will be created automatically.
- Example:
mame -comment_directory C:\mame\comments
Core State/Playback Options¶
-[no]rewind
When enabled and emulation is paused, automatically creates a save state in memory every time a frame is advanced. Rewind save states can then be loaded consecutively by pressing the rewind single step shortcut key (Left Shift + Tilde by default).
The default rewind value is OFF (-norewind).
If debugger is in a 'break' state, a save state is instead created every time step in, step over, or step out occurs. In that mode, rewind save states can be loaded by executing the debugger rewind (or rw) command.
- Example:
mame -norewind
-rewind_capacity <value>
Sets the rewind capacity value, in megabytes. It is the total amount of memory rewind savestates can occupy. When capacity is hit, old savestates get erased as new ones are captured. Setting capacity lower than the current savestate size disables rewind. Values below 0 are automatically clamped to 0.
- Example:
mame -rewind_capacity 30
-state <slot>
Immediately after starting the specified system, will cause the save state in the specified <slot> to be loaded.
- Example:
mame -state 1
-[no]autosave
When enabled, automatically creates a save state file when exiting MAME and automatically attempts to reload it when later starting MAME with the same system. This only works for systems that have explicitly enabled save state support in their driver.
The default is OFF (-noautosave).
- Example:
mame -autosave
-playback / -pb <filename>
Specifies a file from which to play back a series of inputs. This feature does not work reliably for all systems, but can be used to watch a previously recorded game session from start to finish.
The default is
NULL
(no playback).
- Example:
mame pacman -playback worldrecord
Tip
You may experience desync in playback if the configuration, NVRAM, and memory card files don't match the original; this is why it is suggested you should only record and playback with all configuration (.cfg), NVRAM (.nv), and memory card files deleted.
-[no]exit_after_playback
When used in conjunction with the -playback option, MAME will exit after playing back the input file. By default, MAME continues to run the emulated system after playback completes.
The default is OFF (-noexit_after_playback).
- Example:
mame pacman -playback worldrecord -exit_after_playback
-record / -rec <filename>
Specifies a file to record all input from a session. This can be used to record a session for later playback. This feature does not work reliably for all systems, but can be used to record a session from start to finish.
The default is
NULL
(no recording).
- Example:
mame pacman -record worldrecord
Tip
You may experience desync in playback if the configuration, NVRAM, and memory card files don't match the original; this is why it is suggested you should only record and playback with all configuration (.cfg), NVRAM (.nv), and memory card files deleted.
-mngwrite <filename>
Writes each video frame to the given <filename> in MNG format, producing an animation of the session. Note that -mngwrite only writes video frames; it does not save any audio data. Either use -wavwrite to record audio and combine the audio and video tracks using video editing software, or use -aviwrite to record audio and video to a single file.
The default is
NULL
(no recording).
- Example:
mame pacman -mngwrite pacman-video
-aviwrite <filename>
Stream video and sound data to the given <filename> in uncompressed AVI format, producing an animation of the session complete with sound. Note that the AVI format does not changes to resolution or frame rate, uncompressed video consumes a lot of disk space, and recording uncompressed video in realtime requires a fast disk. It may be more practical to record an emulation session using -record then make a video of it with -aviwrite in combination with -playback and -exit_after_playback options.
The default is
NULL
(no recording).
- Example:
mame pacman -playback worldrecord -exit_after_playback -aviwrite worldrecord
-wavwrite <filename>
Writes the final mixer output to the given <filename> in WAV format, producing an audio recording of the session.
The default is
NULL
(no recording).
- Example:
mame pacman -wavwrite pacsounds
-snapname <name>
Describes how MAME should name files for snapshots. <name> is a string that provides a template that is used to generate a filename.
Three simple substitutions are provided: the
/
character represents the path separator on any target platform (even Windows); the string%g
represents the driver name of the current system; and the string%i
represents an incrementing index. If%i
is omitted, then each snapshot taken will overwrite the previous one; otherwise, MAME will find the next empty value for%i
and use that for a filename.The default is
%g/%i
, which creates a separate folder for each system, and names the snapshots under it starting with 0000 and increasing from there.In addition to the above, for drivers using different media, like carts or floppy disks, you can also use the
%d_[media]
indicator. Replace [media] with the media switch you want to use.
- Example 1:
mame robby -snapname foo\%g%iSnapshots will be saved as
snaps\foo\robby0000.png
,snaps\foo\robby0001.png
and so on.- Example 2:
mame nes -cart robby -snapname %g\%d_cartSnapshots will be saved as
snaps\nes\robby.png
.- Example 3:
mame c64 -flop1 robby -snapname %g\%d_flop1/%iSnapshots will be saved as
snaps\c64\robby\0000.png
.
-snapsize <width>x<height>
Hard-codes the size for snapshots and movie recording. By default, MAME will create snapshots at the system's current resolution in raw pixels, and will create movies at the system's starting resolution in raw pixels. If you specify this option, then MAME will create both snapshots and movies at the size specified, and will bilinear filter the result.
The default is
auto
.
- Example:
mame pacman -snapsize 1920x1080
Tip
-snapsize does not automatically rotate if the system is vertically oriented, so for vertical systems you'll want to swap the width and height options.
-snapview <viewname>
Specifies the view to use when rendering snapshots and videos. The <viewname> does not need to be the full name of a view, MAME will choose the first view with a name that has the <viewname> as a prefix. For example -snapview "screen 0 pixel" will match the “Screen 0 Pixel Aspect (10:7)” view.
If the <viewname> is
auto
or an empty string, MAME will select a view based on the number of emulated screens in the system, and the available external and internal artwork. MAME tries to select a view that shows all emulated screens by default.If the <viewname> is
native
, MAME uses special internal view to save a separate snapshot for each visible emulated screen, or to record a video for the first visible screen only. The snapshot(s) or video will have the same resolution as the emulated screen(s) with no artwork elements drawn or effects applied.The default value is
auto
.
- Example:
mame wrecking -snapview cocktail
-[no]snapbilinear
Specify if the snapshot or movie should have bilinear filtering applied. Disabling this off can improve performance while recording video to a file.
The default is ON (-snapbilinear).
- Example:
mame pacman -nosnapbilinear
-statename <name>
Describes how MAME should store save state files, relative to the state_directory path. <name> is a string that provides a template that is used to generate a relative path.
Two simple substitutions are provided: the
/
character represents the path separator on any target platform (even Windows); the string%g
represents the driver name of the current system.The default is
%g
, which creates a separate folder for each system.In addition to the above, for drivers using different media, like carts or floppy disks, you can also use the
%d_[media]
indicator. Replace[media]
with the media switch you want to use.
- Example 1:
mame robby -statename foo\%g All save states will be stored inside sta\foo\robby\- Example 2:
mame nes -cart robby -statename %g/%d_cart All save states will be stored inside sta\nes\robby\- Example 3:
mame c64 -flop1 robby -statename %g/%d_flop1 All save states will be stored inside sta\c64\robby\
Tip
Note that even on Microsoft Windows, you should use /
as your
path seperator for -statename
-[no]burnin
Tracks brightness of the screen during play and at the end of emulation generates a PNG that can be used to simulate burn-in effects on other systems. The resulting PNG is created such that the least used-areas of the screen are fully white (since burned-in areas are darker, all other areas of the screen must be lightened a touch).
The intention is that this PNG can be loaded via an artwork file with a low alpha (e.g, 0.1-0.2 seems to work well) and blended over the entire screen.
The PNG files are saved in the snap directory under the
<systemname>/burnin-<screen.name>.png
.The default is OFF (-noburnin).
- Example:
mame neogeo -burnin
Core Performance Options¶
-[no]autoframeskip / -[no]afs
Dynamically adjust the frameskip level while you're running the system to maintain full speed. Turning this on overrides the -frameskip setting described below.
This is off by default (-noautoframeskip).
- Example:
mame gradius4 -autoframeskip
-frameskip / -fs <level>
Specifies the frameskip value. This is the number of frames out of every 12 to drop when running. For example, if you specify -frameskip 2, MAME will render and display 10 out of every 12 emulated frames. By skipping some frames, you may be able to get full speed emulation for a system that would otherwise be too demanding for your computer.
The default value is -frameskip 0, which skips no frames.
- Example:
mame gradius4 -frameskip 2
-seconds_to_run / -str <seconds>
This option tells MAME to automatically stop emulation after a fixed number of seconds of emulated time have elapsed. This may be useful for benchmarking and automated testing. By combining this with a fixed set of other command line options, you can set up a consistent environment for benchmarking MAME's emulation performance. In addition, upon exit, the -str option will write a screenshot to the system's snapshot directory with the file name determined by the -snapname option.
- Example:
mame pacman -seconds_to_run 60
-[no]throttle
Enable or disable throttling emulation speed. When throttling is enabled, MAME limits emulation speed to so the emulated system will not run faster than the original hardware. When throttling is disabled, MAME runs the emulation as fast as possible. Depending on your settings and the characteristics of the emulated system, performance may be limited by your CPU, graphics card, or even memory performance.
The default is to enable throttling (-throttle).
- Example:
mame pacman -nothrottle
-[no]sleep
When enabled along with -throttle, MAME will yield the CPU when limiting emulation speed. This allows other programs to use CPU time, assuming the main emulation thread isn't completely utilising a CPU core. This option can potentially cause hiccups in performance if other demanding programs are running.
The default is on (-sleep).
- Example:
mame gradius 4 -nosleep
-speed <factor>
Changes the way MAME throttles the emulation so that it runs at some multiple of the system's original speed. A <factor> of
1.0
means to run the system at its normal speed, a <factor> of0.5
means run at half speed, and a <factor> of 2.0 means run at double speed. Note that changing this value affects sound playback as well, which will scale in pitch accordingly. The internal precision of the fraction is two decimal places, so a <factor> of1.002
is rounded to1.00
.The default is
1.0
(normal speed).
- Example:
mame pacman -speed 1.25
-[no]refreshspeed / -[no]rs
Allows MAME to adjust the emulation speed so that the refresh rate of the first emulated screen does not exceed the slowest refresh rate for any targeted monitors in your system. Thus, if you have a 60Hz monitor and run a system that is designed to run at 60.6Hz, MAME will reduce the emulation speed to 99% in order to prevent sound hiccups or other undesirable side effects of running at a slower refresh rate.
The default is off (-norefreshspeed).
- Example:
mame pacman -refreshspeed
-numprocessors / -np auto|<value>
Specify the number of threads to use for work queues. Specifying
auto
will use the value reported by the system or environment variableOSDPROCESSORS
. This value is internally limited to four times the number of processors reported by the system.The default is
auto
.
- Example:
mame gradius4 -numprocessors 2
-bench <n>
Benchmark for <n> emulated seconds. This is equivalent to the following options:
-str <n> -video none -sound none -nothrottle
- Example:
mame gradius4 -bench 300
-[no]lowlatency
This tells MAME to draw a new frame before throttling to reduce input latency. This is particularly effective with VRR (Variable Refresh Rate) displays.
This may cause frame pacing issues in the form of jitter with some systems (especially newer 3D-based systems or systems that run software akin to an operating system), so the default is off (-nolowlatency).
- Example:
mame bgaregga -lowlatency
Core Rotation Options¶
-[no]rotate
Rotate the system to match its normal state (horizontal/vertical). This ensures that both vertically and horizontally oriented systems show up correctly without the need to rotate your monitor. If you want to keep the system displaying 'raw' on the screen the way it would have in the arcade, turn this option OFF.
The default is ON (-rotate).
- Example:
mame pacman -norotate
-[no]ror
-[no]rol
Rotate the system screen to the right (clockwise) or left (counter-clockwise) relative to either its normal state (if -rotate is specified) or its native state (if -norotate is specified).
The default for both of these options is OFF (-noror -norol).
- Example 1:
mame pacman -ror- Example 2:
mame pacman -rol
-[no]autoror
-[no]autorol
These options are designed for use with pivoting screens that only pivot in a single direction. If your screen only pivots clockwise, use -autorol to ensure that the system will fill the screen either horizontally or vertically in one of the directions you can handle. If your screen only pivots counter-clockwise, use -autoror.
- Example 1:
mame pacman -autoror- Example 2:
mame pacman -autorol
Tip
If you have a display that can be rotated, -autorol or -autoror will allow you to get a larger display for both horizontal and vertical systems.
-[no]flipx
-[no]flipy
Flip (mirror) the system screen either horizontally (-flipx) or vertically (-flipy). The flips are applied after the -rotate and -ror/-rol options are applied.
The default for both of these options is OFF (-noflipx -noflipy).
- Example 1:
mame -flipx pacman- Example 2:
mame -flipy suprmrio
Core Video Options¶
-video <bgfx|gdi|d3d|opengl|soft|accel|none>
Specifies which video subsystem to use for drawing. Options here depend on the operating system and whether this is an SDL-compiled version of MAME.
Generally Available:
Using
bgfx
specifies the new hardware accelerated renderer.Using
opengl
tells MAME to render video using OpenGL acceleration.Using
none
displays no windows and does no drawing. This is primarily intended for benchmarking emulation without the overhead of the video system.On Windows:
Using
gdi
tells MAME to render video using older standard Windows graphics drawing calls. This is the slowest but most compatible option on older versions of Windows or buggy graphics hardware drivers.Using
d3d
tells MAME to use Direct3D 9 for rendering. This produces better quality output thangdi
and enables additional rendering options. It is recommended if you have a 3D-capable video card or onboard Intel video of the HD3000 line or better.On other platforms (including SDL on Windows):
Using
accel
tells MAME to render video using SDL’s 2D acceleration if possible.Using
soft
uses software rendering for video output. This isn’t as fast or as nice as OpenGL, but it will work on any platform.Defaults:
The default on Windows is
d3d
.The default for macOS is
opengl
because OS X is guaranteed to have a compliant OpenGL stack.The default on all other systems is
soft
.
- Example:
mame gradius3 -video bgfx
-numscreens <count>
Tells MAME how many output windows or screens to create. For most systems, a single output window is all you need, but some systems originally used multiple screens (e.g. Darius and PlayChoice-10 arcade machines). Some systems with front panel controls and/or status lights also may let you put these in different windows/screens. Each screen (up to 4) has its own independent settings for physical monitor, aspect ratio, resolution, and view, which can be set using the options below.
The default is
1
.
- Example 1:
mame darius -numscreens 3- Example 2:
mame pc_cntra -numscreens 2
-[no]window / -[no]w
Run MAME in either a window or full screen.
The default is OFF (-nowindow).
- Example:
mame coco3 -window
-[no]maximize / -[no]max
Controls initial window size in windowed mode. If it is set on, the window will initially be set to the maximum supported size when you start MAME. If it is turned off, the window will start out at the closest possible size to the original size of the display; it will scale on only one axis where non-square pixels are used. This option only has an effect when the -window option is used.
The default is ON (-maximize).
- Example:
mame apple2e -window -nomaximize
-[no]keepaspect / -[no]ka
When enabled, MAME preserves the correct aspect ratio for the emulated system's screen(s). This is most often 4:3 or 3:4 for CRT monitors (depending on the orientation), though many other aspect ratios have been used, such as 3:2 (Nintendo Game Boy), 5:4 (some workstations), and various other ratios. If the emulated screen and/or artwork does not fill MAME's screen or Window, the image will be centred and black bars will be added as necessary to fill unused space (either above/below or to the left and right).
When this option is disabled, the emulated screen and/or artwork will be stretched to fill MAME's screen or window. The image will be distorted by non-proportional scaling if the aspect ratio does not match. This is very pronounced when the emulated system uses a vertically-oriented screen and MAME stretches the image to fill a horizontally-oriented screen.
On Windows, when this option is enabled and MAME is running in a window (not full screen), the aspect ratio will be maintained when you resize the window unless you hold the Control (or Ctrl) key on your keyboard. The window size will not be restricted when this option is disabled.
The default is ON (-keepaspect).
The MAME team strongly recommends leaving this option enabled. Stretching systems beyond their original aspect ratio will mangle the appearance of the system in ways that no filtering or shaders can repair.
- Example:
mame sf2ua -nokeepaspect
-[no]waitvsync
Waits for the refresh period on your computer's monitor to finish before starting to draw video to your screen. If this option is off, MAME will just draw to the screen as a frame is ready, even if in the middle of a refresh cycle. This can cause "tearing" artifacts, where the top portion of the screen is out of sync with the bottom portion.
The effect of turning -waitvsync on differs a bit between combinations of different operating systems and video drivers.
On Windows, -waitvsync will block until video blanking before allowing MAME to draw the next frame, limiting the emulated machine's framerate to that of the host display. Note that this option does not work with -video gdi mode in Windows.
On macOS, -waitvsync does not block; instead the most recent completely drawn frame will be displayed at vblank. This means that if an emulated system has a higher framerate than your host display, emulated frames will be dropped periodically resulting in motion judder.
On Windows, you should only need to turn this on in windowed mode. In full screen mode, it is only needed if -triplebuffer does not remove the tearing, in which case you should use -notriplebuffer -waitvsync.
Note that SDL-based MAME support for this option depends entirely on your operating system and video drivers; in general it will not work in windowed mode so -video opengl and fullscreen give the greatest chance of success with SDL builds of MAME.
The default is OFF (-nowaitvsync).
- Example:
mame gradius2 -waitvsync
-[no]syncrefresh
Enables speed throttling only to the refresh of your monitor. This means that the system's actual refresh rate is ignored; however, the sound code still attempts to keep up with the system's original refresh rate, so you may encounter sound problems.
This option is intended mainly for those who have tweaked their video card's settings to provide carefully matched refresh rate options. Note that this option does not work with -video gdi mode.
The default is OFF (-nosyncrefresh).
- Example:
mame mk -syncrefresh
-prescale <amount>
Controls the size of the screen images when they are passed off to the graphics system for scaling. At the minimum setting of 1, the screen is rendered at its original resolution before being scaled. At higher settings, the screen is expanded in both axes by a factor of <amount> using nearest-neighbor sampling before applying filters or shaders. With -video d3d, this produces a less blurry image at the expense of speed.
The default is
1
.This is supported with all video output types (
bgfx
,d3d
, etc.) on Windows and is supported with BGFX and OpenGL on other platforms.
- Example:
mame pacman -video d3d -prescale 3
-[no]filter / -[no]d3dfilter / -[no]flt
Enable bilinear filtering on the system screen graphics. When disabled, point filtering is applied, which is crisper but leads to scaling artifacts. If you don't like the filtered look, you are probably better off increasing the -prescale value rather than turning off filtering altogether.
The default is ON (-filter).
This is supported with OpenGL and D3D video on Windows and is ONLY supported with OpenGL on other platforms.
Use
bgfx_screen_chains
in your INI file(s) to adjust filtering with the BGFX video system.
- Example:
mame pacman -nofilter
-[no]unevenstretch
Allow non-integer scaling factors allowing for great window sizing flexibility.
The default is ON. (-unevenstretch)
- Example:
mame dkong -nounevenstretch
Core Full Screen Options¶
-[no]switchres
Enables resolution switching. This option is required for the -resolution* options to switch resolutions in full screen mode.
On modern video cards, there is little reason to switch resolutions unless you are trying to achieve the "exact" pixel resolutions of the original systems, which requires significant tweaking. This is also true on LCD displays, since they run with a fixed resolution and switching resolutions on them is just silly. This option does not work with -video gdi and -video bgfx.
The default is OFF (-noswitchres).
- Example:
mame kof97 -video d3d -switchres -resolution 1280x1024
Core Per-Window Options¶
-screen <display>
-screen0 <display>
-screen1 <display>
-screen2 <display>
-screen3 <display>
Specifies which physical monitor on your system you wish to have each window use by default. In order to use multiple windows, you must have increased the value of the -numscreens option. The name of each display in your system can be determined by running MAME with the -verbose option. The display names are typically in the format of:
\\\\.\\DISPLAYn
, where 'n' is a number from 1 to the number of connected monitors.The default value for these options is
auto
, which means that the first window is placed on the first display, the second window on the second display, etc.The -screen0, -screen1, -screen2, -screen3 parameters apply to the specific window. The -screen parameter applies to all windows. The window-specific options override values from the all window option.
- Example 1:
mame pc_cntra -numscreens 2 -screen0 \\.\DISPLAY1 -screen1 \\.\DISPLAY2- Example 2:
mame darius -numscreens 3 -screen0 \\.\DISPLAY1 -screen1 \\.\DISPLAY3 -screen2 \\.\DISPLAY2
Tip
Using -verbose will tell you which displays you have on your system, where they are connected, and what their current resolutions are.
Tip
Multiple Screens may fail to work correctly on some Mac machines as of right now.
-aspect <width:height> / -screen_aspect <num:den>
-aspect0 <width:height>
-aspect1 <width:height>
-aspect2 <width:height>
-aspect3 <width:height>
Specifies the physical aspect ratio of the physical monitor for each window. In order to use multiple windows, you must have increased the value of the -numscreens option. The physical aspect ratio can be determined by measuring the width and height of the visible screen image and specifying them separated by a colon.
The default value for these options is
auto
, which means that MAME assumes the aspect ratio is proportional to the number of pixels in the desktop video mode for each monitor.The -aspect0, -aspect1, -aspect2, -aspect3 parameters apply to the specific window. The -aspect parameter applies to all windows. The window-specific options override values from the all window option.
- Example 1:
mame contra -aspect 16:9- Example 2:
mame pc_cntra -numscreens 2 -aspect0 16:9 -aspect1 5:4
-resolution <widthxheight[@refresh]> / -r <widthxheight[@refresh]>
-resolution0 <widthxheight[@refresh]> / -r0 <widthxheight[@refresh]>
-resolution1 <widthxheight[@refresh]> / -r1 <widthxheight[@refresh]>
-resolution2 <widthxheight[@refresh]> / -r2 <widthxheight[@refresh]>
-resolution3 <widthxheight[@refresh]> / -r3 <widthxheight[@refresh]>
Specifies an exact resolution to run in. In full screen mode, MAME will try to use the specific resolution you request. The width and height are required; the refresh rate is optional. If omitted or set to 0, MAME will determine the mode automatically. For example, -resolution 640x480 will force 640x480 resolution, but MAME is free to choose the refresh rate. Similarly, -resolution 0x0@60 will force a 60Hz refresh rate, but allows MAME to choose the resolution. The string
auto
is also supported, and is equivalent to0x0@0
.In window mode, this resolution is used as a maximum size for the window. This option requires the -switchres option as well in order to actually enable resolution switching with -video d3d.
The default value for these options is
auto
.The -resolution0, -resolution1, -resolution2, -resolution3 parameters apply to the specific window. The -resolution parameter applies to all windows. The window-specific options override values from the all window option.
- Example:
mame pc_cntra -numscreens 2 -resolution0 1920x1080 -resolution1 1280x1024
-view <viewname>
-view0 <viewname>
-view1 <viewname>
-view2 <viewname>
-view3 <viewname>
Specifies the initial view setting for each window/screen. The <viewname> does not need to be the full name of a view, MAME will choose the first view with a name that has the <viewname> as a prefix. For example -view "screen 0 pixel" will match the “Screen 0 Pixel Aspect (10:7)” view.
If the <viewname> is
auto
or an empty string, MAME will select views based on the number of emulated screens in the system, the number of windows/screens MAME is using, and the available external and internal artwork. MAME tries to select views so that all emulated screens are visible by default.The default value for these options is
auto
.The -view0, -view1, -view2, -view3 parameters apply to the specific window. The -view parameter applies to all windows. The window-specific options override values from the all windows option.
Note that view settings saved in the configuration file for the machine take precedence over the initial view settings. If you change the selected views in the Video Options menu, this will be saved in the configuration file for the machine and take precedence over any initial views specified in INI files or on the command line.
- Example:
mame contra -view native
Core Artwork Options¶
-[no]artwork_crop / -[no]artcrop
Enable cropping of artwork to the system screen area only. This means that vertically oriented systems running full screen can display their artwork to the left and right sides of the screen. This option can also be controlled via the Video Options menu in the user interface.
The default is OFF -noartwork_crop.
- Example:
mame pacman -artwork_crop
Tip
-artwork_crop is great for widescreen displays. You will get a full-sized system display and the artwork will fill the empty space on the sides as much as possible.
-fallback_artwork
Specifies fallback artwork if no external artwork or internal driver layout is defined. If external artwork for the system is present or a layout is included in the driver for the system, then that will take precedence.
- Example:
mame coco -fallback_artwork suprmrio
Tip
You can use fallback_artwork <artwork name> in
horizontal.ini
and vertical.ini
to specify different
fallback artwork choices for horizontal and vertical systems.
-override_artwork
Specifies override artwork for external artwork and internal driver layout.
- Example:
mame galaga -override_artwork puckman
Core Screen Options¶
-brightness <value>
Controls the default brightness, or black level, of the system screens. This option does not affect the artwork or other parts of the display. Using the MAME UI, you can individually set the brightness for each system screen; this option controls the initial value for all visible system screens. The standard and default value is
1.0
. Selecting lower values (down to 0.1) will produce a darkened display, while selecting higher values (up to 2.0) will give a brighter display.
- Example:
mame pacman -brightness 0.5
-contrast <value>
Controls the contrast, or white level, of the system screens. This option does not affect the artwork or other parts of the display. Using the MAME UI, you can individually set the contrast for each system screen; this option controls the initial value for all visible system screens. The standard and default value is
1.0
. Selecting lower values (down to 0.1) will produce a dimmer display, while selecting higher values (up to 2.0) will give a more saturated display.
- Example:
mame pacman -contrast 0.5
-gamma <value>
Controls the gamma, which produces a potentially nonlinear black to white ramp, for the system screens. This option does not affect the artwork or other parts of the display. Using the MAME UI, you can individually set the gamma for each system screen; this option controls the initial value for all visible system screens. The standard and default value is
1.0
, which gives a linear ramp from black to white. Selecting lower values (down to 0.1) will increase the nonlinearity toward black, while selecting higher values (up to 3.0) will push the nonlinearity toward white.The default is
1.0
.
- Example:
mame pacman -gamma 0.8
-pause_brightness <value>
This controls the brightness level when MAME is paused.
The default value is
0.65
.
- Example:
mame pacman -pause_brightness 0.33
-effect <filename>
Specifies a single PNG file that is used as an overlay over any system screens in the video display. This PNG file is assumed to live in the root of one of the artpath directories. The pattern in the PNG file is repeated both horizontally and vertically to cover the entire system screen areas (but not any external artwork), and is rendered at the target resolution of the system image.
For -video gdi and -video d3d modes, this means that one pixel in the PNG will map to one pixel on your output display. The RGB values of each pixel in the PNG are multiplied against the RGB values of the target screen.
The default is
none
, meaning no effect.
- Example:
mame pacman -effect scanlines
Core Vector Options¶
-beam_width_min <width>
Sets the vector beam minimum width. The beam width varies between the minimum and maximum beam widths as the intensity of the vector drawn changes. To disable vector width changes based on intensity, set the maximum equal to the minimum.
- Example:
mame asteroid -beam_width_min 0.1
-beam_width_max <width>
Sets the vector beam maximum width. The beam width varies between the minimum and maximum beam widths as the intensity of the vector drawn changes. To disable vector width changes based on intensity, set the maximum equal to the minimum.
- Example:
mame asteroid -beam_width_max 2
-beam_intensity_weight <weight>
Sets the vector beam intensity weight. This value determines how the intensity of the vector drawn affects the width. A value of 0 creates a linear mapping from intensity to width. Negative values mean that lower intensities will increase the width toward maximum faster, while positive values will increase the width toward maximum more slowly.
- Example:
mame asteroid -beam_intensity_weight 0.5
-beam_dot_size <scale>
Scale factor to apply to the size of single-point dots in vector games. Normally these are rendered according to the computed beam width; however, it is common for this to produce dots that are difficult to see. The beam_dot_size option applies a scale factor on top of the beam width to help them show up better.
The default is
1
.
- Example:
mame asteroid -beam_dot_size 2
-flicker <value>
Simulates a vector "flicker" effect, similar to a vector monitor that needs adjustment. This option requires a float argument in the range of 0.00 - 100.00 (0=none, 100=maximum).
The default is
0
.
- Example:
mame asteroid -flicker 0.15
Core Video OpenGL Feature Options¶
These options are for compatibility in -video opengl. If you report rendering artifacts you may be asked to try messing with them by the developers, but normally they should be left at their defaults which results in the best possible video performance.
Tip
Examples are not provided for these options as MAMEdev will provide suitable test options in the case of needing them for debugging.
-[no]gl_forcepow2texture
Always use only power-of-2 sized textures.
The default is OFF. (-nogl_forcepow2texture)
-[no]gl_notexturerect
Don't use OpenGL GL_ARB_texture_rectangle.
The default is ON. (-gl_notexturerect)
-[no]gl_vbo
Enable OpenGL VBO (Vertex Buffer Objects), if available.
The default is ON. (-gl_vbo)
-[no]gl_pbo
Enable OpenGL PBO (Pixel Buffer Objects), if available (default
on
)The default is ON. (-gl_pbo)
Core Video OpenGL GLSL Options¶
-[no]gl_glsl
Enable OpenGL GLSL, if available.
The default is OFF (-nogl_glsl).
- Example:
mame galaxian -gl_glsl
-gl_glsl_filter
Use OpenGL GLSL shader-based filtering instead of fixed function pipeline-based filtering.
0-plain, 1-bilinear, 2-bicubic
The default is 1. (-gl_glsl_filter 1)
- Example:
mame galaxian -gl_glsl -gl_glsl_filter 0
-glsl_shader_mame0
-glsl_shader_mame1
...
-glsl_shader_mame9
Set a custom OpenGL GLSL shader effect to the internal system screen in the given slot. MAME does not include a vast selection of shaders by default; more can be found online.
- Example:
mame suprmrio -gl_glsl -glsl_shader_mame0 NTSC/NTSC_chain -glsl_shader_mame1 CRT-geom/CRT-geom
-glsl_shader_screen0
-glsl_shader_screen1
...
-glsl_shader_screen9
Set a custom OpenGL GLSL shader effect to the whole scaled-up output screen that will be rendered by your graphics card. MAME does not include a vast selection of shaders by default; more can be found online.
- Example:
mame suprmrio -gl_glsl -glsl_shader_screen0 gaussx -glsl_shader_screen1 gaussy -glsl_shader_screen2 CRT-geom-halation
Core Sound Options¶
-samplerate <value> / -sr <value>
Sets the audio sample rate. Smaller values (e.g. 11025) cause lower audio quality but faster emulation speed. Higher values (e.g. 48000) cause higher audio quality but slower emulation speed.
The default is
48000
.
- Example:
mame galaga -samplerate 44100
-[no]samples
Use samples if available.
The default is ON (-samples).
- Example:
mame qbert -nosamples
-[no]compressor
Enable audio compressor. It temporarily reduces the overall volume when the audio output is overdriven.
The default is ON (-compressor).
- Example:
mame popeye -nocompressor
-volume / -vol <value>
Sets the initial sound volume. It can be changed later with the user interface (see Keys section). The volume is an attenuation in decibels: e.g. "-volume -12" will start with -12 dB attenuation. Note that if the volume is changed in the user interface it will be saved to the configuration file for the system. The value from the configuration file for the system has priority over
volume
settings in general INI files.The default is
0
(no attenuation, or full volume).
- Example:
mame pacman -volume -30
-sound <dsound | coreaudio | sdl | xaudio2 | portaudio | none>
Specifies which sound subsystem to use. Selecting
none
disables sound output altogether (sound hardware is still emulated).On Windows and Linux, portaudio is likely to give the lowest possible latency, while Mac users will find coreaudio provides the best results.
When using the
sdl
sound subsystem, the audio API to use may be selected by setting the SDL_AUDIODRIVER environment variable. Available audio APIs depend on the operating system. On Windows, it may be necessary to setSDL_AUDIODRIVER=directsound
if no sound output is produced by default.The default is
dsound
on Windows. On Mac,coreaudio
is the default. On all other platforms,sdl
is the default.
- Example:
mame pacman -sound portaudio
Microsoft Windows |
dsound |
xaudio2 |
portaudio |
sdl [14]. |
none |
|
macOS |
portaudio |
coreaudio |
sdl |
none |
||
Linux and others |
portaudio |
sdl |
none |
Footnotes
While SDL is not a supported option on official builds for Windows, you can compile MAME with SDL support on Windows.
-audio_latency <value>
The exact behavior depends on the selected audio output module. Smaller values provide less audio delay while requiring better system performance. Higher values increase audio delay but may help avoid buffer under-runs and audio interruptions.
The default is
1
.
For PortAudio, see the section on -pa_latency.
XAudio2 calculates audio_latency as 10ms steps.
DSound calculates audio_latency as 10ms steps.
CoreAudio calculates audio_latency as 25ms steps.
SDL calculates audio_latency as Xms steps.
- Example:
mame galaga -audio_latency 1
Core Input Options¶
-[no]coin_lockout / -[no]coinlock
Enables simulation of the "coin lockout" feature that is implemented on a number of arcade game PCBs. It was up to the operator whether or not the coin lockout outputs were actually connected to the coin mechanisms. If this feature is enabled, then attempts to enter a coin while the lockout is active will fail and will display a popup message in the user interface (in debug mode). If this feature is disabled, the coin lockout signal will be ignored.
The default is ON (-coin_lockout).
- Example:
mame suprmrio -coin_lockout
-ctrlr <controller>
Specifies a controller configuration file, typically used to set more suitable default input assignments for special controllers. Directories specified using the
ctrlrpath
option are searched. Controller configuration files use a similar format to.cfg
used to save system settings. See Controller Configuration Files for more details.The default is
NULL
(no controller configuration file).
- Example:
mame dkong -ctrlr xarcade
-[no]mouse
Controls whether or not MAME makes use of mouse controllers. When this is enabled, you will likely be unable to use your mouse for other purposes until you exit or pause the system. Supported mouse controllers depend on your mouseprovider setting.
Note that if this setting is off (-nomouse), mouse input may still be enabled depending on the inputs present on the emulated system and your automatic input enable settings. In particular, the default is to enable mouse input when the emulated system has mouse inputs (-mouse_device mouse), so MAME will capture your mouse pointer when you run a system with mouse inputs unless you also change the mouse_device setting.
The default is OFF (-nomouse).
- Example:
mame centiped -mouse
-[no]joystick / -[no]joy
Controls whether or not MAME makes use of game controllers (e.g. joysticks, gamepads and simulation controls). Supported game controllers depend on your joystickprovider setting.
When this is enabled, MAME will ask the system about which controllers are connected.
Note that if this setting is off (-nojoystick), joystick input may still be enabled depending on the inputs present on the emulated system and your automatic input enable settings.
The default is OFF (-nojoystick).
- Example:
mame mappy -joystick
-[no]lightgun / -[no]gun
Controls whether or not MAME makes use of lightgun controllers. Note that most lightguns also produce mouse input, so enabling mouse and lightgun controllers simultaneously (using -lightgun and -mouse together) may produce strange behaviour. Supported lightgun controllers depend on your lightgunprovider setting.
Note that if this setting is off (-nolightgun), lightgun input may still be enabled depending on the inputs present on the emulated system and your automatic input enable settings.
The default is OFF (-nolightgun).
- Example:
mame lethalen -lightgun
-[no]multikeyboard / -[no]multikey
Determines whether MAME differentiates between multiple keyboards. Some systems may report more than one keyboard; by default, the data from all of these keyboards is combined so that it looks like a single keyboard.
Turning this option on will enable MAME to report keypresses on different keyboards independently.
The default is OFF (-nomultikeyboard).
- Example:
mame sf2ceua -multikey
-[no]multimouse
Determines whether MAME differentiates between multiple mice. Some systems may report more than one mouse device; by default, the data from all of these mice is combined so that it looks like a single mouse. Turning this option on will enable MAME to report mouse movement and button presses on different mice independently.
The default is OFF (-nomultimouse).
- Example:
mame warlords -multimouse
-[no]steadykey / -[no]steady
Some systems require two or more buttons to be pressed at exactly the same time to make special moves. Due to limitations in the keyboard hardware, it can be difficult or even impossible to accomplish that using the standard keyboard handling. This option selects a different handling that makes it easier to register simultaneous button presses, but has the disadvantage of making controls less responsive.
The default is OFF (-nosteadykey)
- Example:
mame sf2ua -steadykey
-[no]ui_active
Enable user interface on top of emulated keyboard (if present).
The default is OFF (-noui_active)
- Example:
mame apple2e -ui_active
-[no]offscreen_reload / -[no]reload
Controls whether or not MAME treats a second button input from a lightgun as a reload signal. In this case, MAME will report the gun's position as (0,MAX) with the trigger held, which is equivalent to an offscreen reload.
This is only needed for games that required you to shoot offscreen to reload, and then only if your gun does not support off screen reloads.
The default is OFF (-nooffscreen_reload).
- Example:
mame lethalen -offscreen_reload
-joystick_map <map> / -joymap <map>
Controls how analog joystick values map to digital joystick controls.
Systems such as Pac-Man use a 4-way digital joystick and will exhibit undesired behavior when a diagonal is triggered; in the case of Pac-Man, movement will stop completely at intersections when diagonals are triggered and the game will be considerably harder to play correctly. Many other arcade cabinets used 4-way or 8-way joysticks (as opposed to full analog joysticks), so for true analog joysticks such as flight sticks and analog thumb sticks, this then needs to be mapped down to the expected 4-way or 8-way digital joystick values.
To do this, MAME divides the analog range into a 9x9 grid that looks like this:
insert 9x9 grid picture here
MAME then takes the joystick axis position (for X and Y axes only), maps it to this grid, and then looks up a translation from a joystick map. This parameter allows you to specify the map.
For instance, an 8-way joystick map traditionally looks like this:
insert 8-way map picture here
This mapping gives considerable leeway to the angles accepted for a given direction, so that being approximately in the area of the direction you want will give you the results you want. Without that, if you were slightly off center while holding the stick left, it would not recognize the action correctly.
The default is
auto
, which means that a standard 8-way, 4-way, or 4-way diagonal map is selected automatically based on the input port configuration of the current system.Generally you will want to set up the -joystick_map setting in the per-system
<system>.ini
file as opposed to the mainMAME.INI
file so that the mapping only affects the systems you want it to. See Multiple Configuration Files for further details on per-system configuration.Maps are defined as a string of numbers and characters. Since the grid is 9x9, there are a total of 81 characters necessary to define a complete map. Below is an example map for an 8-way joystick that matches the picture shown above:
777888999777888999777888999444555666444555666444555666111222333111222333111222333 Note that the numeric digits correspond to the keyson a numeric keypad. So '7' maps to up+left, '4' mapsto left, '5' maps to neutral, etc. In addition to thenumeric values, you can specify the character 's',which means "sticky". Sticky map positions will keepthe output the same as the last non-sticky input sentto the system.To specify the map for this parameter, you can specify a string of rows separated by a '.' (which indicates the end of a row), like so:
-joymap 777888999.777888999.777888999.444555666.444555666.444555666.111222333.111222333.111222333
However, this can be reduced using several shorthands supported by the <map> parameter. If information about a row is missing, then it is assumed that any missing data in columns 5-9 are left/right symmetric with data in columns 0-4; and any missing data in columns 0-4 is assumed to be copies of the previous data. The same logic applies to missing rows, except that up/down symmetry is assumed.
By using these shorthands, the 81 character map can be simply specified by this 11 character string: 7778...4445 (which means we then use -joymap 7778...4445)
Looking at the first row, 7778 is only 4 characters long. The 5th entry can't use symmetry, so it is assumed to be equal to the previous character '8'. The 6th character is left/right symmetric with the 4th character, giving an '8'. The 7th character is left/right symmetric with the 3rd character, giving a '9' (which is '7' with left/right flipped). Eventually this gives the full 777888999 string of the row.
The second and third rows are missing, so they are assumed to be identical to the first row. The fourth row decodes similarly to the first row, producing 444555666. The fifth row is missing so it is assumed to be the same as the fourth.
The remaining three rows are also missing, so they are assumed to be the up/down mirrors of the first three rows, giving three final rows of 111222333.
With 4-way games, sticky becomes important to avoid problems with diagonals. Typically you would choose a map that looks something like this:
insert 9x9 4-way sticky grid picture here
This means that if you press left, then roll the stick towards up (without re-centering it) you'll pass through the sticky section in the corner. As you do, MAME will read that sticky corner as left as that's the last non-sticky input it received. As the roll gets into the upward space of the map, this then switches to an up motion.
This map would look somewhat like:
s8888888s4s88888s644s888s6644455566644455566644455566644s222s664s22222s6s2222222s For this mapping, we have a wide range for thecardinal directions on 8, 4, 6, and 2. We have stickyon the meeting points between those cardinaldirections where the appropriate direction isn'tgoing to be completely obvious.To specify the map for this parameter, you can specify a string of rows separated by a '.' (which indicates the end of a row), like so:
-joymap s8888888s.4s88888s6.44s888s66.444555666.444555666.444555666.44s222s66.4s22222s6.s2222222s
Like before, because of the symmetry between top and bottom and left and right, we can shorten this down to:
-joymap s8.4s8.44s8.4445
-joystick_deadzone <value> / -joy_deadzone <value> / -jdz <value>
If you play with an analog joystick, the center can drift a little. joystick_deadzone tells how far along an axis you must move before the axis starts to change. This option expects a float in the range of 0.0 to 1.0. Where 0 is the center of the joystick and 1 is the outer limit.
The default is
0.15
.
- Example:
mame sinistar -joystick_deadzone 0.3
-joystick_saturation <value> / joy_saturation <value> / -jsat <value>
If you play with an analog joystick, the ends can drift a little, and may not match in the +/- directions. joystick_saturation tells how far along an axis movement change will be accepted before it reaches the maximum range. This option expects a float in the range of 0.0 to 1.0, where 0 is the center of the joystick and 1 is the outer limit.
The default is
0.85
.
- Example:
mame sinistar -joystick_saturation 1.0
-joystick_threshold <value> / joy_threshold <value> / -jthresh <value>
When a joystick axis (or other absolute analog axis) is assigned to a digital input, this controls how far it must be moved from the neutral position (or centre) to be considered active or switched on. This option expects a float in the range of 0.0 to 1.0, where 0 means any movement from the neutral position is considered active, and 1 means only the outer limits are considered active. This threshold is not adjusted to the range between the dead zone and saturation point.
Note that if a joystick map is configured, that will take precedence over this setting when a joystick’s main X/Y axes are assigned to digital inputs.
The default is
0.3
.
- Example:
mame raiden -joystick_threshold 0.2
-[no]natural
Allows user to specify whether or not to use a natural keyboard or not. This allows you to start your system in a 'native' mode, depending on your region, allowing compatibility for non-"QWERTY" style keyboards.
The default is OFF (-nonatural)
In "emulated keyboard" mode (the default mode), MAME translates pressing/releasing host keys/buttons to emulated keystrokes. When you press/release a key/button mapped to an emulated key, MAME presses/releases the emulated key.
In "natural keyboard" mode, MAME attempts to translate characters to keystrokes. The OS translates keystrokes to characters (similarly to when you type into a text editor), and MAME attempts to translate these characters to emulated keystrokes.
There are a number of unavoidable limitations in "natural keyboard" mode:
The emulated system driver and/or keyboard device has to support it.
The selected keyboard layout must match the keyboard layout selected in the emulated OS!
Keystrokes that don’t produce characters can’t be translated (e.g. pressing a modifier on its own such as shift, ctrl, or alt).
Holding a key until the character repeats will cause the emulated key to be pressed repeatedly as opposed to being held down.
Dead key sequences are cumbersome to use at best.
It won’t work at all if IME edit is involved (e.g. for Chinese, Japanese or Korean language input).
- Example:
mame coco2 -natural
-[no]joystick_contradictory
Enable contradictory direction digital joystick input at the same time such as Left and Right or Up and Down at the same time.
The default is OFF (-nojoystick_contradictory)
- Example:
mame pc_smb -joystick_contradictory
-coin_impulse [n]
Set coin impulse time based on n (n<0 disable impulse, n==0 obey driver, 0<n set time n).
Default is
0
.
- Example:
mame contra -coin_impulse 1
Core Input Automatic Enable Options¶
-paddle_device ( none
| keyboard
| mouse
| lightgun
| joystick
)
-adstick_device ( none
| keyboard
| mouse
| lightgun
| joystick
)
-pedal_device ( none
| keyboard
| mouse
| `lightgun
| joystick
)
-dial_device ( none
| keyboard
| mouse
| lightgun
| joystick
)
-trackball_device ( none
| keyboard
| mouse
| lightgun
| joystick
)
-lightgun_device ( none
| keyboard
| mouse
| lightgun
| joystick
)
-positional_device ( none
| keyboard
| mouse
| lightgun
| joystick
)
-mouse_device ( none
| keyboard
| mouse
| lightgun
| joystick
)
Each of these options sets whether mouse, joystick or lightgun controllers should be enabled when running an emulated system that uses a particular class of analog inputs. These options can effectively set -mouse, -joystick and/or -lightgun depending on the type of inputs present on the emulated system. Note that these options will not override explicit -nomouse, -nojoystick and/or -nolightgun settings at a higher priority level (e.g. in a more specific INI file or on the command line).
For example, if you specify the option -paddle_device mouse, then mouse controls will automatically be enabled when you run a game that has paddle controls (e.g. Super Breakout), even if you specified -nomouse .
The default is to automatically enable mouse controls when running emulated systems with mouse inputs (-mouse_device mouse).
- Example:
mame sbrkout -paddle_device mouse
Tip
Note that these settings can override -nomouse, -nojoystick and/or -nolightgun depending on the inputs present on the emulated system.
Debugging Options¶
-[no]verbose / -[no]v
Displays internal diagnostic information. This information is very useful for debugging problems with your configuration.
The default is OFF (-noverbose).
- Example:
mame polepos -verbose
Tip
IMPORTANT: When reporting bugs to MAMEdev, please run with -verbose and include the resulting information.
-[no]oslog
Output
error.log
messages to the system diagnostic output, if one is present.By default messages are sent to the standard error output (this is typically displayed in the terminal or command prompt window, or saved to a system log file). On Windows, if a debugger is attached (e.g. the Visual Studio debugger or WinDbg), messages will be sent to the debugger instead.
The default is OFF (-nooslog).
- Example:
mame mappy -oslog
-[no]log
Creates a file called error.log which contains all of the internal log messages generated by the MAME core and system drivers. This can be used at the same time as -oslog to output the log data to both targets as well.
The default is OFF (-nolog).
- Example 1:
mame qbert -log- Example 2:
mame qbert -oslog -log
-[no]debug
Activates the integrated debugger. By default, pressing the backtick/tilde (~) key during emulation breaks into the debugger. MAME also breaks into the debugger after the initial soft reset on startup if the debugger is active. See MAME Debugger for information on using the debugger.
The default is OFF (-nodebug).
- Example:
mame indy_4610 -debug
-debugger <module>
Chooses the module to use for debugging the target system when the debug option is on. Available debugger modules depend on the host platform and build options.
Supported debugger modules:
- windows
Win32 GUI debugger (default on Windows). Only supported on Windows.
- qt
Qt GUI debugger (default on Linux). Supported on Windows, Linux and macOS, but only included on Linux by default. Set
USE_QTDEBUG=1
when compiling MAME to include the Qt debugger on Windows or macOS.- osx
Cocoa GUI debugger (default on macOS). Only supported on macOS.
- imgui
ImgUi GUI debugger displayed in first MAME window. Requires video option to be set to bgfx. Supported on all platforms with BGFX video output support.
- gdbstub
Acts as a remote debugging server for the GNU debugger (GDB). Only a small subset of the CPUs emulated by MAME are supported. Use the debugger_port option to set the listening port and the debugger_host option to set the address to bind to. Supported on all platforms with TCP socket support.
- Example:
mame ambush -debug -debugger qt
-debugscript <filename>
Specifies a file that contains a list of debugger commands to execute immediately upon startup.
The default is
NULL
(no commands).
- Example:
mame galaga -debug -debugscript testscript.txt
-[no]update_in_pause
Enables updating of the main screen bitmap while the system is paused. This means that the video update callback will be called repeatedly while the emulation is paused, which can be useful for debugging.
The default is OFF (-noupdate_in_pause).
- Example:
mame indy_4610 -update_in_pause
-watchdog <duration> / -wdog <duration>
Enables an internal watchdog timer that will automatically kill the MAME process if more than <duration> seconds passes without a frame update. Keep in mind that some systems sit for a while during load time without updating the screen, so <duration> should be long enough to cover that.
10-30 seconds on a modern system should be plenty in general.
By default there is no watchdog.
- Example:
mame ibm_5150 -watchdog 30
-debugger_host <address>
Set the IP address to listen on to accept GDB connections when using the GDB stub debugger module (see the debugger option).
The default is
localhost
.
- Example:
mame rfjet -debug -debugger gdbstub -debugger_host 0.0.0.0
-debugger_port <port>
Set the TCP port number to accept GDB connections on when using the GDB stub debugger module (see the debugger option).
The default is
23946
.
- Example:
mame rfjet -debug -debugger gdbstub -debugger_port 2159
-debugger_font <fontname> / -dfont <fontname>
Specifies the name of the font to use for debugger windows.
The Windows default font isLucida Console
.The Mac (Cocoa) default font is system fixed-pitch font default (typicallyMonaco
).The Qt default font isCourier New
.
- Example:
mame marble -debug -debugger_font "Comic Sans MS"
-debugger_font_size <points> / -dfontsize <points>
Specifies the size of the font to use for debugger windows, in points.
The Windows default size is9
points.The Qt default size is11
points.The Mac (Cocoa) default size is the system default size.
- Example:
mame marble -debug -debugger_font "Comic Sans MS" -debugger_font_size 16
Core Communication Options¶
-comm_localhost <string>
Local address to bind to. This can be a traditional
xxx.xxx.xxx.xxx
address or a string containing a resolvable hostname.The default is value is
0.0.0.0
(which binds to all local IPv4 addresses).
- Example:
mame arescue -comm_localhost 192.168.1.2
-comm_localport <string>
Local port to bind to. This can be any traditional communications port as an unsigned 16-bit integer (0-65535).
The default value is
15122
.
- Example:
mame arescue -comm_localhost 192.168.1.2 -comm_localport 30100
-comm_remotehost <string>
Remote address to connect to. This can be a traditional xxx.xxx.xxx.xxx address or a string containing a resolvable hostname.
The default is value is "
0.0.0.0
" (which binds to all local IPv4 addresses).
- Example:
mame arescue -comm_remotehost 192.168.1.2
-comm_remoteport <string>
Remote port to connect to. This can be any traditional communications port as an unsigned 16-bit integer (0-65535).
The default value is "
15122
".
- Example:
mame arescue -comm_remotehost 192.168.1.2 -comm_remoteport 30100
-[no]comm_framesync
Synchronize frames between the communications network.
The default is OFF (-nocomm_framesync).
- Example:
mame arescue -comm_remotehost 192.168.1.3 -comm_remoteport 30100 -comm_framesync
Core Misc Options¶
-[no]drc
Enable DRC (dynamic recompiler) CPU core if available for maximum speed.
The default is ON (-drc).
- Example:
mame ironfort -nodrc
-[no]drc_use_c
Force DRC to use the C code backend.
The default is OFF (-nodrc_use_c).
- Example:
mame ironfort -drc_use_c
-[no]drc_log_uml
Write DRC UML disassembly log.
The default is OFF (-nodrc_log_uml).
- Example:
mame ironfort -drc_log_uml
-[no]drc_log_native
Write DRC native disassembly log.
The default is OFF (-nodrc_log_native).
- Example:
mame ironfort -drc_log_native
-bios <biosname>
Specifies the specific BIOS to use with the current system, for systems that make use of a BIOS. The -listbios output will list all of the possible BIOS names for a system, as does the -listxml output.
The default is
default
.
- Example:
mame mslug -bios unibios33
-[no]cheat / -[no]c
Activates the cheat menu with autofire options and other tricks from the cheat database, if present. This also activates additional options on the slider menu for overclocking/underclocking.
Be advised that savestates created with cheats on may not work correctly with this turned off and vice-versa.
The default is OFF (-nocheat).
- Example:
mame dkong -cheat
-[no]skip_gameinfo
Forces MAME to skip displaying the system info screen.
The default is OFF (-noskip_gameinfo).
- Example:
mame samsho5 -skip_gameinfo
-uifont <fontname>
Specifies the name of a font file to use for the UI font. If this font cannot be found or cannot be loaded, the system will fall back to its built-in UI font. On some platforms fontname can be a system font name instead of a BDF font file.
The default is
default
(use the OSD-determined default font).
- Example:
mame -uifont "Comic Sans MS"
-ui <type>
Specifies the type of UI to use, either
simple
orcabinet
.The default is cabinet (-ui cabinet).
- Example:
mame -ui simple
-ramsize [n]
Allows you to change the default RAM size (if supported by driver).
- Example:
mame coco -ramsize 16K
-[no]confirm_quit
Display a Confirm Quit dialog to screen on exit, requiring one extra step to exit MAME.
The default is OFF (-noconfirm_quit).
- Example:
mame pacman -confirm_quit
-[no]ui_mouse
Displays a mouse cursor when using the built-in MAME user interface.
The default is ON (-ui_mouse).
- Example:
mame -ui_mouse
-language <language>
Specify a localization language found in the
languagepath
tree.
- Example:
mame -language Japanese
-[no]nvram_save
Save the NVRAM contents when exiting machine emulation. By turning this off, you can retain your previous NVRAM contents as any current changes made will not be saved. Turning this option off will also unconditionally suppress the saving of .nv files associated with some types of software cartridges.
The default is ON (-nvram_save).
- Example:
mame galaga88 -nonvram_save
Scripting Options¶
-autoboot_command "<command>"
Command string to execute after machine boot (in quotes " "). To issue a quote to the emulation, use """ in the string. Using \n will create a new line, issuing what was typed prior as a command.
This works only with systems that support natural keyboard mode.
- Example:
mame c64 -autoboot_delay 5 -autoboot_command "load """$""",8,1\n"
-autoboot_delay [n]
Timer delay (in seconds) to trigger command execution on autoboot.
- Example:
mame c64 -autoboot_delay 5 -autoboot_command "load """$""",8,1\n"
-autoboot_script / -script [filename.lua]
File containing scripting to execute after machine boot.
- Example:
mame ibm5150 -autoboot_script myscript.lua
-[no]console
Enables emulator Lua Console window.
The default of OFF (-noconsole).
- Example:
mame ibm5150 -console
-plugins
Enable the use of Lua Plugins.
The default is ON (-plugins).
- Example:
mame apple2e -plugins
-plugin [plugin shortname]
A list of Lua Plugins to enable, comma separated.
- Example:
mame alcon -plugin cheat,discord,autofire
-noplugin [plugin shortname]
A list of Lua Plugins to disable, comma separated.
- Example:
mame alcon -noplugin cheat
HTTP Server Options¶
-[no]http
Enable HTTP server.
The default is OFF (-nohttp).
- Example:
mame -http
-http_port <port>
Choose HTTP server port.
The default is
8080
.
- Example:
mame apple2 -http -http_port 6502
-http_root <rootfolder>
Choose HTTP server document root.
The default is
web
.
- Example:
mame apple2 -http -http_port 6502 -http_root C:\Users\me\appleweb\root
PortAudio Options¶
-pa_api API
Choose which API that PortAudio should use to talk to your sound hardware. You can use -verbose to see which APIs are available.
The default is
none
.
- Example 1:
mame -sound portaudio -verbose Attempting load of mame.ini ... PortAudio: API MME has 20 devices PortAudio: MME: " - Input" PortAudio: MME: "Microphone (3- USB Camera-B4.09" PortAudio: MME: "Line (AVerMedia Live Gamer HD 2" PortAudio: MME: "Digital Audio Interface (AVerMe" PortAudio: MME: "Headset Microphone (Razer Krake" ... PortAudio: MME: " - Output" PortAudio: MME: "Headset Earphone (Razer Kraken " PortAudio: MME: "Digital Audio (S/PDIF) (High De" PortAudio: MME: "NX-EDG27 (NVIDIA High Definitio" ... PortAudio: API Windows DirectSound has 20 devices PortAudio: Windows DirectSound: "Primary Sound Capture Driver" PortAudio: Windows DirectSound: "Headset Microphone (Razer Kraken 7.1 V2)" PortAudio: Windows DirectSound: "Primary Sound Driver" (default) PortAudio: Windows DirectSound: "Headset Earphone (Razer Kraken 7.1 V2)" PortAudio: Windows DirectSound: "Digital Audio (S/PDIF) (High Definition Audio Device)" PortAudio: Windows DirectSound: "NX-EDG27 (NVIDIA High Definition Audio)" ... PortAudio: API Windows WASAPI has 18 devices PortAudio: Windows WASAPI: "Headset Earphone (Razer Kraken 7.1 V2)" PortAudio: Windows WASAPI: "Digital Audio (S/PDIF) (High Definition Audio Device)" PortAudio: Windows WASAPI: "NX-EDG27 (NVIDIA High Definition Audio)" PortAudio: Windows WASAPI: "Headset Microphone (Razer Kraken 7.1 V2)" ... PortAudio: API Windows WDM-KS has 22 devices PortAudio: Windows WDM-KS: "Output (NVIDIA High Definition Audio)" PortAudio: Windows WDM-KS: "SPDIF Out (HD Audio SPDIF out)" PortAudio: Windows WDM-KS: "Headset Microphone (Razer Kraken 7.1 V2)" PortAudio: Windows WDM-KS: "Headset Earphone (Razer Kraken 7.1 V2)" PortAudio: Windows WDM-KS: "Microphone (VDVAD Wave)" PortAudio: Windows WDM-KS: "Speakers (VDVAD Wave)" ... PortAudio: Sample rate is 48000 Hz, device output latency is 218.67 ms PortAudio: Allowed additional buffering latency is 18.00 ms/864 frames- Example 2:
mame suprmrio -sound portaudio -pa_api "Windows WASAPI"
-pa_device device
Choose which sound device to output through. This would typically be one of the outputs on your sound card or a USB headset.
The default is
none
.
- Example:
mame suprmrio -sound portaudio -pa_api "Windows WASAPI" -pa_device "NX-EDG27 (NVIDIA High Definition Audio)"
-pa_latency latency
Choose the buffer size for PortAudio output; this is specified in seconds. Lower numbers have less latency but may increase stutter in the sound. Decimal places are supported. Try starting from 0.20 and decrease or increase until you find the best number your hardware and OS are capable of handling.
The default is
0
.
- Example:
mame suprmrio -sound portaudio -pa_api "Windows WASAPI" -pa_device "NX-EDG27 (NVIDIA High Definition Audio)" -pa_latency 0.20