Setup & Configuration β
If you haven't already hacked your Nitendo Switch you can do so right here
This guide illustrates how to use an untrimmed game cartridge dump (XCI file) to install firmware directly to Ryujinx. If you would prefer to dump the firmware standlone, you may follow this firmware dumping guide
If you haven't already downloaded Ryujinx, get the latest version from: https://github.com/GreemDev/Ryujinx/releases/latest
Ryujinx checks for updates automatically at startup. You can disable this feature if you wish in Options > Settings . You may also check for updates manually by navigating to Help > Check for Updates
Thanks to Gab for providing the guide images
Preface β
Ryujinx comes pre-optimized by default. If a particular menu option is not mentioned in this guide, it should be ignored and should not be changed unless directly instructed by Ryujinx staff.
When requesting support on the Discord Server, you will usually be asked for your log file. With this in mind, Logging should be left at default settings (enabled) for everything except debug logs. Do not enable debug logs unless specifically instructed by Ryujinx staff.
System Requirements β
In order to use Ryujinx your computer will need:
At least 8GB RAM
A video card/GPU that supports OpenGL 4.5/Vulkan 1.2 or higher
Your prod.keys and either your dumped firmware or game cartridge untrimmed XCI
Your dumped Nintendo Switch games or homebrew
Windows 10.0.17134 or higher / macOS 12 / Any modern linux distribution see dependencies
A recommended baseline system (native resolution and framerate) would look something like:
- CPU: Ryzen 5 3600
- RAM: 16GB DDR4
- GPU: NVIDIA GTX 1060 6GB
Dependencies β
Windows
- Windows 10 RS4 (Redstone 4, version 1803) or newer is required.
- Graphics drivers must be up to date. On laptops with 2 different graphics cards, both iGPU and dGPU drivers must be updated.
Linux
copy the command into your terminal emulator of choice and execute it
- Archlinux based distros:
sudo pacman -S sdl2 openal
- Ubuntu based distros:
sudo apt-get install libsdl2-2.0 libsdl2-dev libalut-dev
- Fedora:
sudo dnf install SDL2-devel openal-soft
MacOS
- macOS 12 Monterey or latest (recommended) installed.
Placement of Prod.keys β
By default Ryujinx will use %appdata%/Ryujinx
(or the equivalent application data folder on Linux/macOS) to store all of it's permanent files. This includes firmware, save files, shader caches and other configuration. If you wish Ryujinx to be fully self-contained you may use portable mode!
Now that you've downloaded the Ryujinx archive, open it and extract the contents of the publish folder onto your drive in the location of your choice. We recommend against using your desktop or the root of any drive as these can sometimes be protected.
Navigate to where you extracted the Ryujinx files, and double-click on Ryujinx.exe. This will launch the emulator and you may be met with a Windows Protected your PC window (don't worry, this is normal!)
Click Run anyway on the warning box. Now that Ryujinx has been launched, the proper folders have been created for you in your
%appdata% folder
Click File at the top left of the Ryujinx window, and then click Open Ryujinx Folder.
- Navigate down into the system subfolder and paste your prod.keys file here. The file/folder structure should look like this:
- Close and reopen Ryujinx so that the prod.keys file is validated.
You're done installing keys!
Installation of Firmware β
Now that your keys are installed, it's time to install a firmware. Make sure you have an untrimmed XCI file of a recent game cartridge you dumped, or have compiled your dumped firmware into a ZIP file.
Open Ryujinx. There should be no warning about KEYS anymore; if you still get the warning, go back through the prod.keys steps and ensure you have placed the file correctly.
Now that Ryujinx is open, click Tools > Install Firmware > Install from XCI/ZIP
- This will bring up your OS's File Explorer, navigate to the location of your dumped XCI file and click Open. You will be asked to confirm whether you want to install the firmware. Make sure your prod.keys are at least as new as the firmware you are installing! (Your firmware version number may vary)
- Click Yes. You will see a message that the firmware is installing and was successfully installed:
- Click OK. If all went well, you will now see your firmware version listed as the "System Version" in the bottom right hand corner of the main Ryujinx window.
Adding Games β
You have keys and firmware ready to go. Time to add your games!
With Ryujinx open, click on Options > Settings. This takes you straight to the User Interface tab.
There are two different methods in which you can add a Game Directory in this window.
1st Method: Type the absolute path of the folder containing your games into the path field and click Add.
2nd Method: Without typing anything into the path field, click Add.
This brings up your OS's navigation window. Navigate to the folder containing your games (e.g. D:\Switch Games) and click Add.
Whichever method you chose, click Save to save the game directory setting.
Your games will now show up in the main Ryujinx window.
Managing Game Updates β
Manage game update versions from within Ryujinx
Now that your games are added, you may wish to update your game for various reasons e.g. bugfixes, new content, etc. Ryujinx has built-in functionality to manage which version of the game you want to play.
Autoadd Game Updates β
Since version 1.2.0, Ryujinx supports automatically adding and assigning game updates.
- Go to Options > Settings
- Scroll down until you see "Autoadd DLC/Game Updates".
From there, simply add the directories where your Game Updates are located by following Method 1 or Method 2 from Adding Games.
If you add multiple updates in one go with this method, Ryujinx will automatically choose the highest version.
Managing Game Updates β
- In the main Ryujinx game list, right-click the game you want to manage Game Updates for. Then click Manage Title Updates.
After clicking Manage Title Updates, you will see the Ryujinx - Title Update Manager menu.
If you want to add a game update file, go to step 2.
If you do not want to add a game update file, go to step 4.
- Click Add
- This will bring up your OS's File Explorer. From there, navigate to the location of your game's update files, select which one you want to Add and click on Open.
You may repeat this for any other game update files you want to add.
- Select the version of the update you want to be applied by clicking on it and click Save.
Your game update should now be applied, you may repeat the process for any other games you wish to apply updates to.
Managing DLC β
Manage Downloadable Content for your games
Now that your games and game updates are added, you may wish to add DLC to your game. Ryujinx has built-in functionality to manage your DLC.
Autoadd DLC β
Since 1.2.0, Ryujinx supports automatically adding and assigning DLC.
- Go to Options > Settings
- Scroll down until you see "Autoadd DLC/Game Updates".
From there, simply add the directories where your Game Updates are located by following Method 1 or Method 2 from Adding Games.
If you add multiple DLCs in one go with this method, Ryujinx will automatically enable every DLC for each game.
Managing DLC β
Managing Downloadable Content includes, removing, adding and selecting which DLC you want.
- In the main Ryujinx game list, right-click the game you want to manage Game Updates for. Then click Manage DLC.
If you want to add a game update file, go to step 2.
If you do not want to add a game update file, go to step 4.
- Click Add
- This will bring up your OS's File Explorer. From there, navigate to the location of your DLC files, select which ones you want to Add and click on Open.
You may repeat this for any other DLC files you want to add.
- Select which DLC you want to be applied by clicking on it and click Save.
Repeat this process, if you wish, for any other games you would like to manage DLC for.
Your DLC should now be applied and enabled automatically.
Managing Mods β
Quick Start Guide for managing mods
Various game mods are available from enthusiasts & content creators online. Ryujinx supports the following types of mods:
- ExeFS Partition Replacement
- ExeFS File Replacement
- ExeFS Patching
- RomFS Partition Replacement
- RomFS File Replacement
Using the Mod Manager β
Ryujinx has a built-in Mod Manager that can very easily be used to enable, disable, add and remove mods.
- Right-click on the game you want to add a mod for, from there click on Manage Mods.
- The Mod Manager window will pop-up, this is where you can add, remove, enable and disable your mods for the game of your choice.
- To add Mods, simply click the Add button.
- This will bring up your OS's File explorer. From there select the unzipped folder containing all the files for the mod you want to add.
Your mods should now be installed and already enabled by default.
- Click Save to exit and save your mods.
Manually Adding Mods β
(NOT RECOMMENDED)
This is only recommended for experienced users who know what they are doing.
- Right-click on the game you wish to add mods for and click Open Mods Directory.
This will open the AppData\Roaming\Ryujinx\mods\contents\<game ID>\
folder.
- Create a subfolder with a name that fits the mod you'll be using. Then, place the ExeFS and RomFS of the mod inside that folder.
You can also place mods in C:\Users\[redacted]\AppData\Roaming\Ryujinx\sdcard\atmosphere
if the mod was packaged for real hardware (usually indicated with an "atmosphere" folder as the top directory).
Right-click the game you wish to add an atmosphere mod to and click on Open Atmosphere Mods Directory. This will open AppData\Roaming\Ryujinx\sdcard\atmosphere\contents\<game ID>
where you can then place the RomFS and ExeFS of the mod you wish to add.
Managing Cheats β
Ryujinx fully supports Atmosphere style cheats (except game pausing/resume): Atmosphere's cheats doc
Installation of Atmosphere Cheats β
A good place to acquire Atmosphere cheats is:
- EdiZon (general switch cheats)
Inside the cheat zip
, rar
, or other archive format, there is usually a file structure like this:
Cheat_Name\cheats\0123456789ABCDEF.txt
Where 0123456789ABCDEF
will vary according to the game and the cheat (this is the build id of the executable the cheat attaches itself to). A cheat can also contain several txt
files. Cheats are game-specific and version-specific, they will not work if transferred from one game to another or to an incompatible update of the game.
To install the cheat:
- Open Ryujinx, right-click the game you wish to install the cheat and select to open its
Mod directory
.
- A directory like this will open:
Ryujinx\mods\contents\XXXXXXXXXXXXXXXX\
,XXXXXXXXXXXXXXXX
will be the id of the chosen game.
- Extract the cheat archive to the mod directory, keeping the cheat name:
Ryujinx\mods\contents\XXXXXXXXXXXXXXXX\Cheat_Name\cheats\<all the txt files>
. The following image may be a bit confusing to look at, but take your time it's actually quite easy to understand.
Activating/Deactivating cheats β
In Ryujinx, cheats are all automatically disabled, so you need to enable them in the Ryujinx UI to be able to use them.
To do so, start by right-clicking a game and clicking on "Manage Cheats"
This will bring up Ryujinx's Cheat Manager, from where you can enable/disable cheats by checking the box next to their name.
Next, click Save to save which cheats you enabled/disabled.
Managing User Profiles β
Ryujinx offers the ability to use multiple, customizable user profiles. WARNING: Save data is specific to each user profile so if you delete a profile, the save data under that profile is also deleted.
To edit a user profile: β
- With Ryujinx open, but no game running, click on Options > Manage User Profiles
Now in the Manage User Profiles window, you will see the default RyuPlayer profile. This is the default profile that comes with Ryujinx and cannot be deleted as it contains all of the original save data for your games. You may, however, rename it and change the picture to something else, if you like.
- To rename a profile, hover over the profile and click the editing icon.
You can then edit the name of the profile.
- To change the profile image, hover over the profile and click the editing icon again.
Then, click on "Change Profile Image".
You will then be prompted to select from either a custom image, or from one of the many avatars provided in the firmware.
If you choose to import an image: supported formats are png
, bmp
, and jpg
. You can use the image you want, but it will be resized to 256x256 pixels, so using a square image is recommended.
If you choose to use a built-in firmware avatar, click on Select Firmware Avatar
In the Manage Accounts - Avatar window, select the avatar you want, and choose a background color. When finished, click Choose to make it the profile's image.
Add a new profile: β
With Ryujinx open, but no game running, click on Options > Manage User Profiles
Click on the Plus sign next to the already existing Profile.
- A window will pop up asking you to name the new Profile. Enter the desired name of the new profile, and click OK.
To set a profile picture, just click on Set Profile Image and follow Step 3 from the user profile editing instructions above.
Input Configuration β
Setting up your controls: this part requires close attention, so read carefully!
Plug in the controller(s) that you will be using.
Open Ryujinx and navigate to Options > Settings
You will now see the Ryujinx - Settings window. Click on the Input tab.
Enable Docked Mode: checking this box emulates the Nintendo Switch being docked. Docked Mode enables higher resolution, higher FPS, and better graphical fidelity on games that support these features. If you check this box, you will need to click configure under Player 1.If you leave this box unchecked, you will need to click configure under Handheld.
Direct Keyboard Access: checking this box emulates a real, physical keyboard being directly connected to a Nintendo Switch via USB. Do not check this box unless you have a specific reason.
Direct Mouse Access: checking this box emulates a real, physical mouse being directly connected to a Nintendo Switch via USB. Do not check this box unless you have a specific reason.
- If you have checked Docked Mode, select Player 1 under the "Player" Dropdown. If you have unchecked Docked Mode, select Handheld under the "Player" Dropdown.
- Click on the Input Device dropdown and choose the controller you want. If you have connected multiple controllers, choose the one you want to be configured to be P1 in game. If you do not see any Xinput controllers in the list, you will need to use an Xinput wrapper/translator such as x360ce.
- After selecting your controller you should now see a full mapping UI.
You may continue tweaking the settings to your liking, or binding each button from scratch if you want a fully custom button layout.
NOTE: while the default Deadzones are 0.10, we recommend increasing your Deadzones to at least 0.20 in order to avoid unwanted joystick drift.
If you are in Docked Mode and have additional controllers to configure, configure them now under Player 2, Player 3, and so on.
- Click Apply and then OK to save your configuration.
Motion Controls β
Ryujinx offers the ability to natively use motion controls with motion-enabled controllers such as a Switch Pro Controller, DS4, DS5, DSE and others.
Native motion controls β
Native motion controls should already be enabled and working by default. If you want to change the sensitivity and deadzone, you can do so in the Settings.
Then, go to the Input tab, make sure the box next to "Motion" is checked and click Configure.
You will now see the Motion Controls Settings. From here, feel free to modify the sensitivity and deadzone. Since you are natively using motion, you do not need to touch any cemuhook related settings.
Make sure to click on Save to save your configuration.
Cemuhook motion controls β
Since Ryujinx uses SDL2 as it's input wrapper, it means that not all controllers are supported, and that not all the features of a controller are supported. Meaning that sometimes, a controller that has motion controls may not be natively supported by Ryujinx.
Cemuhook is also needed to use a joycon pair, since it can group 2 controllers under 1.
To fix this, we can use cemuhook:
Launch & configure your favorite cemuhook server application (Betterjoy, DS4Windows,etc.) with your Bluetooth or wired motion-capable controller. Leave the application running.
In Ryujinx, navigate to Options > Settings > Input tab and select which controller you are configuring. Remember: if you are in docked mode, configure Player 1. If you are in Handheld mode, configure the Handheld controller.
- Select your motion controller from the dropdown. It will be listed as "Xinput controller", "Xbox 360 Controller" or "Xbox One Controller".
- Next up, make sure Motion is activated, and click Configure to bring up the Motion Controls Settings.
- Once here, check the box named Use CemuHook compatible motion, then enter the IP and Port that your cemuhook application uses (usually 127.0.0.1 and 26760).
If you set your controller type to Joycon Pair, an option called "Mirror Input" becomes available. This is useful for games in which both Joycons are connected to a Joycon grip and are moving together. If you enable this checkbox, the first Joycon's motion will be used for both Joycons.
- Click Save to save your configurations.
Repeat steps 2 through 5 for any other motion controllers you wish to configure. If you have more than one, make sure to choose the respective slot # for each controller
Amiibo Emulation β
All Amiibo are able to be virtually scanned within the emulator, as long as you are actively connected to the internet. No files or dumps are required!
To scan an Amiibo:
While playing a game that supports Amiibo, either navigate to the area where Amiibo scanning is expected, or press/hold the correct button to enable the Amiibo scan prompt (this site has a basic list of supported games and what benefits are provided by each: https://amiibo.life/games
Click the "Actions" menu header, then click "Scan an Amiibo"
- Choose the Amiibo you want from the Amiibo Series and Character dropdowns. Note: only the Amiibo that have content for the game you are currently playing are shown in this window. All the same, if you'd like to see all Amiibo you may check the box that says "Show All Amiibo".
Addendum: In The Legend of Zelda: Breath of the Wild, you may continually scan Amiibo as many times as you wish by checking the box labeled "Hack: Use Random Tag Uuid" box.
Profiled Persistent Translation Cache β
Speed up game loading times with PPTC
In a nutshell, this feature caches translated functions so that they do not need to be translated every time the game loads. This results in a significant reduction of load times (the amount of time between launching a game and arriving at the title screen) for nearly every game.
NOTE: You must launch the game at least twice and let it load to the title screen or beyond before performance improvements areunlocked on the third launch! These improvements are permanent and do not require any extra launches going forward.
PPTC (Profiled Persistent Translation Cache) is now enabled by default. To disable it:
- With Ryujinx open, click on Options > Settings
- Then navigate to the CPU tab and uncheck the box marked "PPTC (Profiled Persistent Translation Cache)"
From time to time you may wish to examine or purge your PPTC cache files if you are experiencing PPTC-related issues.
To open the PPTC cache file location:
With Ryujinx open, right-click the game in the game list whose PPTC cache files you wish to view. This will bring up a pop-up menu.
Navigate to Cache Management > Open the PPTC directory
To purge the PPTC cache files:
With Ryujinx open, right-click the game in the game list whose PPTC cache files you wish to purge. This will bring up a pop-up menu.
Navigate to Cache Management > Open PPTC Directory
- You can then select the folders and delete them.
Graphics Enhancements β
Ryujinx offers a few graphics enhancement options.
Resolution Scaling, which offers a much sharper image with little to no impact to performance. Resolution scaling can increase image quality much more noticeably than Anisotropic Filtering. Ryujinx's resolution scaling implementation allows native, 2x, 3x, 4x, or even custom ratios for upscaling.
Anisotropic Filtering, which can visibly improve graphic quality. Wikipedia says: In layman's terms, anisotropic filtering retains the "sharpness" of a texture normally lost by MIP map texture's attempts to avoid aliasing. Anisotropic filtering can therefore be said to maintain crisp texture detail at all viewing orientations while providing fast anti-aliased texture filtering.
Shader Cache, which stores onto disk the shaders that have already been compiled, negating the need to compile them again. This feature is highly sought after as it significantly reduces stuttering and FPS drops on subsequent plays of a particular game making for a smoother, more enjoyable gameplay experience. Note: Shader Cache is enabled by default.
Aspect Ratio Options, which allow you to adjust the width-to-height ratio to your liking. Note: these options may give your game a stretched or squeezed appearance unless you are using mods that change the expected aspect ratio of the game.
To enable Resolution Scaling:
Note: Enabling this feature may cause graphical glitches on some games.
These settings may be changed in-game on the fly! On a standard 1080p display, 2x resolution scaling is recommended.
- With Ryujinx open, click Options > Settings
- Navigate to the Graphics tab and click the dropdown next to Resolution Scale. Select your desired level of resolution scaling.
Click Apply and then OK to save the enhancement setting.
To enable Anisotropic Filtering:
Note: enabling this feature may cause graphical glitches on somegames.
- With Ryujinx open, click on Options > Settings
- Navigate to the Graphics tab and click the dropdown next to Anisotropic Filtering. Set it to your desired level.
Click Apply and then OK to save the settings.
To Manage Shader Cache:
Shader Cache is enabled by default. There are no good reasons to disable it other than for testing purposes.
Disabling this setting is strongly discouraged. However, if you absolutely must disable it:
With Ryujinx open, navigate to Options > Settings.
Navigate to the Graphics tab and disable shader cache by unchecking the box marked "Enable Shader Cache"
In some rare cases, a shader cache might become corrupted and crash when compiling shaders on boot. To solve this you'll have to purge the shader cache for that particular game:
Right click on a game in the game list and navigate to Cache Management > Purge Shader Cache.
To view the shader cache directory for a particular game:
Right click on a game in the game list and navigate to Cache Management > Open Shader Cache Directory.
To adjust your aspect ratio:
Option 1:
- With Ryujinx open, navigate to Options > Settings and click on the Graphics tab. Click on the Aspect Ratio dropdown and adjust the ratio to your liking.
Option 2:
- With your game running, click on the aspect ratio button in the status toolbar at the bottom of the Ryujinx window.
Option 3 (NOT RECOMMENDED):
Use Option 1 and select "Stretch to Fit Window" or Option 2 and select "Stretched".
Simply click and drag your window borders to the size you want!
Portable Mode β
If you wish, you may use a custom folder location for all Ryujinx data (as opposed to keeping it in its default location: %appdata%). This is done via the command-line or, more conveniently, a custom shortcut. In the future, the ability to configure custom data folders may be added to the GUI.
NOTE: You must manually create the custom folder first before using portable mode! After enabling portable mode, you will need to copy your prod.keys file and any desired game data/save data from its original location to the new data folder.
To enable Portable Mode
Option 1: (Recommended) Create a "portable" subfolder
- Create a subfolder in the Ryujinx program base directory called "portable". This automatically enables portable mode and utilizes this "portable" folder for system folder contents (keys, firmware, PPTC/shader caches, etc.).
Option 2: Command-line
- Open a command prompt, navigate to the location of the Ryujinx executable and type the following command: ryujinx.exe -r d:[folderpath]. For example, if your custom folder was d:\ryujinxdata, your command would be the following, without quotes (THIS IS ONLY AN EXAMPLE. USE WHATEVER CUSTOM FOLDER NAME YOU PREFER): "ryujinx.exe -r d:\ryujinxdata"
The command prompt window will become the console window when Ryujinx launches.
Option 3: Custom Shortcut
- Right-click on your Ryujinx executable and click Send To -> Desktop Shortcut
- Locate the new shortcut on your desktop and right-click on it, then click Properties
- In the Properties window, click into the Target field and add a space onto the end of the existing command. Then add "-r [folderpath]" without quotes where [folderpath] is your own custom data folder full path, and click OK. For example, if your custom data folder was d:\ryujinxdata, the addition you would paste into the target field would be "-r d:\ryujinxdata" without the quotes.
Note: On MacOS, the command would be as follows, without the quotes: "/Applications/Ryujinx.app/Contents/MacOS/Ryujinx -r /path/to/custom/ryujinx/folder"
You can now use this shortcut any time you want to launch Ryujinx in portable mode!
Launch in Fullscreen β
Ryujinx can automatically launch games in fullscreen mode. You can enable this functionality in one of two ways:
Method One: In Ryujinx, click on Options, then check the box marked "Start Games in Fullscreen Mode".
Method Two: If you launch Ryujinx from the commandline, add a --fullscreen option. Like so: