Retroarch: Difference between revisions

From OoT Randomizer Wiki
(add changing ParaLLEl GFX plugin)
(42 intermediate revisions by 3 users not shown)
Line 1: Line 1:
'''by Raizuto'''
'''by Raizuto'''


RetroArch is the only cross-platform emulator supported by the Ocarina of Time Item Randomizer staff, and the number 1 recommended one. It is also possible to use it to play a vast number of platforms other than N64 as well. This might just make it your emulator of choice once you get used to using it.
RetroArch is the only cross-platform emulator supported by the Ocarina of Time Item Randomizer staff, and the number 1 recommended emulator regardless of platform. It is also possible to use it to play a vast number of platforms other than N64 as well. This might just make it your emulator of choice once you get used to using it.


Install [http://www.retroarch.com/index.php?page=platforms RetroArch] by choosing the download for your operating system. If you are using Windows and RetroArch crashes upon opening for you using the Windows 10/8/7 32bit and 64bit options, try installing the Windows XP 32bit or 64bit installations instead.
'''IMPORTANT MESSAGE TO MAC USERS''': Currently the only N64 core compatible with mac is not in the RA library. A mirror is available for download in #setup-support in our Discord. See the pin by shiroaeli.
 
== Installing RetroArch ==
[[File:RetroArch-Download-Stable.jpeg|none|thumb|RetroArch Downloads Page and Download Stable button]]
Head over to the [http://www.RetroArch.com/index.php?page=platforms RetroArch downloads page] and click the button labeled <kbd><samp>Download Stable</samp></kbd> Run the installer file it downloads.
 
=== Windows Specific Installation ===
On Windows you may get a popup when trying to run the installer that warns you if you do not have <samp>DirectX 9.0c</samp> installed<sup>1</sup>. Press <kbd><samp>OK</samp></kbd> to continue. Click <kbd><samp>Next &gt;</samp></kbd> until it asks you where you would like to install RetroArch<sup>2</sup>. The default path should be <var>C:\Users\&lt;yourusername&gt;\AppData\Roaming\RetroArch</var>. If it does not display this location it is recommended to copy and paste the following text into the box: <kbd><samp>%AppData%\RetroArch</samp></kbd> and then continue clicking <kbd><samp>Next &gt;</samp></kbd>. Soon you will see the <samp>Choose Components</samp> screen<sup>3</sup>. Make sure you click the checkbox next to <kbd><samp>DirectX 9.0c Runtime</samp></kbd> before clicking <kbd><samp>Next &gt;</samp></kbd>. Keep clicking <kbd><samp>Next &gt;</samp></kbd> until the <samp>Install</samp> button appears. Once you click <kbd><samp>Install</samp></kbd> RetroArch will begin installing.
 
Before RetroArch finishes installing it should pop up the DirectX installer. Click <kbd><samp>Next &gt;</samp></kbd> until you get to the screen offering to install the Bing Bar<sup>4</sup>. You should uncheck <kbd><samp>Install the Bing Bar</samp></kbd> before clicking <kbd><samp>Next &gt;</samp></kbd>. Once you finish the DirectX installation the RetroArch installation will finish as well.
<gallery>
File:RetroArch-Windows-DirectXWarning.jpeg|1. The DirectX not installed warning.
File:RetroArch-Windows-InstallLocation.jpeg|2. The location you install to should be similar to the one displayed here. Copy the value displayed above if it doesn't.
File:RetroArch-Windows-ChooseComponents.jpeg|3. Make sure DirectX 9.0c Runtime is checked.
File:RetroArch-Windows-DirectXBingBar.jpeg|4. Make sure you uncheck this so you don't end up with software you don't need on your computer.
</gallery>


== Install a RetroArch Core ==
== Install a RetroArch Core ==
You should now be at the <samp>Main Menu</samp> of RetroArch<sup>1</sup>. You can switch between the different menus on the left side of the screen when you are on the top-most sub-menu of a menu. If you can't see the left sidebar with the different menus listed and you need to switch which menu you are in, you can press <kbd>Backspace</kbd>, <kbd>X</kbd>, or the <kbd>Right Mouse Button</kbd> until you see it again. To open a menu, submenu, or option you can press <kbd>Enter</kbd> or <kbd>Z</kbd> while it is highlighted, or <kbd>Left Mouse Button</kbd> while hovering over it. ''Keep in mind that these are the default controls in RetroArch''. If you change these keyboard bindings in the <samp>Settings</samp> menu, you'll have to use the buttons you bound to A or Start to select, and the buttons you bound to B or Back to go back to the previous menu. Using the mouse controls should always work properly, so we will assume you are using them throughout the rest of the guide.
On the <samp>Main Menu</samp> click on the <kbd><samp>Load Core</samp></kbd> option. In the <samp>Load Core</samp> submenu, you will normally see your installed cores. Since you just installed RetroArch you won't see any. Click the <kbd><samp>Download a Core<samp></kbd> option<sup>2</sup>. In the <samp>Core Updater</samp> menu that appears, scroll down to the <samp>Nintendo - Nintendo 64</samp> options. It is recommended that you choose the <samp>Nintendo - Nintendo 64 (ParaLLEl N64)</samp> core option<sup>3</sup>. You can also choose the <samp>Nintendo - Nintendo 64 (Mupen64Plus-Next)</samp> core option if you want, but be aware that the it can have the following issues: [[#Mupen64Plus Next Freezes|Mupen64Plus Next Freezes]] and [[#Mupen64Plus Next Epona Carrots|Mupen64Plus Next Epona Carrots]]. '''Windows Users:''' the <samp>Nintendo - Nintendo 64 (Mupen64Plus-Next GLES3)</samp> option should not be chosen. This is a special build of the Mupen64Plus-Next core intended to run on XBox One devices. '''It will not run on Windows PCs'''.
<gallery>
File:RetroArch-InstallCore-MainMenu.jpeg|1. The Main Menu of RetroArch. You'll want to return here often.
File:RetroArch-InstallCore-DownloadCore.jpeg|2. You'll need to download a core before you can play any ROMs.
File:RetroArch-InstallCore-ParaLLEl.jpeg|3. ParaLLEl N64 is known to be the most stable core for the Ocarina of Time Randomizer.
</gallery>
== Configure RetroArch ==
From the top menu level of the <samp>Main Menu</samp> click on the <kbd><samp>Settings</samp></kbd> menu below the <samp>Main Menu</samp> in the sidebar on the left. Scroll down to <kbd><samp>Saving</samp></kbd> and change <kbd><samp>SaveRAM Autosave Interval</samp></kbd><sup>1</sup> to <kbd><samp>10</samp></kbd> seconds by clicking it, and the scrolling down to <kbd><samp>10 seconds</samp></kbd>.
Next, go back to the top level menu of <samp>Settings</samp>. Scroll down and select the option <kbd><samp>Directory</samp></kbd><sup>2</sup>. In the menu this opens scroll down and select the option called <kbd><samp>File Browser</samp></kbd><sup>3</sup>. You will be presented with an overview of your system partitions. Navigate through your computer files to the folder you keep your ROMs in. '''They will not show up yet'''. Choose <kbd><samp>Use this directory</samp></kbd><sup>4</sup> anyway. Most browsers will save your randomizer ROM to your Downloads folder by default<sup>5</sup>. However, if you are using the downloaded version of the Ocarina of Time Randomizer the default location for your patched ROMs is a folder called <samp>Output</samp> next to the <samp>.exe</samp> file you double click to start the randomizer.
Once you have finished configuring RetroArch you must properly restart it. ''Do not press <kbd>Esc</kbd> or the X in the top right corner.'' Go back to the <kbd><samp>Main Menu</samp></kbd> and move all the way down to the option near the bottom <kbd><samp>Quit RetroArch</kbd></samp><sup>6</sup>. Once you reopen RetroArch go to <kbd><samp>Load Content</samp> ⇒ <samp>Start directory</samp></kbd>. You should now see your ROMs<sup>7</sup>. When you choose one of your ROMs it may ask you which core you want to use if you downloaded more than one of them. It is recommended that you choose <kbd><samp>Nintendo - Nintendo 64 (ParaLLEl N64)</samp></kbd><sup>8</sup> for the most stable experience.
<gallery>
File:RetroArch-Configure-AutoSave.png|1. With this option RetroArch will periodically save your save data to disk. This will prevent most data loss in the event of a crash.
File:RetroArch-Configure-Directory.jpeg|2. This option lets you set where RetroArch saves and looks for various files on your computer.
File:RetroArch-Configure-FileBrowser.jpeg|3. File Browser defines the <samp>Start Directory</samp> that RetroArch uses when you are picking your ROM.
File:RetroArch-Configure-UseThisDirectory.jpeg|4. Your ROM files will not show up here! You still want to click &lt;Use this directory&gt; so that they will show up in a couple more steps.
File:RetroArch-Configure-Downloads.jpeg|5. You probably want your File Browser setting to have a similar path to this image.
File:RetroArch-Configure-Restart.jpeg|6. RetroArch will delete any changes you made if you do not restart it properly. Always use this option to ensure your settings get saved.
File:RetroArch-Configure-StartDirectory.jpeg|7. Your ROMs should now appear when you select this menu option if you set your <samp>File Browser</samp> directory properly. If you don't you should go back to that step and try again.
File:RetroArch-Configure-SelectCore.jpeg|8. ParaLLEl N64 core is the most stable core for the Ocarina of Time Randomizer.
</gallery>


Go to ''Load Core'' on the main menu. [[File:Retroarch-Load-core.png|none|thumb|Load Core]]
== Keyboard Configuration ==
If you are going to use a controller, [[#Controller Configuration|skip this section]].


Then select ''Download Core...''
Head to <kbd><samp>Settings</samp> ⇒ <samp>Input</samp> ⇒ <samp>Port 1 Input Binds</samp></kbd>. An example of some control binds when using a keyboard can be found [https://docs.google.com/document/d/1F8JOk-eqoowZyeYtoF3XLBh1EwYULddo6ZyFgFYxU5M/edit here].


[[File:RA-Download-Core.png|none|thumb|Download Core]]
== Controller Configuration ==


After the core index list populates, go down until you find ''Nintendo - Nintendo 64 (ParaLLEl N64)'' and install it. If this core gives you issues you can try ''Nintendo - Nintendo 64 (Mupen64Plus - Next)'' however it is likely to crash somewhat frequently. To help prevent this try [[#Mupen64plus Next crashes|changing the Max Texture Cache Size]] after following the rest of the guide.
First, take a look at the [[Controller Setup]] guide. Ensure your controller is calibrated, and if you are using one of the controllers with additional setups steps in that guide make sure you follow them.


[[File:Retroarch 01.png|none|thumb|ParaLLEl Core]]
If your controls don't feel quite right, while running the ROM press <kbd>F1</kbd> to access the <kbd><samp>Quick Menu</samp> ⇒ <samp>Options</samp></kbd> menu. If your stick causes input without you trying to, change the <samp>Analog Deadzone</samp> to <kbd><samp>10</samp></kbd> or higher if that is not enough. If you aren't able to both walk and run increase <samp>Analog Sensitivity</samp> to make it easier to run. Decrease it to make it easier to walk.


Now that the core is installed you can backspace back out to the main menu.
=== Remap Your Controls ===
You'll probably need to customize your controller inputs by loading your ROM and pressing the <kbd>F1</kbd> key to bring up the RetroArch <samp>Quick Menu</samp>. Choose <kbd><samp>Controls ⇒ Port 1 Controls</samp></kbd>. Highlight the control on your controller on the left side and press <kbd>←</kbd> and <kbd>→</kbd> to cycle through the available N64 controller options on the right side.


== Configure RetroArch ==
Make sure <samp>C-Buttons Mode</samp> is not bound to any of your controls. This is intended for controllers without enough buttons/a right analog stick to map C-Buttons to and usually causes controller issues.


Move over to the ''Settings'' column in the menu. Head down to ''Saving'' and change ''SaveRAM Autosave Interval'' to 10 seconds by selecting it and pressing the right arrow key.
==== Gamecube Style C-Buttons ====
If you want to emulate the Gamecube controller's style of C-Buttons, where they are bound to the right analog stick and the the extra face buttons on your controller, you need to enable another setting. Press <kbd>F1</kbd> to open the <samp>Quick Menu</samp> and scroll down and select <kbd><samp>Options</samp></kbd>. Scroll down and switch the <samp>Independant C-button Controls</samp> from <samp>False</samp> to <kbd><samp>True</samp></kbd>. This will add controls like <samp>C-Down</samp> and <samp>C-Up</samp> to the right side of the Controls remappings.


[[File:RA-Saving-Interval.png|none|thumb|RA-Saving-Interval.png]]
Head back to the <samp>Quick Menu</samp> and go over to <kbd><samp>Controls</samp> ⇒ <samp>Port 1 Controls</samp></kbd> and map your face buttons to the <samp>C-*</samp> options, and your right analog stick to the <samp>C Buttons *</samp> analog control values.


Next, go back to the ''Settings'' column and go down to ''Directory''
=== GameCube Controller Setup ===


<gallery>
==== MayFlash GameCube Adapter ====
File:Retroarch 02.png|Directory
Make sure the switch on the back of your controller is set to <kbd><samp>PC</samp></kbd>. If you just downloaded RetroArch the controller should just work. If not, go to <kbd><samp>Online Updater</samp></kbd> on the <samp>Main Menu</samp> and choose <kbd><samp>Update Joypad Profiles</samp></kbd>. Once it finishes downloading and extracting the zip file, restart RetroArch.
File:Retroarch 03.png|Downloads
</gallery>


Select ''Downloads'' with <code>Enter</code>. You will be presented with an overview of your system partitions.
Your controller should now be working. If it isn't you can try the different controller ports or go to <kbd><samp>Settings</samp> ⇒ <samp>Input</samp> ⇒ <samp>Port 1 Input Binds</samp></kbd>. Highlight <samp>Device Index</samp> and press <kbd>←</kbd> or <kbd>→</kbd> to choose the correct MAYFLASH Controller number.


[[File:Retroarch 04.png|none|thumb|Filesystem]]
==== Using Custom Drivers (Zadig) ====
Make sure the GCN USB Adapter program is running.


Navigate through your computer files to the folder you keep your ROMs in. '''They will not show up yet'''. Choose ''Use this directory'' anyway. If you are using the downloaded version of the Ocarina of Time Randomizer the default location for your patched ROMs is a folder called ''Output'' next to the <code>.exe</code> file you double click to start the randomizer.
Start RetroArch and go to <kbd><samp>Settings</samp> ⇒ <samp>Drivers</samp></kbd> and make sure <samp>Joypad Driver</samp> is set to <kbd><samp>xinput</samp></kbd>. Then use the <kbd><samp>Quit RetroArch</samp></kbd> option in the main menu to properly close RetroArch and save your new configuration if you changed it.


Once you have finished configuring RetroArch you must properly restart it. ''Do not press <code>Esc</code> or the X in the top right corner.'' Go to the far left column in the menu and move all the way down to the option near the bottom ''Quit Retroarch''. Once you reopen RetroArch you should be able to load your ROMs in the ''Downloads'' section of the ''Load Content'' menu.
You'll want to save [https://pastebin.com/raw/QAhXFvUS this configuration file] as <kbd><samp>vJoy_Device_GameCube.cfg</samp></kbd> in your RetroArch XInput autoconfig directory. You should find this folder by pasting <kbd><samp>%AppData%\RetroArch\autoconfig\xinput</samp></kbd> in the Windows Explorer address bar and pressing <kbd>Enter</kbd>. Once that file is in place start RetroArch. You should get a message saying something like <samp>vJoy device #1 configured in Port #0</samp>.


[[File:Retroarch 05.png|none|thumb|ROMs under here appear after restarting RetroArch]]
If your controller is not working still, click on the <kbd><samp>Windows Gamepad Info</samp></kbd> button to bring up the list of connected controllers on your computer.<sup>1</sup> The vJoy gamepads should be in order of what number RetroArch is expecting. Try each one by clicking it's entry, pressing the <kbd><samp>Properties</samp></kbd> button and moving the control stick. Whichever on causes the cursor in the square to move is the number you want to remember. Go back to RetroArch and head to <kbd><samp>Settings</samp> ⇒ <samp>Input</samp> ⇒ <samp>Port 1 Input Binds</samp></kbd>. Highlight <samp>Device Index</samp> and press <kbd>←</kbd> or <kbd>→</kbd> to choose the correct vJoy Device number.<sup>2</sup> You may have to do this every time you restart the driver application.


== Controller Configuration ==
Your controller should now be working.


If your controls don't feel quite right, access the Quick Menu by pressing <code>F1</code> while a ROM is loaded. Go down to ''Options'' and change the deadzone to 10 and analog sensitivity to 80. You may wish to make further personal adjustments as necessary as well.
<gallery>
File:RetroArch-GameCube-WindowsGameControllers.png|1. The Windows Game Controller dialog with the list of vJoy Devices.
RetroArch-GameCube-vJoyDeviceNumber.png|2. vJoy Device #4 was the correct one for this time.
</gallery>


== HiRes Texture Packs ==
== HiRes Texture Packs ==
Line 52: Line 98:
== Tips ==
== Tips ==


*To unbind any button/key hit the delete key on your keyboard in the input settings.  
*To unbind any button/key hit the <kbd>Delete</kbd> key on your keyboard in the input settings.  
*'''Never''' close RA via it’s top right X, close it from far left Main Menu ''Quit Retroarch''.  
*'''Never''' close RA via it’s top right X, close it from far left Main Menu <kbd><samp>Quit RetroArch</samp></kbd>.  
*If you want Retroarch to keep running in the background, go over to the ''Settings'' column in the menu, then down to ''User Interface'', hit enter and set ''Don’t run in the background'' to ''OFF''.  
*If you want RetroArch to keep running in the background, go over to the <samp>Settings</samp> column in the menu, then down to <samp>User Interface</samp>, hit <kbd>Enter</kbd> and set <samp>Don’t run in the background</samp> to <kbd><samp>OFF</samp></kbd>.
*To enable the FPS display, go to <kbd><samp>Settings</samp> ⇒ <samp>On-Screen Display</samp> ⇒ <samp>On-Screen Notifications</samp></kbd> and switch <samp>On-Screen Notifications</samp> to <kbd>ON</kbd> if it is not already. Then, change <samp>Display Framerate</samp> to <kbd>ON</kbd>.
*To be able to position the FPS counter, go to <kbd><samp>Settings</samp> ⇒ <samp>On-Screen Display</samp> ⇒ <samp>On-Screen Notifications</samp></kbd> and set <samp>Graphics Widgets</samp> to <kbd><samp>OFF</samp></kbd> and then restart RetroArch.




If your controller does not have a default profile or you are using a keyboard, the following information may be helpful.
If your controller does not have a default profile or you are using a keyboard, the following information may be helpful.
*Don't alter the Main Menu bindings for controllers that have default profiles. Open the Quick Menu and change the button mapping there instead.
*Don't alter the Main Menu bindings for controllers that have default profiles. Open the Quick Menu and change the button mapping there instead.
*Left side user input binds (the <code>Delete</code> key will delete any binding)
*Left side user input binds (the <kbd>Delete</kbd> key will delete any binding)
**'''B button''' is equivalent to N64 A Button  
**'''B button''' is equivalent to N64 A Button  
**'''Y button''' is equivalent to N64 B Button  
**'''Y button''' is equivalent to N64 B Button  
Line 67: Line 115:
**'''Movement:'''  
**'''Movement:'''  
***Left analog X+ = Right  
***Left analog X+ = Right  
***Left analog X-&nbsp; = Left  
***Left analog X- = Left  
***Left analog Y+ = Down  
***Left analog Y+ = Down  
***Left analog Y-&nbsp; = Up   
***Left analog Y- = Up   
**'''<ins>C-Buttons/C-Stick:</ins>'''  
**'''C-Buttons/C-Stick:'''  
***Right analog X+ = C-Right  
***Right analog X+ = C-Right  
***Right analog X-&nbsp; = C-Left  
***Right analog X- = C-Left  
***Right analog Y+ = C-Down  
***Right analog Y+ = C-Down  
***Right analog Y-&nbsp; = C-Up
***Right analog Y- = C-Up


== Common Issues ==
== Common Issues ==


There are several issues that crop up often when new users try out RetroArch.
There are several issues that crop up often when new users try out RetroArch.
=== My A and B Buttons Are Swapped On The Menu ===
Go into <kbd><samp>Settings</samp> ⇒ <samp>Input</samp> ⇒ <samp>Menu Controls</samp></kbd> and change the <kbd><samp>Menu Swap OK & Cancel Buttons</samp></kbd> option.


=== No Audio ===
=== No Audio ===


Go into the Driver Menu (first thing under the Settings Menu Column) and change the Audio Driver from xaudio to dsound. Then quit RetroArch properly via the Main Menu and restart it.  
Go into the <kbd><samp>Settings</samp> ⇒ <samp>Drivers</samp></kbd> menu and change the <samp>Audio Driver</samp> from <samp>xaudio</samp> to <kbd><samp>dsound</samp></kbd>. Then quit RetroArch properly via the Main Menu and restart it.
 
=== RetroArch crash when loading ROM ===
 
If using the <samp>Nintendo - Nintendo 64 (Mupen64Plus)</samp> core, try the <kbd><samp>Nintendo - Nintendo 64 (ParaLLEl N64)</samp></kbd> core instead. If using the <samp>Nintendo - Nintendo 64 (ParaLLEl N64)</samp> core, try the <kbd><samp>Nintendo - Nintendo 64 (Mupen64Plus)</samp></kbd> core instead.
 
=== Mupen64Plus Next Freezes ===
 
This is an issue with the Mupen64Plus Next core. A workaround has been implemented as an option in the latest version, which at least avoids these crashes, so make sure your core is updated by redownloading it from the <samp> Download a Core</samp> section in the <samp>Load Core</samp> menu. After loading a ROM press <kbd>F1</kbd> to open the <samp>Quick Menu</samp>. Under <samp>Options</samp> Move down to <samp>Ignore emulated TLB Exceptions</samp> and press the <kbd>→</kbd> arrow key once. The selection should change from <samp>Don't Ignore</samp> to <samp>Ignore TLB Exceptions if not using TLB</samp>. If it does not, just press the key again.
 
Once you have changed the option, press <kbd>F1</kbd>, go down to <samp>Close Content</samp> and press <kbd>Enter</kbd>. This will either close the ROM and emulator core, or crash the emulator. Both outcomes are fine.
 
That being said, this is a workaround and not a fix, and whenever the game would've crashed without it, it will display Epona Carrots instead, which will slightly hinder your gameplay because it also overrides some of the A-button functions. What you should do if this happens and how you can mitigate this will be explained in the next section.


=== Retroarch crash when loading ROM ===
=== Mupen64Plus Next Epona Carrots ===


If using the Nintendo - Nintendo 64 (Mupen64Plus) core, try the Nintendo - Nintendo 64 (ParaLLEl N64) core instead. If using the& Nintendo - Nintendo 64 (ParaLLEl N64) core, try the Nintendo - Nintendo 64 (Mupen64Plus) core instead.  
This is a side-effect of the quick-fix done to solve the above issue in certain versions of Mupen64Plus Next. When this occurs your ability to play the game as normal is slightly hindered, but still playable. To restore normal functionality you will have to save the game, press <kbd>F1</kbd>, go down to <samp>Close Content</samp> and press <kbd>Enter</kbd>. This will either close the ROM and emulator core, or crash the emulator. Both outcomes are fine and relaunching the ROM you were playing will no longer have the Epona carrots displaying.


=== Mupen64plus Next crashes ===
Note: ''Selecting <kbd><samp>Restart</samp></kbd> will not remove the carrot display. This may be due to the core's reset being hardcoded to be a soft reset. You '''must''' choose <kbd><samp>Close Content</samp></kbd>.''


Mupen64plus Next core is known to crash more frequently than the older mupen64plus core. This may be related to using a newer GlideN64 version, [https://github.com/libretro/mupen64plus-libretro-nx/issues/49 which seems to have issues with the texture cache]. To help reduce how often it crashes you can try changing the Max Texture Cache Size. After loading a ROM press <code>F1</code> to open the "Quick Menu" and move down to "Options" and press <code>Enter</code>. Move down to "Max Texture Cache Size" and press the <code>→</code> arrow key once. The selection should change from <code>8000</code> to <code>4000</code>. If it does not, just press the key again.
To help reduce how often this bug happens you can try changing the <samp>CPU core</samp>. After loading a ROM press <kbd>F1</kbd> to open the <samp>Quick Menu</samp>. Under <samp>Options</samp> Move down to <samp>CPU Core</samp> and press the <kbd>→</kbd> arrow key once. The selection should change from <samp>dynamic_recompiler</samp> to <samp>cached_interpreter</samp>. If it does not, just press the key again.


Once you have changed the option, press <code>Backspace</code> twice to return to the "Main Menu" and select <code>Quit Retroarch</code> to close RetroArch. Simply run RetroArch and open the ROM again and your mupen64plus Next core should be running with a smaller texture cache, which hopefully allows you to play at least twice as long.
Once you have changed the option, press <kbd>F1</kbd>, go down to <samp>Close Content</samp> and press <kbd>Enter</kbd>. This will either close the ROM and emulator core, or crash the emulator. Both outcomes are fine and relaunching the ROM you were playing will no longer have the Epona carrots displaying. Your Mupen64Plus Next core should be running with the more stable, albeit slightly slower, cached interpreter.


=== Boots are equipped / Ocarina pulled out randomly while walking ===
=== Boots are equipped / Ocarina pulled out randomly while walking === <!-- This is a reasonably common issue in #setup-support. Perhaps "check if this setting is off" can be added to the setup section of the guide? -->


Go to the input menu and set 'Analog to Digital' to 'None'
Go to the <kbd><samp>Settings</samp> ⇒ <samp>Input</samp> ⇒ <samp>Port 1 Input Binds</samp></kbd> menu and set <samp>Analog to Digital</samp> to <kbd><samp>None</samp></kbd>


=== One of My Buttons Won't Work ===
=== One of My Buttons Won't Work ===


If you messed with the Main Menu User Input Binds you likely configured something wrong. It is not recommended to ever modify controller binds this way unless your controller doesn't have a built in profile. To reset your controller bindings to their default you have to load the default RetroArch.cfg again.
If you messed with the Main Menu User Input Binds you likely configured something wrong. It is not recommended to ever modify controller binds this way unless your controller doesn't have a built in profile. To reset your controller bindings to their default you have to load the default <samp>RetroArch.cfg</samp> again.


If you have a ROM loaded, start by pressing F1 to open the Quick Menu then press <code>Backspace</code> to get back to the Main Menu.
If you have a ROM loaded, start by pressing <kbd>F1</kbd> to open the <samp>Quick Menu</samp> then press <kbd>Backspace</kbd> to get back to the <samp>Main Menu</samp>.


Go to the far left menu item, ''Main Menu''. Move down to ''Configurations'' and press <code>Enter</code>. Select ''<Parent directory>'' and hit <code>Enter</code>. Scroll down to the file <code>retroarch.default.cfg</code> and press <code>Enter</code>.
Go to the far left menu item, <samp>Main Menu</samp>. Move down to '<samp>Configurations</samp> and press <kbd>Enter</kbd>. Select <samp><Parent directory></samp> and hit <kbd>Enter</kbd>. Scroll down to the file <samp>RetroArch.default.cfg</samp> and press <kbd>Enter</kbd>.


=== ParaLLEl Black Screen or Crashes ===
=== ParaLLEl Black Screen or Crashes ===


If you are able to launch the ParaLLEl core but get a black screen, or frequently crash while pausing, try changing the video plugin it is using. Press <code>F1</code> to open the '''Quick Menu''' and move down to '''Options''' and press <code>Enter</code>. Next, move down to '''GFX Plugin''' and press the <code>→</code> arrow key once. Once you have changed the option, press <code>Backspace</code> twice to return to the "Main Menu" and select <code>Quit Retroarch</code> to close RetroArch. Simply run RetroArch and open the ROM again and your ParaLLEl core should be running the new plugin you selected. Try each one and see if any of them work for you. If they do not, you may want to try the mupen64plus Next core instead.
If you are able to launch the ParaLLEl core but get a black screen, or frequently crash while pausing, try changing the video plugin it is using. Press <kbd>F1</kbd> to open the <samp>Quick Menu</samp> and move down to <samp>Options</samp> and press <kbd>Enter</kbd>. Next, move down to <samp>GFX Plugin</samp> and press the <kbd>→</kbd> arrow key once. Once you have changed the option, press <kbd>Backspace</kbd> twice to return to the <samp>Main Menu</samp> and select <kbd><samp>Quit RetroArch</samp></kbd> to close RetroArch. Simply run RetroArch and open the ROM again and your ParaLLEl core should be running the new plugin you selected. Try each one and see if any of them work for you. If they do not, you may want to try the Mupen64Plus Next core instead.
 
=== My Remapping in Quick Menu Controls Won't Save ===
 
If your remapping won't save even after using <kbd><samp>Quit RetroArch</samp></kbd> in the main menu, you may have to explicitly save the reamppings. Open the <samp>Quick Menu</samp> with <kbd>F1</kbd>, go down to <kbd><samp>Controls</samp></kbd> and map your controls how you wish. Once you have done so, go back to the <samp>Controls</samp> menu. Near the top of the menu is a <samp>Save Core Remap File</samp> option. Select this to save these controller binds for all randomizer ROMs you open in the future.

Revision as of 06:44, 15 September 2020

by Raizuto

RetroArch is the only cross-platform emulator supported by the Ocarina of Time Item Randomizer staff, and the number 1 recommended emulator regardless of platform. It is also possible to use it to play a vast number of platforms other than N64 as well. This might just make it your emulator of choice once you get used to using it.

IMPORTANT MESSAGE TO MAC USERS: Currently the only N64 core compatible with mac is not in the RA library. A mirror is available for download in #setup-support in our Discord. See the pin by shiroaeli.

Installing RetroArch

RetroArch Downloads Page and Download Stable button

Head over to the RetroArch downloads page and click the button labeled Download Stable Run the installer file it downloads.

Windows Specific Installation

On Windows you may get a popup when trying to run the installer that warns you if you do not have DirectX 9.0c installed1. Press OK to continue. Click Next > until it asks you where you would like to install RetroArch2. The default path should be C:\Users\<yourusername>\AppData\Roaming\RetroArch. If it does not display this location it is recommended to copy and paste the following text into the box: %AppData%\RetroArch and then continue clicking Next >. Soon you will see the Choose Components screen3. Make sure you click the checkbox next to DirectX 9.0c Runtime before clicking Next >. Keep clicking Next > until the Install button appears. Once you click Install RetroArch will begin installing.

Before RetroArch finishes installing it should pop up the DirectX installer. Click Next > until you get to the screen offering to install the Bing Bar4. You should uncheck Install the Bing Bar before clicking Next >. Once you finish the DirectX installation the RetroArch installation will finish as well.

Install a RetroArch Core

You should now be at the Main Menu of RetroArch1. You can switch between the different menus on the left side of the screen when you are on the top-most sub-menu of a menu. If you can't see the left sidebar with the different menus listed and you need to switch which menu you are in, you can press Backspace, X, or the Right Mouse Button until you see it again. To open a menu, submenu, or option you can press Enter or Z while it is highlighted, or Left Mouse Button while hovering over it. Keep in mind that these are the default controls in RetroArch. If you change these keyboard bindings in the Settings menu, you'll have to use the buttons you bound to A or Start to select, and the buttons you bound to B or Back to go back to the previous menu. Using the mouse controls should always work properly, so we will assume you are using them throughout the rest of the guide.

On the Main Menu click on the Load Core option. In the Load Core submenu, you will normally see your installed cores. Since you just installed RetroArch you won't see any. Click the Download a Core option2. In the Core Updater menu that appears, scroll down to the Nintendo - Nintendo 64 options. It is recommended that you choose the Nintendo - Nintendo 64 (ParaLLEl N64) core option3. You can also choose the Nintendo - Nintendo 64 (Mupen64Plus-Next) core option if you want, but be aware that the it can have the following issues: Mupen64Plus Next Freezes and Mupen64Plus Next Epona Carrots. Windows Users: the Nintendo - Nintendo 64 (Mupen64Plus-Next GLES3) option should not be chosen. This is a special build of the Mupen64Plus-Next core intended to run on XBox One devices. It will not run on Windows PCs.

Configure RetroArch

From the top menu level of the Main Menu click on the Settings menu below the Main Menu in the sidebar on the left. Scroll down to Saving and change SaveRAM Autosave Interval1 to 10 seconds by clicking it, and the scrolling down to 10 seconds.

Next, go back to the top level menu of Settings. Scroll down and select the option Directory2. In the menu this opens scroll down and select the option called File Browser3. You will be presented with an overview of your system partitions. Navigate through your computer files to the folder you keep your ROMs in. They will not show up yet. Choose Use this directory4 anyway. Most browsers will save your randomizer ROM to your Downloads folder by default5. However, if you are using the downloaded version of the Ocarina of Time Randomizer the default location for your patched ROMs is a folder called Output next to the .exe file you double click to start the randomizer.

Once you have finished configuring RetroArch you must properly restart it. Do not press Esc or the X in the top right corner. Go back to the Main Menu and move all the way down to the option near the bottom Quit RetroArch6. Once you reopen RetroArch go to Load ContentStart directory. You should now see your ROMs7. When you choose one of your ROMs it may ask you which core you want to use if you downloaded more than one of them. It is recommended that you choose Nintendo - Nintendo 64 (ParaLLEl N64)8 for the most stable experience.

Keyboard Configuration

If you are going to use a controller, skip this section.

Head to SettingsInputPort 1 Input Binds. An example of some control binds when using a keyboard can be found here.

Controller Configuration

First, take a look at the Controller Setup guide. Ensure your controller is calibrated, and if you are using one of the controllers with additional setups steps in that guide make sure you follow them.

If your controls don't feel quite right, while running the ROM press F1 to access the Quick MenuOptions menu. If your stick causes input without you trying to, change the Analog Deadzone to 10 or higher if that is not enough. If you aren't able to both walk and run increase Analog Sensitivity to make it easier to run. Decrease it to make it easier to walk.

Remap Your Controls

You'll probably need to customize your controller inputs by loading your ROM and pressing the F1 key to bring up the RetroArch Quick Menu. Choose Controls ⇒ Port 1 Controls. Highlight the control on your controller on the left side and press and to cycle through the available N64 controller options on the right side.

Make sure C-Buttons Mode is not bound to any of your controls. This is intended for controllers without enough buttons/a right analog stick to map C-Buttons to and usually causes controller issues.

Gamecube Style C-Buttons

If you want to emulate the Gamecube controller's style of C-Buttons, where they are bound to the right analog stick and the the extra face buttons on your controller, you need to enable another setting. Press F1 to open the Quick Menu and scroll down and select Options. Scroll down and switch the Independant C-button Controls from False to True. This will add controls like C-Down and C-Up to the right side of the Controls remappings.

Head back to the Quick Menu and go over to ControlsPort 1 Controls and map your face buttons to the C-* options, and your right analog stick to the C Buttons * analog control values.

GameCube Controller Setup

MayFlash GameCube Adapter

Make sure the switch on the back of your controller is set to PC. If you just downloaded RetroArch the controller should just work. If not, go to Online Updater on the Main Menu and choose Update Joypad Profiles. Once it finishes downloading and extracting the zip file, restart RetroArch.

Your controller should now be working. If it isn't you can try the different controller ports or go to SettingsInputPort 1 Input Binds. Highlight Device Index and press or to choose the correct MAYFLASH Controller number.

Using Custom Drivers (Zadig)

Make sure the GCN USB Adapter program is running.

Start RetroArch and go to SettingsDrivers and make sure Joypad Driver is set to xinput. Then use the Quit RetroArch option in the main menu to properly close RetroArch and save your new configuration if you changed it.

You'll want to save this configuration file as vJoy_Device_GameCube.cfg in your RetroArch XInput autoconfig directory. You should find this folder by pasting %AppData%\RetroArch\autoconfig\xinput in the Windows Explorer address bar and pressing Enter. Once that file is in place start RetroArch. You should get a message saying something like vJoy device #1 configured in Port #0.

If your controller is not working still, click on the Windows Gamepad Info button to bring up the list of connected controllers on your computer.1 The vJoy gamepads should be in order of what number RetroArch is expecting. Try each one by clicking it's entry, pressing the Properties button and moving the control stick. Whichever on causes the cursor in the square to move is the number you want to remember. Go back to RetroArch and head to SettingsInputPort 1 Input Binds. Highlight Device Index and press or to choose the correct vJoy Device number.2 You may have to do this every time you restart the driver application.

Your controller should now be working.

HiRes Texture Packs

Keep in mind texture packs are not allowed to be active for races. HiRes Texture Packs

Tips

  • To unbind any button/key hit the Delete key on your keyboard in the input settings.
  • Never close RA via it’s top right X, close it from far left Main Menu Quit RetroArch.
  • If you want RetroArch to keep running in the background, go over to the Settings column in the menu, then down to User Interface, hit Enter and set Don’t run in the background to OFF.
  • To enable the FPS display, go to SettingsOn-Screen DisplayOn-Screen Notifications and switch On-Screen Notifications to ON if it is not already. Then, change Display Framerate to ON.
  • To be able to position the FPS counter, go to SettingsOn-Screen DisplayOn-Screen Notifications and set Graphics Widgets to OFF and then restart RetroArch.


If your controller does not have a default profile or you are using a keyboard, the following information may be helpful.

  • Don't alter the Main Menu bindings for controllers that have default profiles. Open the Quick Menu and change the button mapping there instead.
  • Left side user input binds (the Delete key will delete any binding)
    • B button is equivalent to N64 A Button
    • Y button is equivalent to N64 B Button
    • L2 button (trigger) is equivalent to N64 Z Button
    • L1 is equivalent to N64 L
    • R1 is equivalent to N64 R
    • Movement:
      • Left analog X+ = Right
      • Left analog X- = Left
      • Left analog Y+ = Down
      • Left analog Y- = Up
    • C-Buttons/C-Stick:
      • Right analog X+ = C-Right
      • Right analog X- = C-Left
      • Right analog Y+ = C-Down
      • Right analog Y- = C-Up

Common Issues

There are several issues that crop up often when new users try out RetroArch.

My A and B Buttons Are Swapped On The Menu

Go into SettingsInputMenu Controls and change the Menu Swap OK & Cancel Buttons option.

No Audio

Go into the SettingsDrivers menu and change the Audio Driver from xaudio to dsound. Then quit RetroArch properly via the Main Menu and restart it.

RetroArch crash when loading ROM

If using the Nintendo - Nintendo 64 (Mupen64Plus) core, try the Nintendo - Nintendo 64 (ParaLLEl N64) core instead. If using the Nintendo - Nintendo 64 (ParaLLEl N64) core, try the Nintendo - Nintendo 64 (Mupen64Plus) core instead.

Mupen64Plus Next Freezes

This is an issue with the Mupen64Plus Next core. A workaround has been implemented as an option in the latest version, which at least avoids these crashes, so make sure your core is updated by redownloading it from the Download a Core section in the Load Core menu. After loading a ROM press F1 to open the Quick Menu. Under Options Move down to Ignore emulated TLB Exceptions and press the arrow key once. The selection should change from Don't Ignore to Ignore TLB Exceptions if not using TLB. If it does not, just press the key again.

Once you have changed the option, press F1, go down to Close Content and press Enter. This will either close the ROM and emulator core, or crash the emulator. Both outcomes are fine.

That being said, this is a workaround and not a fix, and whenever the game would've crashed without it, it will display Epona Carrots instead, which will slightly hinder your gameplay because it also overrides some of the A-button functions. What you should do if this happens and how you can mitigate this will be explained in the next section.

Mupen64Plus Next Epona Carrots

This is a side-effect of the quick-fix done to solve the above issue in certain versions of Mupen64Plus Next. When this occurs your ability to play the game as normal is slightly hindered, but still playable. To restore normal functionality you will have to save the game, press F1, go down to Close Content and press Enter. This will either close the ROM and emulator core, or crash the emulator. Both outcomes are fine and relaunching the ROM you were playing will no longer have the Epona carrots displaying.

Note: Selecting Restart will not remove the carrot display. This may be due to the core's reset being hardcoded to be a soft reset. You must choose Close Content.

To help reduce how often this bug happens you can try changing the CPU core. After loading a ROM press F1 to open the Quick Menu. Under Options Move down to CPU Core and press the arrow key once. The selection should change from dynamic_recompiler to cached_interpreter. If it does not, just press the key again.

Once you have changed the option, press F1, go down to Close Content and press Enter. This will either close the ROM and emulator core, or crash the emulator. Both outcomes are fine and relaunching the ROM you were playing will no longer have the Epona carrots displaying. Your Mupen64Plus Next core should be running with the more stable, albeit slightly slower, cached interpreter.

Boots are equipped / Ocarina pulled out randomly while walking

Go to the SettingsInputPort 1 Input Binds menu and set Analog to Digital to None

One of My Buttons Won't Work

If you messed with the Main Menu User Input Binds you likely configured something wrong. It is not recommended to ever modify controller binds this way unless your controller doesn't have a built in profile. To reset your controller bindings to their default you have to load the default RetroArch.cfg again.

If you have a ROM loaded, start by pressing F1 to open the Quick Menu then press Backspace to get back to the Main Menu.

Go to the far left menu item, Main Menu. Move down to 'Configurations and press Enter. Select <Parent directory> and hit Enter. Scroll down to the file RetroArch.default.cfg and press Enter.

ParaLLEl Black Screen or Crashes

If you are able to launch the ParaLLEl core but get a black screen, or frequently crash while pausing, try changing the video plugin it is using. Press F1 to open the Quick Menu and move down to Options and press Enter. Next, move down to GFX Plugin and press the arrow key once. Once you have changed the option, press Backspace twice to return to the Main Menu and select Quit RetroArch to close RetroArch. Simply run RetroArch and open the ROM again and your ParaLLEl core should be running the new plugin you selected. Try each one and see if any of them work for you. If they do not, you may want to try the Mupen64Plus Next core instead.

My Remapping in Quick Menu Controls Won't Save

If your remapping won't save even after using Quit RetroArch in the main menu, you may have to explicitly save the reamppings. Open the Quick Menu with F1, go down to Controls and map your controls how you wish. Once you have done so, go back to the Controls menu. Near the top of the menu is a Save Core Remap File option. Select this to save these controller binds for all randomizer ROMs you open in the future.