Build guide

Follow these steps to compile 86Box from source:

  1. Install the MSYS2 environment. The rest of the guide will refer to the directory that you install it to (C:\msys32 or C:\msys64 by default) as the MSYS2 root.

  2. Launch your MSYS2 environment using the MSYS2 MinGW 32-bit shortcut. If you do not wish to use the shortcut, launch it using the mingw32.exe executable in the MSYS2 root.

  3. Once launched, you should update the environment:
    $ pacman -Syu
    

    You may need to do this twice, just follow the on-screen instructions. Please re-run the command periodically to keep the environment up-to-date.

  4. Run the following command to install all of the dependencies:
    $ pacman -S gdb make git mingw-w64-i686-toolchain mingw-w64-i686-openal mingw-w64-i686-freetype mingw-w64-i686-SDL2 mingw-w64-i686-zlib mingw-w64-i686-libpng
    
  5. Once the environment is fully updated and all dependencies are installed, change directory to src:
    $ cd path/to/86Box/src
    
  6. Start the actual compilation process:
    $ make -f win/Makefile.mingw
    

    make does not run in parallel by default. Use the -j switch to specify the number of parallel threads, such as -j4 for 4 threads. You should not exceed your system’s thread (logical processor) count, as that uses more resources for little to no gain.

  1. If compilation succeeded (which it almost always should), the 86Box.exe executable will be in the src directory.

  2. In order to test your fresh build, replace the 86Box.exe in your current 86Box environment with your freshly-built one. If you do not have a pre-existing 86Box environment, download the latest successful build from the 86Box Jenkins, and the latest ROM set from the roms repository.

  3. Enjoy using and testing the emulator! :)

If you encounter issues at any step or have additional questions, please join the IRC channel or the appropriate channel on our Discord server and wait patiently for someone to help you.