2016-10-28 12:33:37 +02:00
|
|
|
=============================
|
|
|
|
The vkd3d 3D Graphics Library
|
|
|
|
=============================
|
|
|
|
|
|
|
|
Vkd3d is a 3D graphics library built on top of Vulkan. It has an API very
|
|
|
|
similar, but not identical, to Direct3D 12.
|
2019-01-25 21:38:57 +03:30
|
|
|
|
|
|
|
==============
|
|
|
|
Building vkd3d
|
|
|
|
==============
|
|
|
|
|
2023-12-14 14:58:19 +10:00
|
|
|
Vkd3d depends on SPIRV-Headers and Vulkan-Headers (>= 1.3.228).
|
2019-01-25 21:38:57 +03:30
|
|
|
|
|
|
|
Vkd3d generates some of its headers from IDL files. If you are using the
|
|
|
|
release tarballs, then these headers are pre-generated and are included. If
|
|
|
|
you are building from git, then they will be generated at build-time using
|
|
|
|
widl. By default, vkd3d will use the widl found in `PATH'. If widl is not
|
2023-07-11 11:08:37 +02:00
|
|
|
available or is not recent (>= 3.21), then you can build Wine with `make
|
|
|
|
tools/widl/widl' to avoid building all of Wine. You can then point vkd3d's
|
2019-01-25 21:38:57 +03:30
|
|
|
configure at that widl binary with `WIDL="/path/to/widl"'.
|
|
|
|
|
2024-10-01 18:53:09 +02:00
|
|
|
For release builds, you may want to disable debug log messages defining
|
|
|
|
preprocessor macros VKD3D_NO_TRACE_MESSAGES and VKD3D_NO_DEBUG_MESSAGES.
|
|
|
|
See the `Preprocessor definitions' section below for more details.
|
2019-05-17 10:39:16 +02:00
|
|
|
|
2024-10-01 18:54:56 +02:00
|
|
|
================
|
|
|
|
Developing vkd3d
|
|
|
|
================
|
|
|
|
|
|
|
|
Development of vkd3d happens on the Wine GitLab instance
|
|
|
|
(https://gitlab.winehq.org/wine/vkd3d/). Contributors are encouraged
|
|
|
|
to submit their patches using the merge request tool.
|
|
|
|
|
|
|
|
Each merge request is automatically tested with the GitLab CI
|
|
|
|
system. See gitlab/README in the Git tree for more details.
|
|
|
|
|
2019-01-25 21:38:57 +03:30
|
|
|
===========
|
|
|
|
Using vkd3d
|
|
|
|
===========
|
|
|
|
|
|
|
|
Vkd3d can be used by projects that target Direct3D 12 as a drop-in replacement
|
|
|
|
at build-time with some modest source modifications.
|
|
|
|
|
|
|
|
If vkd3d is available when building Wine, then Wine will use it to support
|
|
|
|
Direct3D 12 applications.
|
2019-05-17 10:39:15 +02:00
|
|
|
|
|
|
|
=====================
|
|
|
|
Environment variables
|
|
|
|
=====================
|
|
|
|
|
|
|
|
Most of the environment variables used by vkd3d are for debugging purposes. The
|
2024-10-01 18:53:09 +02:00
|
|
|
environment variables are not considered a stable interface and might be changed
|
|
|
|
or removed in future versions of vkd3d.
|
2019-05-17 10:39:15 +02:00
|
|
|
|
|
|
|
Some of debug variables are lists of elements. Elements must be separated by
|
|
|
|
commas or semicolons.
|
|
|
|
|
2021-08-31 01:16:26 +02:00
|
|
|
* NO_COLOR - this is an alias of NO_COLOUR.
|
|
|
|
|
2023-08-03 12:00:01 +02:00
|
|
|
* NO_COLOUR - when set, vkd3d-compiler and vkd3d-dxbc will default to
|
|
|
|
monochrome output, even when the output supports colour.
|
2021-08-31 01:16:26 +02:00
|
|
|
|
2019-05-17 10:39:15 +02:00
|
|
|
* VKD3D_CONFIG - a list of options that change the behavior of libvkd3d.
|
2022-02-22 01:18:59 +10:00
|
|
|
* virtual_heaps - Create descriptors for each D3D12 root signature
|
|
|
|
descriptor range instead of entire descriptor heaps. Useful when push
|
|
|
|
constant or bound descriptor limits are exceeded.
|
2019-05-17 10:39:15 +02:00
|
|
|
* vk_debug - enables Vulkan debug extensions.
|
|
|
|
|
|
|
|
* VKD3D_DEBUG - controls the debug level for log messages produced by
|
|
|
|
libvkd3d. Accepts the following values: none, err, fixme, warn, trace.
|
|
|
|
|
|
|
|
* VKD3D_VULKAN_DEVICE - a zero-based device index. Use to force the selected
|
|
|
|
Vulkan device.
|
|
|
|
|
|
|
|
* VKD3D_DISABLE_EXTENSIONS - a list of Vulkan extensions that libvkd3d should
|
|
|
|
not use even if available.
|
|
|
|
|
2024-08-09 22:30:05 +02:00
|
|
|
* VKD3D_CAPS_OVERRIDE - a list of Direct3D 12 capabilities for which the
|
|
|
|
default value detected by vkd3d should be overridden, in the form
|
|
|
|
`capability1=value1,capability2=value2'. This doesn't change the vkd3d
|
|
|
|
behaviour, only the information reported to the application. The following
|
|
|
|
capabilities can currently be overridden:
|
|
|
|
* feature_level (allowed values: 11.0, 11.1, 12.0, 12.1, 12.2)
|
|
|
|
* resource_binding_tier (allowed values: 1, 2, 3)
|
|
|
|
|
2023-12-03 16:28:53 +01:00
|
|
|
* VKD3D_SHADER_CONFIG - a list of options that change the behavior of
|
|
|
|
libvkd3d-shader.
|
|
|
|
* force_validation - Enable (additional) validation of libvkd3d-shader's
|
|
|
|
internal representation of shaders.
|
|
|
|
|
2019-05-17 10:39:15 +02:00
|
|
|
* VKD3D_SHADER_DEBUG - controls the debug level for log messages produced by
|
|
|
|
libvkd3d-shader. See VKD3D_DEBUG for accepted values.
|
|
|
|
|
|
|
|
* VKD3D_SHADER_DUMP_PATH - path where shader bytecode is dumped.
|
|
|
|
|
|
|
|
* VKD3D_TEST_DEBUG - enables additional debug messages in tests. Set to 0, 1
|
|
|
|
or 2.
|
|
|
|
|
2024-08-06 17:43:28 -04:00
|
|
|
* VKD3D_TEST_DETAILED - enables printing detailed output when running the test
|
|
|
|
suite, reporting specific shader_test lines that trigger XFAIL and SKIP even
|
|
|
|
on tests that overall PASS. Set to 0, or 1.
|
|
|
|
|
2019-07-17 13:17:35 +02:00
|
|
|
* VKD3D_TEST_FILTER - a filter string. Only the tests whose names matches the
|
|
|
|
filter string will be run, e.g. VKD3D_TEST_FILTER=clear_render_target.
|
|
|
|
Useful for debugging or developing new tests.
|
|
|
|
|
2019-05-17 10:39:15 +02:00
|
|
|
* VKD3D_TEST_PLATFORM - can be set to "wine", "windows" or "other". The test
|
|
|
|
platform controls the behavior of todo(), todo_if(), bug_if() and broken()
|
|
|
|
conditions in tests.
|
|
|
|
|
2024-05-27 20:13:53 +02:00
|
|
|
* VKD3D_TEST_SKIP_DXC - when set, tests requiring the dxcompiler library will
|
|
|
|
be skipped.
|
|
|
|
|
2019-05-17 10:39:15 +02:00
|
|
|
* VKD3D_TEST_BUG - set to 0 to disable bug_if() conditions in tests.
|
2023-08-30 22:09:39 +02:00
|
|
|
|
2023-09-14 19:29:24 +10:00
|
|
|
If the configuration defines 'DXCOMPILER_LIBS=-L/path/to/dxcompiler', Shader
|
|
|
|
Runner attempts to load libdxcompiler.so or dxcompiler.dll to compile test
|
|
|
|
shaders in Shader Model 6. LD_LIBRARY_PATH (linux), WINEPATH (wine) or PATH
|
|
|
|
(native windows) should include the location of dxcompiler if SM 6 shader
|
|
|
|
tests are desired. If dxcompiler is not found, Shader Runner will compile the
|
|
|
|
test shaders only in earlier shader models. The DXC source does not contain
|
|
|
|
code for adding DXBC checksums, so the official release should be installed
|
|
|
|
from:
|
|
|
|
https://github.com/microsoft/DirectXShaderCompiler/releases
|
|
|
|
|
2024-10-01 18:53:09 +02:00
|
|
|
========================
|
|
|
|
Preprocessor definitions
|
|
|
|
========================
|
|
|
|
|
|
|
|
A number of preprocessor definitions can be used at compilation time to control
|
|
|
|
the behaviour of the generated binary. You can pass something like
|
|
|
|
`CPPFLAGS="-DVKD3D_VAR1 -DVKD3D_VAR2"' to the configure script. The preprocessor
|
|
|
|
variables are not considered a stable interface and might be changed or removed
|
|
|
|
in future versions of vkd3d.
|
|
|
|
|
|
|
|
* VKD3D_NO_TRACE_MESSAGES - do not emit trace messages in the debug log; this
|
|
|
|
can be useful in release builds to reduce the size of the binary and make it
|
|
|
|
slightly faster.
|
|
|
|
|
|
|
|
* VKD3D_NO_DEBUG_MESSAGES - do not emit warn and fixme messages in the debug
|
|
|
|
log; this will further optimise the binary, but may omit messages that could
|
|
|
|
help debug problems with vkd3d.
|
|
|
|
|
|
|
|
* VKD3D_NO_ERROR_MESSAGES - do not emit error messages; this will optimise the
|
|
|
|
binary even more, but may omit very important messages, so it is not
|
|
|
|
recommended in most circumstances.
|
|
|
|
|
|
|
|
* VKD3D_ABORT_ON_ERR - abort the process as soon as an error message is
|
|
|
|
emitted; this can be useful for developers to make error conditions as
|
|
|
|
conspicuous as possible.
|
|
|
|
|
|
|
|
* VKD3D_SHADER_UNSUPPORTED_DXIL - enable DXIL (DirectX Intermediate Language)
|
|
|
|
support in vkd3d-shader, which is disabled by default because it is not
|
|
|
|
considered ready for release yet. Please note that this feature is not
|
|
|
|
currently supported, and it might change in a non-compatible way before it is
|
|
|
|
released.
|
|
|
|
|
|
|
|
* VKD3D_SHADER_UNSUPPORTED_GLSL - enable GLSL (GL Shading Language) support in
|
|
|
|
vkd3d-shader, which is disabled by default because it is not considered ready
|
|
|
|
for release yet. Please note that this feature is not currently supported,
|
|
|
|
and it might change in a non-compatible way before it is released.
|
|
|
|
|
|
|
|
* VKD3D_SHADER_UNSUPPORTED_MSL - enable MSL (Metal Shading Language) support in
|
|
|
|
vkd3d-shader, which is disabled by default because it is not considered ready
|
|
|
|
for release yet. Please note that this feature is not currently supported,
|
|
|
|
and it might change in a non-compatible way before it is released.
|
|
|
|
|
2024-05-02 11:56:04 -07:00
|
|
|
============================
|
|
|
|
Testing with the Agility SDK
|
|
|
|
============================
|
|
|
|
|
|
|
|
Traditionally Microsoft have released the Direct3D 12 development files,
|
|
|
|
including the debug layer runtime, as part of the larger Windows SDK.
|
|
|
|
In 2021 the DirectX 12 Agility SDK was introduced, which may be updated
|
|
|
|
independently of the Windows SDK. If you plan to run the vkd3d
|
|
|
|
crosstests with Microsoft's debug layer you might want to get it from
|
|
|
|
the Agility SDK, both because it's probably going to be more up-to-date
|
|
|
|
and because the Agility SDK is a couple dozens of megabytes versus the
|
|
|
|
gigabytes of the Windows SDK.
|
|
|
|
|
|
|
|
In order to build the vkd3d crosstests with Agility SDK support, follow
|
|
|
|
these steps:
|
|
|
|
|
|
|
|
* The Agility SDK is distributed at [1]: select your preferred
|
|
|
|
version (likely the most recent one) and note the number in column
|
|
|
|
D3D12SDKVersion, which you're going to need later.
|
|
|
|
|
|
|
|
[1] https://devblogs.microsoft.com/directx/directx12agility/
|
|
|
|
|
2024-07-17 15:14:26 +02:00
|
|
|
* You also need to enable the "Graphics Tools" optional feature in Windows.
|
|
|
|
Open the "Settings" applications, then look for "Apps", "Optional features",
|
|
|
|
"View features" and install "Graphics Tools".
|
|
|
|
|
2024-05-02 11:56:04 -07:00
|
|
|
* Configure vkd3d with something like:
|
|
|
|
'CROSSCC64="x86_64-w64-mingw32-gcc -DVKD3D_AGILITY_SDK_VERSION=<version>"',
|
|
|
|
as well as the equivalent CROSSCC32 variable for the 32-bit
|
|
|
|
crosstests. You'll have to replace '<version>' with the
|
|
|
|
D3D12SDKVersion number you noted above. Then build the crosstests
|
|
|
|
with 'make crosstest' as usual.
|
|
|
|
|
|
|
|
* Download the Agility SDK NuGet package, which is essentially a ZIP
|
|
|
|
file with a .nupkg extension. Extract d3d12core.dll and
|
|
|
|
d3d12sdklayers.dll for your architecture, and put them in the
|
|
|
|
directory containing the crosstest executables.
|
|
|
|
|
|
|
|
* Now you can run the crosstests, possibly with arguments
|
|
|
|
'--validate' and '--gbv' to enable the debug layers. They will use
|
|
|
|
the runtime from the Agility SDK.
|
|
|
|
|
|
|
|
* It's also possible to use '-DVKD3D_AGILITY_SDK_PATH=/path/to/sdk/' to
|
|
|
|
specify the directory to load the Agility SDK DLLs from at runtime.
|
|
|
|
If relative, the path is intended to be relative to the executable
|
2024-07-17 14:55:07 +02:00
|
|
|
path. If unspecified the path defaults to './'.
|