Nitrogen is a port of the multi-platform Nintendo DS emulator to iOS and Android (soon).
Currently, emulation is powered by a threaded ARM interpreter. As a result, emulation is rather slow on older devices, like the iPhone 4s and below.
Nitrogen runs at nearly full speed on the iPhone 5 and above, and achieves full speed on devices using the A7-S5L8960X SoC (iPhone 5s, iPad Air, iPad mini Retina, and anything newer than these devices).
Due to the need to mmap the entire ROM into memory, older devices with only 256MB of RAM are not supported by Nitrogen. These devices include the iPod touch 4, iPad 1, iPhone 3GS, and anything below those devices.
Do not redistribute self-compiled versions of Nitrogen on other sites. We will be adding an official method to download Nitrogen very soon. Any unofficial copies of Nitrogen must change the name and icon. THIS IS A FAIR WARNING.
-
Clone the Nitrogen Git repository. You may do this from a Terminal instance with the command
git clone https://github.com/NitrogenEmulator/Nitrogen.git
, or from a Git frontend like SourceTree. -
Open "Nitrogen.xcodeproj" located within the cloned "Nitrogen" folder.
-
Connect your iOS device and let Xcode Organizer associate itself with your device.
-
In the Xcode IDE, select "iOS Device" (or "$YOUR_NAME's iPhone") and make sure you are using the Release configuration.
-
Click the "Run" button or press Command + R.
-
Please note that if you are using a jailbroken device, this installation of Nitrogen will be treated as a non-jailbroken installation. If you want to compile a jailbroken version of Nitrogen yourself, please see Option 2a below.
-
Clone the Nitrogen Git repository. You may do this from a Terminal instance with the command
git clone https://github.com/NitrogenEmulator/Nitrogen.git
, or from a Git frontend like SourceTree. -
If you have not yet opened a Terminal instance, do so now.
-
Make sure
THEOS_DEVICE_IP
is defined. You can do so by runningexport THEOS_DEVICE_IP=<your iOS device's IP address>
. -
cd
to the cloned "Nitrogen" folder, and runmake install
. -
Nitrogen will compile and
scp
itself to your iOS device.
- Open Safari.
- Download a ROM image of a Nintendo DS game that you legally own the actual game cartridge for.
- Tap the "Open in..." button in the top left hand corner, and select Nitrogen.
- Nitrogen will automatically unzip the file, delete the readme, find the *.nds file, and refresh itself. Your ROM should show up in the list.
- Download one of the many web browsers available on the App Store with download managers built in, such as Dolphin Browser.
- Download a ROM image of a Nintendo DS game that you legally own the actual game cartridge for.
- From the app's list of downloaded files, tap on the downloaded file, and select Nitrogen in the "Open in..." menu.
- Nitrogen will automatically unzip the file, delete the readme, find the *.nds file, and refresh itself. Your ROM should show up in the list.
- Plug your device into your computer and launch iFunBox Classic.
- Go to [device name] -> iTunes File Sharing -> Nitrogen
- Drag and drop *.nds ROM images of Nintendo DS games that you legally own the actual game cartridge for into iFunBox.
- Restart Nitrogen to see the changes.
- Download a download manager tweak from Cydia like Safari Downloader+ or Chrome Downloader+.
- Download a ROM image of a Nintendo DS game that you legally own the actual game cartridge for.
- Using iFile or another filesystem explorer, move the downloaded .nds file to /User/Documents/. Alternatively, you can also tap on the downloaded file in the download manager's list of files, and select Nitrogen in the "Open in..." menu.
- Nitrogen will automatically unzip the file, delete the readme, find the *.nds file, and refresh itself. Your ROM should show up in the list.
- Install OpenSSH from Cydia if you plan to utilise SCP (SSH) to transfer ROMs.
- If you do not wish to utilise SCP, then download iFunBox Classic and install it on your computer.
- ROMs (*.nds) go in the directory: /User/Documents/
- Saves (in DeSmuME's *.dsv format) go in: /User/Documents/Battery/
When something in Nitrogen isn't working correctly for you, please open a GitHub issue ticket here.
- iOS device
- iOS version
- Jailbreak status
- Download location
- Slow performance
- Crashing on older devices with 256MB of RAM (iPod touch 4, iPhone 3GS, iPad 1, and anything released prior to those devices.)
- GNU Lightning JIT
- OpenGL ES rendering
- Automatically fix permissions of crucial folders on the jailbroken distribution
- Ability to change the folder the ROM chooser reads from
- ROM streaming
- ROM auto-trimming
- Add more localizations
- Much more