Copyright © 2015-2018 LunarG, Inc.

Vulkan Samples

The LunarG Vulkan SDK includes a set of C++ Vulkan sample programs. These samples illustrate specific Vulkan entry points and their use in implementing graphical features.

The source code of the sample Vulkan programs is available in the samples directory of the Vulkan SDK.

Build and Run Samples

Note that you will need CMake 3.2 (or later) and Python 3 to build the samples To build and run the sample programs:

  1. Configure the sample program build system for a release build and build the samples.


    A shell script is provided to build the samples and their dependencies. Use the following command to run this script.

    $ ./

    Alternatively you can manually build the samples as described next. The Vulkan sample programs have a dependency on certain glslang components. These libraries and header files are included in the Vulkan SDK. Specifically, the Linux samples build will pull the libraries from $VULKAN_SDK/x64_64/lib/glslang and the headers from $VULKAN_SDK/source/glslang. Use the following commands to build the glslang components.

    $ pushd source/glslang
    $ mkdir build
    $ cd build
    $ cmake ..
    $ make
    $ cp SPIRV/libSPIRV.a ../../../x86_64/lib/glslang
    $ cp glslang/libglslang.a ../../../x86_64/lib/glslang
    $ cp glslang/OSDependent/Unix/libOSDependent.a ../../../x86_64/lib/glslang
    $ cp OGLCompilersDLL/libOGLCompiler.a ../../../x86_64/lib/glslang
    $ cp hlsl/libHLSL.a ../../../x86_64/lib/glslang
    $ popd

    Use the following commands to build the samples.

    $ pushd samples
    $ mkdir build
    $ cd build
    $ cmake ..
    $ make
    $ popd

    WSI Selection

    When building the samples on Linux, the Xcb windowing system is used by default.

    The environment variable SAMPLES_WSI_SELECTION can be set to build for a different windowing system. The supported options are XCB and WAYLAND.


    $ mkdir build
    $ cd build

    This can be done by either modifying the script or by building manually.


    Make sure CMake, python and MSBuild are in your PATH. The MSBuild path is included automatically when opening Developer Command Prompt for VS201x, or alternatively can be loaded in a command window by executing 'vsvars32.bat' found in \Program Files (x86)\Microsoft Visual Studio xx.0\Common7\Tools\.

    A Windows batch file build_windows_samples.bat is provided to locate the installed build tools and build the samples and their dependencies. Note: This batch file builds only 64-bit versions of the tools and samples.

    If desired to build the samples manually, do so by running the following commands:

    > mkdir build
    > cd build
    > cmake -G "Visual Studio 14 2015 Win64" ..
    > msbuild ALL_BUILD.vcxproj /p:Platform=x64 /p:Configuration=Debug /verbosity:quiet
    > msbuild ALL_BUILD.vcxproj /p:Platform=x64 /p:Configuration=Release /verbosity:quiet
    > cd ..

    within the following directories, in order:

    C:\VulkanSDK\<sdk version>\glslang
    C:\VulkanSDK\<sdk version>\spirv-tools
    C:\VulkanSDK\<sdk version>\Samples

    Alternatively you may skip the msbuild steps above, and build within the Visual Studio IDE by opening the VULKAN_SAMPLES.sln file generated by the cmake command.

    • The Debug versions of the loader and layers were built with VS 2015.
    • If you want to run the samples with the debug version of the loader and layers, you should build the samples with VS 2015.
    • Note that VS 2017 is supported. Attempting to use VS2017 with the debug loader and layers will fail on loading MSVCR140.dll.

    32-bit support

    32-bit support is currently available, but should only be considered at an Alpha level of stability. 32-bit applications and layers have only been validated to a minimal extent.

  2. Verify the build artifacts.


    $ cd build/src
    $ ls


    cd src\Release

    Notice the listed set of Vulkan sample programs. The program name identifies the Vulkan entry point or graphical feature implemented in the sample.

  3. Generate the list of samples currently available (Linux).

    $ ./

    This script displays each sample filename and a short description of the sample.

  4. Run the textured cube sample program.


    $ ./drawtexturedcube



    This program uses the appropriate Vulkan entry points to open a window and draw a textured cube.

Note: The focus of some sample programs may be to enumerate individual features of specific Vulkan entry points and may not render to the screen at all.

Examine Sample Code

The Vulkan Samples currently include samples that are both self-contained and those that use external utilities. In future releases, all samples will be self-contained, i.e. all code will be located within the sample source file itself.

A typical sample Vulkan program will, using one or more Vulkan API entry points, perform the following activities:

To find code for a specific entry point, search for that entry point name in all or specific samples.

More detailed information on programming with specific Vulkan API entry points will be provided in future SDK releases.

Provide input, feedback, or contribute a New Sample