dxvk-remix is a fork of the DXVK project, which overhauls the fixed-function graphics pipeline implementation in order to remaster games with path tracing.
Thanks to all the contributors to DXVK for creating this foundational piece of software, on top of which we were able to build the RTX Remix Runtime.
While dxvk-remix is a fork of DXVK, please report bugs encountered with dxvk-remix to this repo rather than to the DXVK project.
- Windows 10 or 11
- Git
- Visual Studio
- VS 2019 is tested
- VS 2022 may also work, but it is not actively tested
- Note that our build system will always use the most recent version available on the system
- Windows SDK
- 10.0.19041.0 is tested
- Meson
- 0.61.4 has been tested
- Follow instructions on how to install and reboot the PC before moving on (Meson will indicate as much)
- Vulkan SDK
- 1.3.211.0 or newer
- You may need to uninstall previous SDK if you have an old version
- Python
- 3.9 or newer
- DirectX Runtime
- Latest version should work.
- This includes d3d9x*.dll which are required to run the game
- May already be installed if you have D3D9 games installed
- If any dependency paths change (i.e. new Vulkan library), run
meson --reconfigure
in _Compiler64 directory via a command prompt. This may revert some custom VS project settings
-
Clone the repository with all submodules:
git clone --recursive https://github.com/NVIDIAGameWorks/dxvk-remix.git
If the clone was made non-recursively and the submodules are missing, clone them separately:
git submodule update --init --recursive
-
Install all the requirements before proceeding further
-
Make sure PowerShell scripts are enabled
- One-time system setup: run
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned
in an elevated PowerShell prompt, then close and reopen any existing PowerShell prompts
- One-time system setup: run
-
To generate and build dxvk-remix project:
- Right Click on
dxvk-remix\build_dxvk_all_ninja.ps1
and select "Run with Powershell" - If that fails or has problems, run the build manually in a way you can read the errors:
- open a windows file explorer to the
dxvk-remix
folder - remove artifacts from the previous attempt by deleting all folders that start with
_
, i.e._vs/
and_Comp64Debug
- type
cmd
in the address bar to open a command line window in that folder. - copy and paste
powershell -command "& .\build_dxvk_all_ninja.ps1"
into the command line, then press enter
- open a windows file explorer to the
- This will build all 3 configurations of dxvk-remix project inside subdirectories of the build tree:
- _Comp64Debug - full debug instrumentation, runtime speed may be slow
- _Comp64DebugOptimized - partial debug instrumentation (i.e. asserts), runtime speed is generally comparable to that of release configuration
- _Comp64Release - fastest runtime
- This will generate a project in the _vs subdirectory
- Only x64 build targets are supported
- Right Click on
-
Open _vs/dxvk-remix.sln in Visual Studio (2019+).
- Do not convert the solution on load if prompted when using a newer version of Visual Studio
- Once generated, the project can be built via Visual Studio or via powershell scripts
- A build will copy generated DXVK DLLs to any target project as specified in gametargets.conf (see its setup section)
-
First time only: copy gametargets.example.conf to gametargets.conf in the project root
-
Update paths in the gametargets.conf for your game. Follow example in the gametargets.example.conf. Make sure to remove "#" from the start of all three lines
-
Open and, simply, re-save top-level meson.build file (i.e. via notepad) to update its time stamp, and rerun the build. This will trigger a full meson script run which will generate a project within the Visual Studio solution file and deploy built binaries into games' directories specified in gametargets.conf
Remix has support for profiling using the Tracy tool, specifically the v0.8 release
To enable Tracy profiling:
- Open a command line window in a build folder (i.e.
dxvk-remix/_Comp64Release/
) - Run
meson --reconfigure -D enable_tracy=true
- Rebuild dxvk-remix-nv
To profile:
- Launch tracy.exe
- Launch the game and reach the section you wish to profile
- When ready, hit
Connect
in Tracy to begin profiling. - It's best to collect at least 500 frames worth of data, so you can average out the results.
If there's an intent to use the Remix Renderer in projects with available source code, Direct3D 9 API can be utilized, since Remix's d3d9.dll
implements the Direct3D 9 API.
Alternatively, Remix API can be used to programmatically pass the game data to the Remix Renderer, with or instead of Direct3D API. Click for more info.