• Home
  • History
  • Annotate
Name Date Size #Lines LOC

..--

BUILD.gnD23-Nov-2023474 2016

LICENSE.mdD23-Nov-20231 KiB2016

README.chromiumD23-Nov-2023629 2017

README.mdD23-Nov-20235.6 KiB10572

volk.cD23-Nov-2023122.1 KiB1,6971,651

volk.hD23-Nov-202360.4 KiB1,1101,004

README.chromium

1Name: Volk Meta loader for Vulkan API
2Short Name: volk
3URL: https://github.com/zeux/volk
4Version: 0
5License: MIT
6License File: LICENSE.md
7Security Critical: yes
8
9Description:
10volk is a meta-loader for Vulkan. It allows you to dynamically load
11entrypoints required to use Vulkan without linking to vulkan-1.dll
12or statically linking Vulkan loader. Additionally, volk simplifies
13the use of Vulkan extensions by automatically loading all associated
14entrypoints. Finally, volk enables loading Vulkan entrypoints directly
15from the driver which can increase performance by skipping loader
16dispatch overhead.
17
18Local Modifications:
19NONE
20

README.md

1# �� volk [![Build Status](https://travis-ci.org/zeux/volk.svg?branch=master)](https://travis-ci.org/zeux/volk)
2
3## ANGLE Integration
4
5Note that the entirety of the volk README.md is included below. This is an additional section with information
6on volk's integration into ANGLE. The volk source files are copied directly from the volk GitHub repo.
7To update volk in ANGLE, copy the latest volk.h/c files into ANGLE "src/third_party/volk" dir and push update.
8If any changes are made to volk source files locally within ANGLE, please also make corresponding PRs so that
9the changes land in the upstream source volk GitHub repo.
10
11## Purpose
12
13volk is a meta-loader for Vulkan. It allows you to dynamically load entrypoints required to use Vulkan
14without linking to vulkan-1.dll or statically linking Vulkan loader. Additionally, volk simplifies the use of Vulkan extensions by automatically loading all associated entrypoints. Finally, volk enables loading
15Vulkan entrypoints directly from the driver which can increase performance by skipping loader dispatch overhead.
16
17volk is written in C89 and supports Windows, Linux, Android and macOS (via MoltenVK).
18
19## Building
20
21There are multiple ways to use volk in your project:
22
231. You can just add `volk.c` to your build system. Note that the usual preprocessor defines that enable Vulkan's platform-specific functions (VK_USE_PLATFORM_WIN32_KHR, VK_USE_PLATFORM_XLIB_KHR, VK_USE_PLATFORM_MACOS_MVK, etc) must be passed as desired to the compiler when building `volk.c`.
242. You can use volk in header-only fashion. Include `volk.h` whereever you want to use Vulkan functions. In exactly one source file, define `VOLK_IMPLEMENTATION` before including `volk.h`. Do not build `volk.c` at all in this case. This method of integrating volk makes it possible to set the platform defines mentioned above with arbitrary (preprocessor) logic in your code.
253. You can use provided CMake files, with the usage detailed below.
26
27## Basic usage
28
29To use volk, you have to include `volk.h` instead of `vulkan/vulkan.h`; this is necessary to use function definitions from volk.
30If some files in your application include `vulkan/vulkan.h` and don't include `volk.h`, this can result in symbol conflicts; consider defining `VK_NO_PROTOTYPES` when compiling code that uses Vulkan to make sure this doesn't happen.
31
32To initialize volk, call this function first:
33
34```c++
35VkResult volkInitialize();
36```
37
38This will attempt to load Vulkan loader from the system; if this function returns `VK_SUCCESS` you can proceed to create Vulkan instance.
39If this function fails, this means Vulkan loader isn't installed on your system.
40
41After creating the Vulkan instance using Vulkan API, call this function:
42
43```c++
44void volkLoadInstance(VkInstance instance);
45```
46
47This function will load all required Vulkan entrypoints, including all extensions; you can use Vulkan from here on as usual.
48
49## Optimizing device calls
50
51If you use volk as described in the previous section, all device-related function calls, such as `vkCmdDraw`, will go through Vulkan loader dispatch code.
52This allows you to transparently support multiple VkDevice objects in the same application, but comes at a price of dispatch overhead which can be as high as 7% depending on the driver and application.
53
54To avoid this, you have one of two options:
55
561. For applications that use just one VkDevice object, load device-related Vulkan entrypoints directly from the driver with this function:
57
58```c++
59void volkLoadDevice(VkDevice device);
60```
61
622. For applications that use multiple VkDevice objects, load device-related Vulkan entrypoints into a table:
63
64```c++
65void volkLoadDeviceTable(struct VolkDeviceTable* table, VkDevice device);
66```
67
68The second option requires you to change the application code to store one `VolkDeviceTable` per `VkDevice` and call functions from this table instead.
69
70Device entrypoints are loaded using `vkGetDeviceProcAddr`; when no layers are present, this commonly results in most function pointers pointing directly at the driver functions, minimizing the call overhead. When layers are loaded, the entrypoints will point at the implementations in the first applicable layer, so this is compatible with any layers including validation layers.
71
72## CMake support
73
74If your project uses CMake, volk provides you with targets corresponding to the different use cases:
75
761. Target `volk` is a static library. Any platform defines can be passed to the compiler by setting `VOLK_STATIC_DEFINES`. Example:
77```cmake
78if (WIN32)
79   set(VOLK_STATIC_DEFINES VK_USE_PLATFORM_WIN32_KHR)
80elseif()
81   ...
82endif()
83add_subdirectory(volk)
84target_link_library(my_application PRIVATE volk)
85```
862. Target `volk_headers` is an interface target for the header-only style. Example:
87```cmake
88add_subdirectory(volk)
89target_link_library(my_application PRIVATE volk_headers)
90```
91and in the code:
92```c
93/* ...any logic setting VK_USE_PLATFORM_WIN32_KHR and friends... */
94#define VOLK_IMPLEMENTATION
95#include "volk.h"
96```
97
98The above example use `add_subdirectory` to include volk into CMake's build tree. This is a good choice if you copy the volk files into your project tree or as a git submodule.
99
100Volk also supports installation and config-file packages. Installation is disabled by default (so as to not pollute user projects with install rules), and can be disabled by passing `-DVOLK_INSTALL=ON` to CMake. Once installed, do something like `find_package(volk CONFIG REQUIRED)` in your project's CMakeLists.txt. The imported volk targets are called `volk::volk` and `volk::volk_headers`.
101
102## License
103
104This library is available to anybody free of charge, under the terms of MIT License (see LICENSE.md).
105