###### (This is the documentation for SDL3, which is under heavy development and the API is changing! [SDL2](https://wiki.libsdl.org/SDL2/) is the current stable version!) # SDL_Vulkan_GetInstanceExtensions Get the Vulkan instance extensions needed for vkCreateInstance. ## Header File Defined in [](https://github.com/libsdl-org/SDL/blob/main/include/SDL3/SDL_vulkan.h) ## Syntax ```c char const * const * SDL_Vulkan_GetInstanceExtensions(Uint32 *count); ``` ## Function Parameters | | | | | -------- | --------- | ----------------------------------------------------------- | | Uint32 * | **count** | a pointer filled in with the number of extensions returned. | ## Return Value (char const * const *) Returns an array of extension name strings on success, NULL on failure; call [SDL_GetError](SDL_GetError)() for more information. ## Remarks This should be called after either calling [SDL_Vulkan_LoadLibrary](SDL_Vulkan_LoadLibrary)() or creating an [SDL_Window](SDL_Window) with the [`SDL_WINDOW_VULKAN`](SDL_WINDOW_VULKAN) flag. On return, the variable pointed to by `count` will be set to the number of elements returned, suitable for using with VkInstanceCreateInfo::enabledExtensionCount, and the returned array can be used with VkInstanceCreateInfo::ppEnabledExtensionNames, for calling Vulkan's vkCreateInstance API. You should not free the returned array; it is owned by SDL. ## Version This function is available since SDL 3.0.0. ## Code Examples ```c extern void handle_error(void); #ifndef VK_EXT_DEBUG_REPORT_EXTENSION_NAME #define VK_EXT_DEBUG_REPORT_EXTENSION_NAME "VK_EXT_debug_report" #endif Uint32 count_instance_extensions; const char * const *instance_extensions = SDL_Vulkan_GetInstanceExtensions(&count_instance_extensions); if (instance_extensions == NULL) { handle_error(); } int count_extensions = count_instance_extensions + 1; const char **extensions = SDL_malloc(count_extensions * sizeof(const char *)); extensions[0] = VK_EXT_DEBUG_REPORT_EXTENSION_NAME; SDL_memcpy(&extensions[1], instance_extensions, count_instance_extensions * sizeof(const char*)); // Now we can make the Vulkan instance VkInstanceCreateInfo create_info = {}; create_info.enabledExtensionCount = count_extensions; create_info.ppEnabledExtensionNames = extensions; VkInstance instance; VkResult result = vkCreateInstance(&create_info, NULL, &instance); SDL_free(extensions); ``` ## See Also - [SDL_Vulkan_CreateSurface](SDL_Vulkan_CreateSurface) ---- [CategoryAPI](CategoryAPI), [CategoryAPIFunction](CategoryAPIFunction), [CategoryVulkan](CategoryVulkan)