125 lines
5.4 KiB
Plaintext
125 lines
5.4 KiB
Plaintext
vkCreateInstance(3)
|
|
====================
|
|
|
|
Name
|
|
----
|
|
vkCreateInstance - Create a new Vulkan instance
|
|
|
|
C Specification
|
|
---------------
|
|
|
|
include::../protos/vkCreateInstance.txt[]
|
|
|
|
Parameters
|
|
----------
|
|
|
|
pname:pCreateInfo::
|
|
Pointer to instance creation structure.
|
|
|
|
pname:pInstance::
|
|
Pointer to variable which will receive the new instance handle.
|
|
|
|
Description
|
|
-----------
|
|
|
|
fname:vkCreateInstance creates a new Vulkan instance and places a handle to it in
|
|
the variable pointed to by pname:pInstance. pname:pCreateInfo is a pointer to an
|
|
instance of the slink:VkInstanceCreateInfo structure containing information about
|
|
how the instance should be created. The definition of slink:VkInstanceCreateInfo
|
|
is:
|
|
|
|
include::../structs/VkInstanceCreateInfo.txt[]
|
|
|
|
The pname:sType member of sname:VkInstanceCreateInfo should be set to ename:VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO.
|
|
The pname:pNext member of sname:VkInstanceCreateInfo is reserved for use by extensions
|
|
and should be set to code:NULL.
|
|
|
|
The pname:pApplicationInfo member, if non-code:NULL, points to an instance of the slink:VkApplicationInfo
|
|
structure containing information about the application. The expected contents of the pname:pApplicationInfo
|
|
member are documented below.
|
|
|
|
The pname:enabledLayerNameCount member of sname:VkInstanceCreateInfo specifies the number of global layers
|
|
to enable, and pname:ppEnabledLayerNames is a pointer to an array of pname:enabledLayerNameCount
|
|
code:NULL-terminated UTF-8 strings containing the names of layers
|
|
that should be enabled globally. If pname:enabledLayerNameCount is zero, then pname:ppEnabledLayerNames
|
|
is ignored and no global layers are enabled. If a layer cannot be found, the
|
|
call will not create a sname:VkInstance and will return ename:VK_ERROR_LAYER_NOT_PRESENT.
|
|
|
|
Similary, information about global extensions is specified in the pname:enabledExtensionNameCount and
|
|
pname:ppEnabledExtensionNames members. pname:enabledExtensionNameCount specifies the number of global
|
|
extensions to enable and pname:ppEnabledExtensionNames is a pointer to an array of pointers
|
|
to code:NULL-terminated UTF-8 strings containing the extension names. If an extension is provided
|
|
by a layer, both the layer and extension must be specified at
|
|
fname:vkCreateInstance time. If a extension cannot be found, the call will not
|
|
create a sname:VkInstance and will return ename:VK_ERROR_LAYER_NOT_PRESENT.
|
|
|
|
If pname:enabledExtensionNameCount is zero then no extensions are enabled and pname:ppEnabledExtensionNames
|
|
is ignored.
|
|
|
|
The definition of the slink:VkApplicationInfo structure is as follows:
|
|
|
|
include::../structs/VkApplicationInfo.txt[]
|
|
|
|
The pname:sType member of slink:VkApplicationInfo should be set to ename:VK_STRUCTURE_TYPE_APPLICATION_INFO.
|
|
The pname:pNext member of slink:VkApplicationInfo is reserved for use by extensions and should
|
|
be set to code:NULL.
|
|
|
|
pname:pApplicationName is a pointer to a code:NULL-terminated UTF-8 string containing the name of
|
|
the application. pname:applicationVersion contains an application-specific version number. It is
|
|
recommended that new versions of an existing application specify monotonically increasing
|
|
values for pname:applicationVersion.
|
|
|
|
If the application is built on a reusable engine, the name of the engine may be specified
|
|
in the NULL-terminated UTF-8 string pointed to by pname:pEngineName. pname:engineVersion
|
|
is the version of the engine used to create the application.
|
|
|
|
Finally, pname:apiVersion is the version of the Vulkan API that the application expects to
|
|
use.
|
|
|
|
Any application memory required by the instance will be allocated by calling functions
|
|
specified in the structure pointed to by ptext:pAllocCb. The definition of slink:VkAllocationCallbacks is:
|
|
|
|
include::../structs/VkAllocationCallbacks.txt[]
|
|
|
|
The slink:VkAllocationCallbacks structure contains two function pointers. pname:pfnAllocation
|
|
points to an allocation function whose protoype should be of the following
|
|
form:
|
|
|
|
[source,{basebackend@docbook:c++:cpp}]
|
|
------------------------------------------------------------------------------
|
|
typedef void* (*PFN_vkAllocationFunction)(
|
|
void* pUserData,
|
|
size_t size,
|
|
size_t alignment,
|
|
VkSystemAllocationScope allocationScope);
|
|
------------------------------------------------------------------------------
|
|
|
|
pname:pUserData is set to the value of pname:pUserData in the allocation info structure
|
|
passed to fname:vkCreateInstance. ptext:size is the size of the desired allocation,
|
|
ptext:alignment is the desired allocation, in bytes, and ptext:allocationScope represents
|
|
the intended usage of the allocation. The return value of function is a pointer
|
|
to the newly allocated memory.
|
|
|
|
The pname:pfnFree member of slink:VkAllocationCallbacks points to an instance of the
|
|
following function:
|
|
|
|
[source,{basebackend@docbook:c++:cpp}]
|
|
------------------------------------------------------------------------------
|
|
typedef void (*PFN_vkFreeFunction)(
|
|
void* pUserData,
|
|
void* pMemory);
|
|
------------------------------------------------------------------------------
|
|
|
|
Again, the pname:pUserData parameter is initialized to the value passed in the
|
|
slink:VkAllocationCallbacks structure passed to fname:vkCreateInstance. ptext:pMemory is a
|
|
pointer to the memory to be freed.
|
|
|
|
include::../validity/protos/vkCreateInstance.txt[]
|
|
|
|
See Also
|
|
--------
|
|
|
|
flink:vkDestroyInstance
|
|
|
|
include::footer.txt[]
|