From 3a9a70b5f0dc65eb5d9dd3683aba414bfeffeff2 Mon Sep 17 00:00:00 2001 From: Blisto91 <47954800+Blisto91@users.noreply.github.com> Date: Mon, 17 Jul 2023 13:22:18 +0200 Subject: [PATCH] [meta] Add Graphics Pipeline Library section to readme --- README.md | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 3f50ccbcc..c32c196bd 100644 --- a/README.md +++ b/README.md @@ -26,7 +26,7 @@ cp x32/*.dll $WINEPREFIX/drive_c/windows/system32 winecfg ``` -Verify that your application uses DXVK instead of wined3d by by enabling the HUD (see notes below). +Verify that your application uses DXVK instead of wined3d by enabling the HUD (see notes below). In order to remove DXVK from a prefix, remove the DLLs and DLL overrides, and run `wineboot -u` to restore the original DLL files. @@ -116,6 +116,15 @@ Some applications do not provide a method to select a different GPU. In that cas **Note:** If the device filter is configured incorrectly, it may filter out all devices and applications will be unable to create a D3D device. +### Graphics Pipeline Library +On drivers which support `VK_EXT_graphics_pipeline_library` Vulkan shaders will be compiled at the time the game loads its D3D shaders, rather than at draw time. This reduces or eliminates shader compile stutter in many games when compared to the previous system. + +In games that load their shaders during loading screens or in the menu, this can lead to prolonged periods of very high CPU utilization, especially on weaker CPUs. For affected games it is recommended to wait for shader compilation to finish before starting the game to avoid stutter and low performance. Shader compiler activity can be monitored with `DXVK_HUD=compiler`. + +This feature largely replaces the state cache. + +**Note:** Games which only load their D3D shaders at draw time (e.g. most Unreal Engine games) will still exhibit some stutter, although it should still be less severe than without this feature. + ### State cache DXVK caches pipeline state by default, so that shaders can be recompiled ahead of time on subsequent runs of an application, even if the driver's own shader cache got invalidated in the meantime. This cache is enabled by default, and generally reduces stuttering. @@ -125,6 +134,8 @@ The following environment variables can be used to control the cache: - `reset`: Clears the cache file. - `DXVK_STATE_CACHE_PATH=/some/directory` Specifies a directory where to put the cache files. Defaults to the current working directory of the application. +This feature is mostly only relevant on systems without support for `VK_EXT_graphics_pipeline_library` + ### Debugging The following environment variables can be used for **debugging** purposes. - `VK_INSTANCE_LAYERS=VK_LAYER_KHRONOS_validation` Enables Vulkan debug layers. Highly recommended for troubleshooting rendering issues and driver crashes. Requires the Vulkan SDK to be installed on the host system.