Wiki Page Content


Use this function to get the names of the Vulkan instance extensions needed to create a surface with SDL_Vulkan_CreateSurface.


SDL_bool SDL_Vulkan_GetInstanceExtensions(SDL_Window* window,
                                          unsigned int* pCount,
                                          const char** pNames);

Function Parameters


A window for which the required Vulkan instance extensions should be retrieved (will be deprecated in a future release)


A pointer to an unsigned int corresponding to the number of extensions to be returned


NULL or a pointer to an array to be filled with required Vulkan instance extensions

Return Value

Returns SDL_TRUE on success, SDL_FALSE on error.

Code Examples

// Note: This sample uses C++17 features/syntax.
// Get the required extension count
unsigned int count;
if (!SDL_Vulkan_GetInstanceExtensions(window, &count, nullptr)) handle_error();

std::vector<const char*> extensions = {
    VK_EXT_DEBUG_REPORT_EXTENSION_NAME // Sample additional extension
size_t additional_extension_count = extensions.size();
extensions.resize(additional_extension_count + count);

if (!SDL_Vulkan_GetInstanceExtensions(window, &count, + additional_extension_count)) handle_error();

// Now we can make the Vulkan instance
VkInstanceCreateInfo create_info = {};
create_info.enabledExtensionCount = static_cast<uint32_t>(extensions.size());
create_info.ppEnabledExtensionNames =;

VkInstance instance;
VkResult result = vkCreateInstance(&create_info, nullptr, &instance);


If pNames is NULL, then the number of required Vulkan instance extensions is returned in pCount. Otherwise, pCount must point to a variable set to the number of elements in the pNames array, and on return the variable is overwritten with the number of names actually written to pNames. If pCount is less than the number of required extensions, at most pCount structures will be written. If pCount is smaller than the number of required extensions, SDL_FALSE will be returned instead of SDL_TRUE, to indicate that not all the required extensions were returned.

Note The window parameter is currently needed to be valid as of SDL 2.0.8, however, this parameter will likely be removed in future releases


This function is available in SDL 2.0.8

CategoryAPI, CategoryVulkan


None: SDL_Vulkan_GetInstanceExtensions (last edited 2018-09-03 04:56:46 by ninepoints)

(Page Info.)
Please include your contact information if you'd like to receive a reply.