2017-11-17 11:34:38 +01:00
|
|
|
# DXVK
|
|
|
|
|
|
|
|
Provides a Vulkan-based implementation of DXGI and D3D11 in order to run 3D applications on Linux using Wine.
|
|
|
|
|
|
|
|
For the current status of the project, please refer to the [project wiki](https://github.com/doitsujin/dxvk/wiki).
|
|
|
|
|
|
|
|
## Build instructions
|
|
|
|
|
|
|
|
### Requirements:
|
2017-12-05 13:27:36 +01:00
|
|
|
- [wine-staging](https://wine-staging.com/) for Vulkan support
|
2017-11-17 11:34:38 +01:00
|
|
|
- [Meson](http://mesonbuild.com/) build system
|
|
|
|
- [MinGW64](http://mingw-w64.org/) compiler and headers
|
2018-01-13 19:59:39 +03:00
|
|
|
- [glslang](https://github.com/KhronosGroup/glslang) front end and validator
|
2017-11-17 11:34:38 +01:00
|
|
|
|
|
|
|
### Building DLLs
|
|
|
|
Inside the dxvk directory, run:
|
|
|
|
```
|
2017-12-12 12:54:49 +01:00
|
|
|
# 64-bit build. For 32-bit builds, replace
|
|
|
|
# build-win64.txt with build-win32.txt
|
2017-11-17 11:34:38 +01:00
|
|
|
meson --cross-file build-win64.txt build.w64
|
|
|
|
cd build.w64
|
2017-12-12 12:54:49 +01:00
|
|
|
meson configure -Dprefix=/target/directory
|
2017-11-17 11:34:38 +01:00
|
|
|
ninja
|
|
|
|
ninja install
|
|
|
|
```
|
|
|
|
|
2017-12-12 12:54:49 +01:00
|
|
|
Both `dxgi.dll` and `d3d11.dll`as well as some demo executables will be located in `/your/directory/bin`.
|
2017-11-17 11:34:38 +01:00
|
|
|
|
|
|
|
## How to use
|
|
|
|
In order to run `executable.exe` with DXVK,
|
2018-01-13 16:36:04 +01:00
|
|
|
* Copy `dxgi.dll` and `d3d11.dll` into the same directory as the executable
|
2017-11-17 11:34:38 +01:00
|
|
|
* Run `WINEDLLOVERRIDES=d3d11,dxgi=n wine executable.exe`
|
|
|
|
|
2017-12-07 15:20:12 +01:00
|
|
|
DXVK will create a file `dxgi.log` in the current working directory and may print out messages to stderr.
|
|
|
|
|
|
|
|
### Environment variables
|
|
|
|
The behaviour of DXVK can be modified with environment variables.
|
|
|
|
|
2017-12-08 01:32:02 +01:00
|
|
|
- `DXVK_SHADER_DUMP_PATH=directory` Writes all DXBC and SPIR-V shaders to the given directory
|
2017-12-08 11:19:12 +01:00
|
|
|
- `DXVK_DEBUG_LAYERS=1` Enables Vulkan debug layers. Highly recommended for troubleshooting and debugging purposes.
|
2018-01-13 03:53:33 +01:00
|
|
|
- `DXVK_HUD=1` Enables the HUD
|
2017-12-08 11:19:12 +01:00
|
|
|
|
|
|
|
## Samples and executables
|
|
|
|
In addition to the DLLs, the following standalone programs are included in the project:
|
|
|
|
|
2017-12-28 19:07:52 +01:00
|
|
|
- `d3d11-compute`: Runs a simple compute shader demo. Requires native `d3dcompiler_47.dll`.
|
|
|
|
- `d3d11-triangle`: Renders a bunch of triangles using D3D11. Requires native `d3dcompiler_47.dll`.
|
2017-12-08 11:19:12 +01:00
|
|
|
- `dxgi-factory`: Enumerates DXGI adapters and outputs for debugging purposes.
|
2017-12-28 19:07:52 +01:00
|
|
|
- `dxbc-compiler`: Compiles a DXBC shader to SPIR-V.
|
2017-12-08 11:19:12 +01:00
|
|
|
- `dxbc-disasm`: Disassembles a DXBC shader. Requires native `d3dcompiler_47.dll`.
|
2018-01-13 19:59:39 +03:00
|
|
|
- `hlsl-compiler`: Compiles a HLSL shader to DXBC. Requires native `d3dcompiler_47.dll`.
|