melonDS/README.md

118 lines
4.3 KiB
Markdown
Raw Normal View History

<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>
2020-09-04 11:41:51 +00:00
<a href="http://melonds.kuribo64.net/downloads.php" alt="Release: 0.9"><img src="https://img.shields.io/badge/release-0.9-%235c913b.svg"></a>
<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>
</p>
2017-10-22 03:58:02 +00:00
DS emulator, sorta
2016-05-16 01:40:11 +00: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 :)
<hr>
2017-10-22 03:58:02 +00:00
## How to use
melonDS requires BIOS/firmware copies from a DS. Files required:
* bios7.bin, 16KB: ARM7 BIOS
* bios9.bin, 4KB: ARM9 BIOS
* firmware.bin, 128/256/512KB: firmware
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-22 03:58:02 +00:00
### Possible firmware sizes
* 128KB: DSi/3DS DS-mode firmware (reduced size due to lacking bootcode)
* 256KB: regular DS firmware
* 512KB: iQue DS firmware
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.
As for the rest, the interface should be pretty straightforward. If you have a question, don't hesitate to ask, though!
2017-10-22 03:58:02 +00:00
## How to build
2017-10-22 03:58:02 +00:00
### Linux:
* Install dependencies:
```sh
sudo apt-get install cmake libcurl4-gnutls-dev libpcap0.8-dev libsdl2-dev qtbase5-dev qtdeclarative5-dev libslirp-dev
```
* Compile:
2017-10-22 03:58:02 +00:00
```sh
mkdir -p build
cd build
cmake ..
make -j$(nproc --all)
2017-10-22 03:58:02 +00:00
```
### Windows:
2017-04-02 07:33:01 +00:00
2019-05-01 04:08:00 +00:00
1. Install [MSYS2](https://www.msys2.org/)
2019-05-04 13:28:58 +00:00
2. Open the **MSYS2 MinGW 64-bit** terminal
2019-05-01 04:08:00 +00:00
3. Update the packages using `pacman -Syu` and reopen the terminal if it asks you to
#### Dynamic builds (with DLLs)
2020-07-31 20:20:47 +00:00
4. Install dependencies: `pacman -S git make mingw-w64-x86_64-{cmake,mesa,SDL2,toolchain,qt5,libslirp}`
2019-05-01 04:08:00 +00:00
5. Run the following commands
```bash
git clone https://github.com/Arisotura/melonDS.git
cd melonDS
mkdir build
cd build
cmake .. -G "MSYS Makefiles"
make -j$(nproc --all)
2019-05-01 04:08:00 +00:00
../msys-dist.sh
```
If everything went well, melonDS and the libraries it needs should now be in the `dist` folder.
#### Static builds (without DLLs, standalone executable)
4. Install dependencies: `pacman -S git make mingw-w64-x86_64-{cmake,mesa,SDL2,toolchain,qt5-static,libslirp}`
5. Run the following commands
```bash
git clone https://github.com/Arisotura/melonDS.git
cd melonDS
mkdir build
cd build
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.
2017-10-22 03:58:02 +00:00
## TODO LIST
2019-06-12 12:03:06 +00:00
* DSi emulation
* the impossible quest of pixel-perfect 3D graphics
* improve libui and the emulator UI
* support for rendering screens to separate windows
2017-08-29 16:17:44 +00:00
* emulating some fancy addons
* other non-core shit (debugger, graphics viewers, cheat crapo, etc)
2017-10-22 03:58:02 +00:00
### TODO LIST FOR LATER
2017-08-29 16:17:44 +00:00
* better wifi
* maybe emulate flashcarts or other fancy hardware
2017-03-12 23:45:26 +00:00
* big-endian compatibility (Wii, etc)
* LCD refresh time (used by some games for blending effects)
* any feature you can eventually ask for that isn't outright stupid
2017-10-22 03:58:02 +00:00
## Credits
2017-08-29 16:17:44 +00:00
* Martin for GBAtek, a good piece of documentation
* Cydrak for the extra 3D GPU research
2020-04-14 21:32:47 +00:00
* limittox for the icon
2017-08-29 16:17:44 +00:00
* All of you comrades who have been testing melonDS, reporting issues, suggesting shit, etc
## 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
(at your option) any later version.