- 
                Notifications
    You must be signed in to change notification settings 
- Fork 160
ares Build Options
When generating/configuring ares on any platform, a number of configuration options are available.
- Primary Configuration - General ares configuration
- Compilation - Options that control build optimizations and compiler configuration
- Linux-specific Packaging - Options specific Linux build configurations
- Miscellaneous - Debugging, experimental features, advanced options
- Useful CMake Options - Other non-ares-specific CMake variables that may be useful
Default: "a26;fc;sfc;sg;ms;md;ps1;pce;ng;msx;cv;myvision;gb;gba;ws;ngp;spec;n64"
By default, ares configures with all emulator cores. To specify that only a subset of cores should be built, use the -DARES_CORES option. For example:
cmake .. -G Ninja -DARES_CORES="a26;n64;sg;myvision"
Default: RelWithDebInfo
Multi-configuration generators (Xcode, Visual Studio, Ninja Multi-Config) will automatically configure with all build configurations available. Single-configuration generators will configure by default using the RelWithDebInfo configuration. To specify another configuration, use -DCMAKE_BUILD_TYPE:
cmake .. -G "MinGW Makefiles" -DCMAKE_BUILD_TYPE=Debug
Supported build types are <Debug|Release|RelWithDebInfo|MinSizeRel>.
Default: ON
This flag may be disabled if you wish to compile without librashader and slang-shaders, producing a slimmer build. Note that the librashader header is still required to build without librashader; however, this header is bundled as part of ares-deps on all platforms and it should not be necessary to install any dependency to build without librashader.
These options generally control compile optimizations and options that affect compiler performance and behavior.
| Variable | Description | Default | OS | 
|---|---|---|---|
| ARES_BUILD_LOCAL | Controls the -march=nativeoption for producing more optimized code for the target machine. Also controls certain entitlements and runtime options on macOS that interfere with debugging but are required for notarization and distribution. | ON | All | 
| ENABLE_CCACHE | Sets whether to use Ccache to speed up compilation. Disabling Ccache is recommended if you are experimenting with compilation options or working on the build system. | ON | All | 
| ENABLE_IPO | Controls whether CMake's interprocedural optimization (otherwise known as link-time optimization or LTO) is enabled. | ON | All | 
| ARES_PRECOMPILE_HEADERS | Controls whether to precompile headers to reduce compile times. Turn off if you encounter compile issues. | OFF | All | 
| ARES_UNITY_CORES | Builds each core in ares as a single translation unit. Faster cold build times and slightly better performance, but slower incremental builds. | OFF | All | 
| ARES_CODESIGN_TEAM | Apple Development Team ID for producing signed builds on macOS | - | macOS | 
| ARES_CODESIGN_IDENTITY | Apple Development identity string for producing signed builds on macOS | - | macOS | 
| ENABLE_COMPILER_TRACE | Enable clang compiler traces for debugging compiler performance | - | All | 
| ARES_MINGW_USE_DWARF_SYMBOLS | On Windows MSYS2/MinGW toolchains, generate DWARF debug symbols instead of CodeView ones, for use with gdb or lldb. | ONfor GCC, otherwiseOFF | Windows | 
| CMAKE_OSX_DEPLOYMENT_TARGET | Minimum version of macOS that you wish to build for | "10.15" | macOS | 
| CMAKE_OSX_ARCHITECTURES | Controls whether single-arch or universal binaries are built on macOS | Host | macOS | 
Default: ON
Set to OFF to not install libretro shaders with ares in the ares data directory. Intended for use with package manager installs of libretro's slang-shaders.
Default: OFF
For use by package maintainers; instructs CMake to not fetch prebuilt ares-deps. On Linux, this option fetches only slang-shaders.
Default: ON
Controls whether to pass a "minimum" target instruction set version to the compiler representing the minimum level of SSE functionality we expect to be able to use. Defaults to x86-64-v2 on x86_64; undefined on arm64.
Note
Building ares without advanced SSE feature sets can mean a performance loss of 10% or higher depending on the system. It is recommended to keep enabled and define this minimum requirement for x86_64 systems.
These options control whether ares will search for and attempt to build with the following ruby audio and input drivers.
| Variable | Description | Default | OS | 
|---|---|---|---|
| ARES_ENABLE_OPENAL | Enables the OpenAL audio driver | ON | Linux/BSD | 
| ARES_ENABLE_SDL | Enables the SDL audio and input drivers | ON | Linux/BSD | 
| ARES_ENABLE_OSS | Enables the OSS audio driver | ON | Linux/BSD | 
| ARES_ENABLE_ALSA | Enables the ALSA audio driver | ON | Linux/BSD | 
| ARES_ENABLE_PULSEAUDIO | Enables the Pulse and Pulse-Simple audio drivers | ON | Linux/BSD | 
| ARES_ENABLE_AO | Enables the AO audio driver | ON | Linux/BSD | 
| ARES_ENABLE_UDEV | Enables the udev input driver | ON | Linux/BSD | 
| ARES_ENABLE_USBHID | Enables the usbhid input driver | ON | BSD | 
| Variable | Description | Default | OS | 
|---|---|---|---|
| ARES_BUILD_OFFICIAL | Use an official git describeversion string for the application version information. For CI, this isONfor builds on the master branch. | OFF | All | 
| ARES_BUILD_OPTIONAL_TARGETS | Whether to include supplementary executable targets besides desktop-uiandsourceryin the build. | OFF | All | 
| ARES_ENABLE_CHD | Enables support for MAME's "compressed hunks of data" format via libchdr. | ON | All | 
| CCACHE_PROGRAM | Point CMake toward a specific Ccache installation location | ON | All | 
| ARES_SKIP_DEPS | Skip downloading precompiled dependencies from ares-deps. This is NOT intended for general use, but is included for debugging purposes. | ON | All | 
| <DEPENDENCY>_LIBRARY | Point CMake toward a specific library location for a dependency. This is NOT intended for general use, but is included for debugging. If you need to use this option, you should file a bug report. | ON | All | 
| <DEPENDENCY>_INCLUDE_DIR | Point CMake toward a specific library include directory. This is NOT intended for general use, but is included for debugging. If you need to use this option, you should file a bug report. | ON | All | 
| WITH_SYSTEM_ZLIB | Try to use a system-installed zlib when compiling libchdr | OFF | macOS | 
| USE_QT5 | Try to build with QT5 on Linux instead of GTK3 | OFF | Linux | 
| ARES_VERSION_OVERRIDE | Define a custom ares version when building. | - | All | 
| ARES_PROFILE_ACCURACY | Mostly unused in modern versions of ares; acts as a compile-time switch to prefer accuracy over performance in certain areas in some emulator cores. | OFF | ALL | 
| Variable | Description | Default | OS | 
|---|---|---|---|
| CMAKE_C_COMPILER | Specify a non-default C compiler for the build. Works with Ccache. | Default | All | 
| CMAKE_CXX_COMPILER | Specify a non-default C++ compiler for the build. Works with Ccache. | Default | All | 
| CMAKE_PREFIX_PATH | Specify directories in which to search for dependencies in addition to the defaults. | Default | All | 
| CMAKE_INSTALL_PREFIX | Specify a prefix in which to install ares after building. | Default | All |