Skip to content

Host Debugging

Stepping through xemu's code for development or troubleshooting an issue can be done via the process outlined below. Note that any GDB-based debugger should do, but VSCode's ease of use and multi-platform capabilities make it a good starter.

Setup

Install VSCode and the ms-vscode.cpptools extension.

Map a drive to the WSL2 root or your projects folder within. The particular path can be found by viewing \\wsl$ in File Explorer and reviewing the folders (distros) underneath. For example, net use w: \\wsl$\Ubuntu-20.04.

Install MSYS2, run the MSYS2 MinGW 64-bit shell, and install GDB.

$ pacman -S mingw-w64-x86_64-gdb

Create a file at xemu\.vscode\launch.json with the following contents.

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) Launch",
            "type": "cppdbg",
            "request": "launch",
            "program": "${workspaceFolder}\\dist\\xemu.exe",
            "args": [],
            "stopAtEntry": false,
            "cwd": "${workspaceFolder}\\dist",
            "environment": [{"name": "_NO_DEBUG_HEAP", "value": "1"}],
            "externalConsole": true,
            "MIMode": "gdb",
            "miDebuggerPath": "C:\\msys64\\mingw64\\bin\\gdb.exe",
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                }
            ]
        }
    ]
}

Create a file at xemu/.vscode/launch.json with the following contents.

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) Launch",
            "type": "cppdbg",
            "request": "launch",
            "program": "${workspaceFolder}/dist/xemu",
            "args": [],
            "stopAtEntry": false,
            "cwd": "${workspaceFolder}/dist",
            "environment": [],
            "externalConsole": false,
            "MIMode": "gdb",
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                }
            ]
        }
    ]
}

Create a file at xemu/.vscode/launch.json with the following contents.

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(lldb) Launch",
            "type": "cppdbg",
            "request": "launch",
            "program": "${workspaceFolder}/dist/xemu.app",
            "args": [],
            "stopAtEntry": false,
            "cwd": "${workspaceFolder}/dist",
            "externalConsole": false,
            "MIMode": "lldb",
            "setupCommands": [
                {
                    "description": "Ignore SIGUSR2",
                    "text": "process handle -p yes -s no -n no SIGUSR2"
                }
            ],
        }
    ]
}

Build & Run

Follow the build instructions appending --debug to the CLI arguments, open the xemu project directory in VSCode via FileOpen folder..., and press F5 to start debugging.

Tip: Arguments

Argument key-value pairs must be separated.

"args": [
    "-machine","xbox,avpack=hdtv"
]

Host and guest debugging can be used simultaneously.

"args": [
    // enable the guest gdb server
    "-s",

    // start in a paused state
    "-S"
]

Debugging crashes

Windows

Getting a core dump

If xemu is crashing and the reason is not clear, you can create a core dump to provide developers with to investigate. To create a core dump on Windows for crash analysis:

First, apply the registry edit script found in this Zip file: xemu_dump_registry_config.zip. This registry edit will configure Windows to create a dump whenever xemu crashes.

Then, download and run the debug build of xemu found at: https://github.com/xemu-project/xemu/releases/latest/download/xemu-win-debug.zip

The dump will be stored at %LOCALAPPDATA%\CrashDumps. You may notice a delay after xemu crashes while this file is saved.