mirror of
https://github.com/mikage-emu/mikage-dev.git
synced 2025-01-24 14:28:17 +01:00
56 lines
2.1 KiB
Markdown
56 lines
2.1 KiB
Markdown
|
# Mikage Developer Edition
|
||
|
|
||
|
## Build instructions
|
||
|
|
||
|
CMake and Conan 2 are required to build Mikage.
|
||
|
* `mkdir build`
|
||
|
* `cd build`
|
||
|
* `conan install .. -of . --build=missing` (add `-s build_type=Debug` for Debug builds)
|
||
|
* `cmake -DCMAKE_BUILD_TYPE=Release .. -G Ninja -DCMAKE_PREFIX_PATH=\`realpath .\``
|
||
|
* `ninja`
|
||
|
|
||
|
The Conan install may fail if the shaderc package cannot be found. In this case,
|
||
|
download our [custom recipe from conan-3ds](https://github.com/mikage-emu/conan-3ds/tree/mikage/packages/shaderc)
|
||
|
and run `conan export . --version 2021.1` from within this `shaderc` folder.
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
For the first launch, three things must be set up:
|
||
|
1. a complete `aes_keys.txt` must be placed in the `build` folder
|
||
|
2. a virtual NAND must be bootstrapped from a game update partition
|
||
|
3. the 3DS initial system setup must be run
|
||
|
|
||
|
Given any game with an update partition, steps 2 and 3 can be done by running:
|
||
|
```
|
||
|
cd build && source conanrun.sh && ./source/mikage game.cci --bootstrap_nand --launch_menu
|
||
|
```
|
||
|
NOTE: Currently, this probably requires a game of the EU region. Patching
|
||
|
`SecureInfo_A` by hand after bootstrapping may work, too.
|
||
|
|
||
|
Once set up, it's sufficient to run `./source/mikage game.cci` or `./source/mikage --launch_menu`.
|
||
|
You'll need to `source conanrun.sh` to set up library directories.
|
||
|
|
||
|
## Key bindings
|
||
|
|
||
|
* Arrow →: A
|
||
|
* Arrow ↓: B
|
||
|
* Arrow ↑: X
|
||
|
* Arrow ←: Y
|
||
|
* WASD keys: Circle pad
|
||
|
* Backspace: HOME (press twice to power down)
|
||
|
* Q key: L
|
||
|
* E key: L
|
||
|
* IJKL keys: D-pad
|
||
|
|
||
|
## Debugging
|
||
|
|
||
|
Individual processes may be debugged through an embedded GDB remote server over
|
||
|
network port 12345. To enable it, pass `--debug` and `--attach_to_process <pid>`
|
||
|
when launching Mikage. After startup, connect via gdb using `tar ext :12345`,
|
||
|
wait until Mikage prints a message about waiting for the debugger attach, then
|
||
|
type `attach <PID>` in the gdb shell. Note that a gdb build for ARM targets may
|
||
|
be necessary to do this. Debuggers other than gdb may work but are untested.
|
||
|
|
||
|
Processes running in the emulated kernel can be introspected through a simple
|
||
|
debug console available via telnet on port 12347.
|