2018-11-01 00:11:11 -06:00
< p align = "center" > < img src = "https://raw.githubusercontent.com/StapleButter/melonDS/master/icon/melon_128x128.png" > < / p >
< h2 align = "center" > < b > melonDS< / b > < / h2 >
< p align = "center" >
< a href = "http://melonds.kuribo64.net/" alt = "melonDS website" > < img src = "https://img.shields.io/badge/website-melonds.kuribo64.net-%2331352e.svg" > < / a >
2021-04-26 15:24:41 -06:00
< a href = "http://melonds.kuribo64.net/downloads.php" alt = "Release: 0.9.2" > < img src = "https://img.shields.io/badge/release-0.9.2-%235c913b.svg" > < / a >
2018-11-01 00:11:11 -06:00
< a href = "https://www.gnu.org/licenses/gpl-3.0" alt = "License: GPLv3" > < img src = "https://img.shields.io/badge/License-GPL%20v3-%23ff554d.svg" > < / a >
< a href = "https://kiwiirc.com/client/irc.badnik.net/?nick=IRC-Source_?#melonds" alt = "IRC channel: #melonds " >< img src = "https://img.shields.io/badge/IRC%20chat-%23melonds-%23dd2e44.svg" ></ a >
2021-02-04 03:10:49 -07:00
< br >
< a href = "https://github.com/Arisotura/melonDS/actions?query=workflow%3A%22CMake+Build+%28Windows+x86-64%29%22+event%3Apush" > < img src = "https://img.shields.io/github/workflow/status/Arisotura/melonDS/CMake%20Build%20(Windows%20x86-64)?label=Windows%20x86-64&logo=GitHub" > < / img > < / a >
< a href = "https://github.com/Arisotura/melonDS/actions?query=workflow%3A%22CMake+Build+%28Ubuntu+x86-64%29%22+event%3Apush" > < img src = "https://img.shields.io/github/workflow/status/Arisotura/melonDS/CMake%20Build%20(Ubuntu%20x86-64)?label=Linux%20x86-64&logo=GitHub" > < / img > < / a >
< a href = "https://github.com/Arisotura/melonDS/actions?query=workflow%3A%22CMake+Build+%28Ubuntu+aarch64%29%22+event%3Apush" > < img src = "https://img.shields.io/github/workflow/status/Arisotura/melonDS/CMake%20Build%20(Ubuntu%20aarch64)?label=Linux%20ARM64&logo=GitHub" > < / img > < / a >
2021-07-22 09:13:33 -06:00
< a href = "https://dev.azure.com/melonDS/melonDS/_build?definitionId=1&repositoryFilter=1&branchFilter=2%2C2%2C2%2C2%2C2%2C2%2C2%2C2%2C2%2C2%2C2%2C2%2C2" > < img src = "https://img.shields.io/azure-devops/build/melonDS/7c9c08a1-669f-42a4-bef4-a6c74eadf723/1/master?label=macOS%20x86-64&logo=Azure%20Pipelines" > < / img > < / a >
< a href = "https://dev.azure.com/melonDS/melonDS/_build?definitionId=2&_a=summary&repositoryFilter=1&branchFilter=2%2C2%2C2%2C2%2C2" > < img src = "https://img.shields.io/azure-devops/build/melonDS/7c9c08a1-669f-42a4-bef4-a6c74eadf723/2/master?label=macOS%20ARM64&logo=Azure%20Pipelines" > < / img > < / a >
2018-11-01 00:11:11 -06:00
< / p >
2017-10-21 21:58:02 -06:00
DS emulator, sorta
2016-05-15 19:40:11 -06:00
2017-03-29 14:56:30 -06:00
The goal is to do things right and fast, akin to blargSNES (but hopefully better). But also to, you know, have a fun challenge :)
2018-11-01 00:11:11 -06:00
< hr >
2018-11-01 14:10:34 -06:00
2017-10-21 21:58:02 -06:00
## How to use
2017-02-07 14:23:46 -07:00
melonDS requires BIOS/firmware copies from a DS. Files required:
* bios7.bin, 16KB: ARM7 BIOS
* bios9.bin, 4KB: ARM9 BIOS
2017-08-05 11:13:55 -06:00
* firmware.bin, 128/256/512KB: firmware
2018-11-01 00:11:11 -06:00
2017-06-15 13:41:18 -06:00
Firmware boot requires a firmware dump from an original DS or DS Lite.
DS firmwares dumped from a DSi or 3DS aren't bootable and only contain configuration data, thus they are only suitable when booting games directly.
2017-10-21 21:58:02 -06:00
### Possible firmware sizes
2017-08-05 11:13:55 -06:00
* 128KB: DSi/3DS DS-mode firmware (reduced size due to lacking bootcode)
* 256KB: regular DS firmware
* 512KB: iQue DS firmware
2018-10-26 13:06:46 -06:00
DS BIOS dumps from a DSi or 3DS can be used with no compatibility issues. DSi BIOS dumps (in DSi mode) are not compatible. Or maybe they are. I don't know.
2017-02-07 14:23:46 -07:00
2017-03-29 14:56:30 -06:00
As for the rest, the interface should be pretty straightforward. If you have a question, don't hesitate to ask, though!
2016-12-05 09:08:24 -07:00
2017-10-21 21:58:02 -06:00
## How to build
2017-04-29 19:46:27 -06:00
2017-10-21 21:58:02 -06:00
### Linux:
2016-12-05 09:08:24 -07:00
2021-02-17 14:45:17 -07:00
1. Install dependencies: `sudo apt install cmake libcurl4-gnutls-dev libpcap0.8-dev libsdl2-dev qt5-default libslirp-dev libarchive-dev libepoxy-dev`
2. Download the melonDS repository and prepare:
```bash
git clone https://github.com/Arisotura/melonDS
cd melonDS
mkdir build & & cd build
```
3. Compile:
```bash
cmake ..
make -j$(nproc --all)
```
2017-10-21 21:58:02 -06:00
### Windows:
2017-04-02 01:33:01 -06:00
2019-04-30 22:08:00 -06:00
1. Install [MSYS2 ](https://www.msys2.org/ )
2019-05-04 07:28:58 -06:00
2. Open the **MSYS2 MinGW 64-bit** terminal
2019-04-30 22:08:00 -06:00
3. Update the packages using `pacman -Syu` and reopen the terminal if it asks you to
2021-02-17 14:45:17 -07:00
4. Download the melonDS repository and prepare:
```bash
git clone https://github.com/Arisotura/melonDS
cd melonDS
mkdir build & & cd build
```
2020-08-16 08:11:28 -06:00
#### Dynamic builds (with DLLs)
2021-02-17 14:45:17 -07:00
5. Install dependencies: `pacman -S git make mingw-w64-x86_64-{cmake,mesa,SDL2,toolchain,qt5,libslirp,libarchive,libepoxy}`
6. Compile:
2019-04-30 22:08:00 -06:00
```bash
cmake .. -G "MSYS Makefiles"
2019-06-04 09:22:25 -06:00
make -j$(nproc --all)
2021-04-21 15:50:32 -06:00
../tools/msys-dist.sh
2019-04-30 22:08:00 -06:00
```
If everything went well, melonDS and the libraries it needs should now be in the `dist` folder.
2017-04-29 19:46:27 -06:00
2020-08-16 08:11:28 -06:00
#### Static builds (without DLLs, standalone executable)
2021-02-17 14:45:17 -07:00
5. Install dependencies: `pacman -S git make mingw-w64-x86_64-{cmake,mesa,SDL2,toolchain,qt5-static,libslirp,libarchive,libepoxy}`
6. Compile:
2020-08-16 08:11:28 -06:00
```bash
cmake .. -G 'MSYS Makefiles' -DBUILD_STATIC=ON -DQT5_STATIC_DIR=/mingw64/qt5-static
make -j$(nproc --all)
mkdir dist & & cp melonDS.exe dist
```
If everything went well, melonDS should now be in the `dist` folder.
2020-11-29 09:11:33 -07:00
### macOS:
1. Install the [Homebrew Package Manager ](https://brew.sh )
2021-05-02 06:53:34 -06:00
2. Install dependencies: `brew install git pkg-config cmake sdl2 qt@6 libslirp libarchive libepoxy`
2021-02-17 14:45:17 -07:00
3. Download the melonDS repository and prepare:
```zsh
git clone https://github.com/Arisotura/melonDS
cd melonDS
mkdir build & & cd build
```
4. Compile:
2020-11-29 09:11:33 -07:00
```zsh
2021-05-02 07:13:43 -06:00
cmake .. -DCMAKE_PREFIX_PATH="$(brew --prefix qt@6);$(brew --prefix libarchive)" -DUSE_QT6=ON -DMACOS_BUNDLE_LIBS=ON
2021-04-24 07:27:11 -06:00
make -j$(sysctl -n hw.logicalcpu)
2020-11-29 09:11:33 -07:00
```
2021-05-02 06:51:11 -06:00
If everything went well, melonDS.app should now be in the curent directory.
2020-11-29 09:11:33 -07:00
2017-10-21 21:58:02 -06:00
## TODO LIST
2016-12-05 09:08:24 -07:00
2019-06-12 06:03:06 -06:00
* DSi emulation
* the impossible quest of pixel-perfect 3D graphics
2018-10-26 13:06:46 -06:00
* improve libui and the emulator UI
* support for rendering screens to separate windows
2017-08-29 10:17:44 -06:00
* emulating some fancy addons
2017-02-12 18:07:54 -07:00
* other non-core shit (debugger, graphics viewers, cheat crapo, etc)
2018-11-01 00:11:11 -06:00
2017-10-21 21:58:02 -06:00
### TODO LIST FOR LATER
2017-02-12 18:07:54 -07:00
2017-08-29 10:17:44 -06:00
* better wifi
2017-02-12 18:07:54 -07:00
* maybe emulate flashcarts or other fancy hardware
2017-03-12 17:45:26 -06:00
* big-endian compatibility (Wii, etc)
* LCD refresh time (used by some games for blending effects)
2017-03-29 14:56:30 -06:00
* any feature you can eventually ask for that isn't outright stupid
2018-11-01 00:11:11 -06:00
2017-10-21 21:58:02 -06:00
## Credits
2017-08-29 10:17:44 -06:00
* Martin for GBAtek, a good piece of documentation
* Cydrak for the extra 3D GPU research
2020-04-14 15:32:47 -06:00
* limittox for the icon
2017-08-29 10:17:44 -06:00
* All of you comrades who have been testing melonDS, reporting issues, suggesting shit, etc
2018-11-01 00:11:11 -06:00
## License
[![GNU GPLv3 Image ](https://www.gnu.org/graphics/gplv3-127x51.png )](http://www.gnu.org/licenses/gpl-3.0.en.html)
melonDS is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
2021-01-26 06:19:32 -07:00
(at your option) any later version.