1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker * Copyright © 2022 Collabora Ltd. and Red Hat Inc.
3*61046927SAndroid Build Coastguard Worker * SPDX-License-Identifier: MIT
4*61046927SAndroid Build Coastguard Worker */
5*61046927SAndroid Build Coastguard Worker #include "nvk_instance.h"
6*61046927SAndroid Build Coastguard Worker
7*61046927SAndroid Build Coastguard Worker #include "nvk_entrypoints.h"
8*61046927SAndroid Build Coastguard Worker #include "nvk_physical_device.h"
9*61046927SAndroid Build Coastguard Worker
10*61046927SAndroid Build Coastguard Worker #include "vulkan/wsi/wsi_common.h"
11*61046927SAndroid Build Coastguard Worker
12*61046927SAndroid Build Coastguard Worker #include "util/build_id.h"
13*61046927SAndroid Build Coastguard Worker #include "util/driconf.h"
14*61046927SAndroid Build Coastguard Worker #include "util/mesa-sha1.h"
15*61046927SAndroid Build Coastguard Worker #include "util/u_debug.h"
16*61046927SAndroid Build Coastguard Worker
17*61046927SAndroid Build Coastguard Worker VKAPI_ATTR VkResult VKAPI_CALL
nvk_EnumerateInstanceVersion(uint32_t * pApiVersion)18*61046927SAndroid Build Coastguard Worker nvk_EnumerateInstanceVersion(uint32_t *pApiVersion)
19*61046927SAndroid Build Coastguard Worker {
20*61046927SAndroid Build Coastguard Worker uint32_t version_override = vk_get_version_override();
21*61046927SAndroid Build Coastguard Worker *pApiVersion = version_override ? version_override :
22*61046927SAndroid Build Coastguard Worker VK_MAKE_VERSION(1, 3, VK_HEADER_VERSION);
23*61046927SAndroid Build Coastguard Worker
24*61046927SAndroid Build Coastguard Worker return VK_SUCCESS;
25*61046927SAndroid Build Coastguard Worker }
26*61046927SAndroid Build Coastguard Worker
27*61046927SAndroid Build Coastguard Worker static const struct vk_instance_extension_table instance_extensions = {
28*61046927SAndroid Build Coastguard Worker #ifdef NVK_USE_WSI_PLATFORM
29*61046927SAndroid Build Coastguard Worker .KHR_get_surface_capabilities2 = true,
30*61046927SAndroid Build Coastguard Worker .KHR_surface = true,
31*61046927SAndroid Build Coastguard Worker .KHR_surface_protected_capabilities = true,
32*61046927SAndroid Build Coastguard Worker .EXT_surface_maintenance1 = true,
33*61046927SAndroid Build Coastguard Worker .EXT_swapchain_colorspace = true,
34*61046927SAndroid Build Coastguard Worker #endif
35*61046927SAndroid Build Coastguard Worker #ifdef VK_USE_PLATFORM_WAYLAND_KHR
36*61046927SAndroid Build Coastguard Worker .KHR_wayland_surface = true,
37*61046927SAndroid Build Coastguard Worker #endif
38*61046927SAndroid Build Coastguard Worker #ifdef VK_USE_PLATFORM_XCB_KHR
39*61046927SAndroid Build Coastguard Worker .KHR_xcb_surface = true,
40*61046927SAndroid Build Coastguard Worker #endif
41*61046927SAndroid Build Coastguard Worker #ifdef VK_USE_PLATFORM_XLIB_KHR
42*61046927SAndroid Build Coastguard Worker .KHR_xlib_surface = true,
43*61046927SAndroid Build Coastguard Worker #endif
44*61046927SAndroid Build Coastguard Worker #ifdef VK_USE_PLATFORM_XLIB_XRANDR_EXT
45*61046927SAndroid Build Coastguard Worker .EXT_acquire_xlib_display = true,
46*61046927SAndroid Build Coastguard Worker #endif
47*61046927SAndroid Build Coastguard Worker #ifdef VK_USE_PLATFORM_DISPLAY_KHR
48*61046927SAndroid Build Coastguard Worker .KHR_display = true,
49*61046927SAndroid Build Coastguard Worker .KHR_get_display_properties2 = true,
50*61046927SAndroid Build Coastguard Worker .EXT_direct_mode_display = true,
51*61046927SAndroid Build Coastguard Worker .EXT_display_surface_counter = true,
52*61046927SAndroid Build Coastguard Worker .EXT_acquire_drm_display = true,
53*61046927SAndroid Build Coastguard Worker #endif
54*61046927SAndroid Build Coastguard Worker #ifndef VK_USE_PLATFORM_WIN32_KHR
55*61046927SAndroid Build Coastguard Worker .EXT_headless_surface = true,
56*61046927SAndroid Build Coastguard Worker #endif
57*61046927SAndroid Build Coastguard Worker .KHR_device_group_creation = true,
58*61046927SAndroid Build Coastguard Worker .KHR_external_fence_capabilities = true,
59*61046927SAndroid Build Coastguard Worker .KHR_external_memory_capabilities = true,
60*61046927SAndroid Build Coastguard Worker .KHR_external_semaphore_capabilities = true,
61*61046927SAndroid Build Coastguard Worker .KHR_get_physical_device_properties2 = true,
62*61046927SAndroid Build Coastguard Worker .EXT_debug_report = true,
63*61046927SAndroid Build Coastguard Worker .EXT_debug_utils = true,
64*61046927SAndroid Build Coastguard Worker };
65*61046927SAndroid Build Coastguard Worker
66*61046927SAndroid Build Coastguard Worker VKAPI_ATTR VkResult VKAPI_CALL
nvk_EnumerateInstanceExtensionProperties(const char * pLayerName,uint32_t * pPropertyCount,VkExtensionProperties * pProperties)67*61046927SAndroid Build Coastguard Worker nvk_EnumerateInstanceExtensionProperties(const char *pLayerName,
68*61046927SAndroid Build Coastguard Worker uint32_t *pPropertyCount,
69*61046927SAndroid Build Coastguard Worker VkExtensionProperties *pProperties)
70*61046927SAndroid Build Coastguard Worker {
71*61046927SAndroid Build Coastguard Worker if (pLayerName)
72*61046927SAndroid Build Coastguard Worker return vk_error(NULL, VK_ERROR_LAYER_NOT_PRESENT);
73*61046927SAndroid Build Coastguard Worker
74*61046927SAndroid Build Coastguard Worker return vk_enumerate_instance_extension_properties(
75*61046927SAndroid Build Coastguard Worker &instance_extensions, pPropertyCount, pProperties);
76*61046927SAndroid Build Coastguard Worker }
77*61046927SAndroid Build Coastguard Worker
78*61046927SAndroid Build Coastguard Worker static void
nvk_init_debug_flags(struct nvk_instance * instance)79*61046927SAndroid Build Coastguard Worker nvk_init_debug_flags(struct nvk_instance *instance)
80*61046927SAndroid Build Coastguard Worker {
81*61046927SAndroid Build Coastguard Worker const struct debug_control flags[] = {
82*61046927SAndroid Build Coastguard Worker { "push_dump", NVK_DEBUG_PUSH_DUMP },
83*61046927SAndroid Build Coastguard Worker { "push", NVK_DEBUG_PUSH_DUMP },
84*61046927SAndroid Build Coastguard Worker { "push_sync", NVK_DEBUG_PUSH_SYNC },
85*61046927SAndroid Build Coastguard Worker { "zero_memory", NVK_DEBUG_ZERO_MEMORY },
86*61046927SAndroid Build Coastguard Worker { "vm", NVK_DEBUG_VM },
87*61046927SAndroid Build Coastguard Worker { "no_cbuf", NVK_DEBUG_NO_CBUF },
88*61046927SAndroid Build Coastguard Worker { "edb_bview", NVK_DEBUG_FORCE_EDB_BVIEW },
89*61046927SAndroid Build Coastguard Worker { NULL, 0 },
90*61046927SAndroid Build Coastguard Worker };
91*61046927SAndroid Build Coastguard Worker
92*61046927SAndroid Build Coastguard Worker instance->debug_flags = parse_debug_string(getenv("NVK_DEBUG"), flags);
93*61046927SAndroid Build Coastguard Worker }
94*61046927SAndroid Build Coastguard Worker
95*61046927SAndroid Build Coastguard Worker static const driOptionDescription nvk_dri_options[] = {
96*61046927SAndroid Build Coastguard Worker DRI_CONF_SECTION_PERFORMANCE
97*61046927SAndroid Build Coastguard Worker DRI_CONF_ADAPTIVE_SYNC(true)
98*61046927SAndroid Build Coastguard Worker DRI_CONF_VK_X11_OVERRIDE_MIN_IMAGE_COUNT(0)
99*61046927SAndroid Build Coastguard Worker DRI_CONF_VK_X11_STRICT_IMAGE_COUNT(false)
100*61046927SAndroid Build Coastguard Worker DRI_CONF_VK_X11_ENSURE_MIN_IMAGE_COUNT(false)
101*61046927SAndroid Build Coastguard Worker DRI_CONF_VK_KHR_PRESENT_WAIT(false)
102*61046927SAndroid Build Coastguard Worker DRI_CONF_VK_XWAYLAND_WAIT_READY(false)
103*61046927SAndroid Build Coastguard Worker DRI_CONF_SECTION_END
104*61046927SAndroid Build Coastguard Worker
105*61046927SAndroid Build Coastguard Worker DRI_CONF_SECTION_DEBUG
106*61046927SAndroid Build Coastguard Worker DRI_CONF_FORCE_VK_VENDOR()
107*61046927SAndroid Build Coastguard Worker DRI_CONF_VK_WSI_FORCE_SWAPCHAIN_TO_CURRENT_EXTENT(false)
108*61046927SAndroid Build Coastguard Worker DRI_CONF_VK_X11_IGNORE_SUBOPTIMAL(false)
109*61046927SAndroid Build Coastguard Worker DRI_CONF_SECTION_END
110*61046927SAndroid Build Coastguard Worker };
111*61046927SAndroid Build Coastguard Worker
112*61046927SAndroid Build Coastguard Worker static void
nvk_init_dri_options(struct nvk_instance * instance)113*61046927SAndroid Build Coastguard Worker nvk_init_dri_options(struct nvk_instance *instance)
114*61046927SAndroid Build Coastguard Worker {
115*61046927SAndroid Build Coastguard Worker driParseOptionInfo(&instance->available_dri_options, nvk_dri_options, ARRAY_SIZE(nvk_dri_options));
116*61046927SAndroid Build Coastguard Worker driParseConfigFiles(&instance->dri_options, &instance->available_dri_options, 0, "nvk", NULL, NULL,
117*61046927SAndroid Build Coastguard Worker instance->vk.app_info.app_name, instance->vk.app_info.app_version,
118*61046927SAndroid Build Coastguard Worker instance->vk.app_info.engine_name, instance->vk.app_info.engine_version);
119*61046927SAndroid Build Coastguard Worker
120*61046927SAndroid Build Coastguard Worker instance->force_vk_vendor =
121*61046927SAndroid Build Coastguard Worker driQueryOptioni(&instance->dri_options, "force_vk_vendor");
122*61046927SAndroid Build Coastguard Worker }
123*61046927SAndroid Build Coastguard Worker
124*61046927SAndroid Build Coastguard Worker VKAPI_ATTR VkResult VKAPI_CALL
nvk_CreateInstance(const VkInstanceCreateInfo * pCreateInfo,const VkAllocationCallbacks * pAllocator,VkInstance * pInstance)125*61046927SAndroid Build Coastguard Worker nvk_CreateInstance(const VkInstanceCreateInfo *pCreateInfo,
126*61046927SAndroid Build Coastguard Worker const VkAllocationCallbacks *pAllocator,
127*61046927SAndroid Build Coastguard Worker VkInstance *pInstance)
128*61046927SAndroid Build Coastguard Worker {
129*61046927SAndroid Build Coastguard Worker struct nvk_instance *instance;
130*61046927SAndroid Build Coastguard Worker VkResult result;
131*61046927SAndroid Build Coastguard Worker
132*61046927SAndroid Build Coastguard Worker if (pAllocator == NULL)
133*61046927SAndroid Build Coastguard Worker pAllocator = vk_default_allocator();
134*61046927SAndroid Build Coastguard Worker
135*61046927SAndroid Build Coastguard Worker instance = vk_alloc(pAllocator, sizeof(*instance), 8,
136*61046927SAndroid Build Coastguard Worker VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE);
137*61046927SAndroid Build Coastguard Worker if (!instance)
138*61046927SAndroid Build Coastguard Worker return vk_error(NULL, VK_ERROR_OUT_OF_HOST_MEMORY);
139*61046927SAndroid Build Coastguard Worker
140*61046927SAndroid Build Coastguard Worker struct vk_instance_dispatch_table dispatch_table;
141*61046927SAndroid Build Coastguard Worker vk_instance_dispatch_table_from_entrypoints(&dispatch_table,
142*61046927SAndroid Build Coastguard Worker &nvk_instance_entrypoints,
143*61046927SAndroid Build Coastguard Worker true);
144*61046927SAndroid Build Coastguard Worker vk_instance_dispatch_table_from_entrypoints(&dispatch_table,
145*61046927SAndroid Build Coastguard Worker &wsi_instance_entrypoints,
146*61046927SAndroid Build Coastguard Worker false);
147*61046927SAndroid Build Coastguard Worker
148*61046927SAndroid Build Coastguard Worker result = vk_instance_init(&instance->vk, &instance_extensions,
149*61046927SAndroid Build Coastguard Worker &dispatch_table, pCreateInfo, pAllocator);
150*61046927SAndroid Build Coastguard Worker if (result != VK_SUCCESS)
151*61046927SAndroid Build Coastguard Worker goto fail_alloc;
152*61046927SAndroid Build Coastguard Worker
153*61046927SAndroid Build Coastguard Worker nvk_init_debug_flags(instance);
154*61046927SAndroid Build Coastguard Worker nvk_init_dri_options(instance);
155*61046927SAndroid Build Coastguard Worker
156*61046927SAndroid Build Coastguard Worker instance->vk.physical_devices.try_create_for_drm =
157*61046927SAndroid Build Coastguard Worker nvk_create_drm_physical_device;
158*61046927SAndroid Build Coastguard Worker instance->vk.physical_devices.destroy = nvk_physical_device_destroy;
159*61046927SAndroid Build Coastguard Worker
160*61046927SAndroid Build Coastguard Worker const struct build_id_note *note =
161*61046927SAndroid Build Coastguard Worker build_id_find_nhdr_for_addr(nvk_CreateInstance);
162*61046927SAndroid Build Coastguard Worker if (!note) {
163*61046927SAndroid Build Coastguard Worker result = vk_errorf(NULL, VK_ERROR_INITIALIZATION_FAILED,
164*61046927SAndroid Build Coastguard Worker "Failed to find build-id");
165*61046927SAndroid Build Coastguard Worker goto fail_init;
166*61046927SAndroid Build Coastguard Worker }
167*61046927SAndroid Build Coastguard Worker
168*61046927SAndroid Build Coastguard Worker unsigned build_id_len = build_id_length(note);
169*61046927SAndroid Build Coastguard Worker if (build_id_len < SHA1_DIGEST_LENGTH) {
170*61046927SAndroid Build Coastguard Worker result = vk_errorf(NULL, VK_ERROR_INITIALIZATION_FAILED,
171*61046927SAndroid Build Coastguard Worker "build-id too short. It needs to be a SHA");
172*61046927SAndroid Build Coastguard Worker goto fail_init;
173*61046927SAndroid Build Coastguard Worker }
174*61046927SAndroid Build Coastguard Worker
175*61046927SAndroid Build Coastguard Worker STATIC_ASSERT(sizeof(instance->driver_build_sha) == SHA1_DIGEST_LENGTH);
176*61046927SAndroid Build Coastguard Worker memcpy(instance->driver_build_sha, build_id_data(note), SHA1_DIGEST_LENGTH);
177*61046927SAndroid Build Coastguard Worker
178*61046927SAndroid Build Coastguard Worker *pInstance = nvk_instance_to_handle(instance);
179*61046927SAndroid Build Coastguard Worker return VK_SUCCESS;
180*61046927SAndroid Build Coastguard Worker
181*61046927SAndroid Build Coastguard Worker fail_init:
182*61046927SAndroid Build Coastguard Worker vk_instance_finish(&instance->vk);
183*61046927SAndroid Build Coastguard Worker fail_alloc:
184*61046927SAndroid Build Coastguard Worker vk_free(pAllocator, instance);
185*61046927SAndroid Build Coastguard Worker
186*61046927SAndroid Build Coastguard Worker return result;
187*61046927SAndroid Build Coastguard Worker }
188*61046927SAndroid Build Coastguard Worker
189*61046927SAndroid Build Coastguard Worker VKAPI_ATTR void VKAPI_CALL
nvk_DestroyInstance(VkInstance _instance,const VkAllocationCallbacks * pAllocator)190*61046927SAndroid Build Coastguard Worker nvk_DestroyInstance(VkInstance _instance,
191*61046927SAndroid Build Coastguard Worker const VkAllocationCallbacks *pAllocator)
192*61046927SAndroid Build Coastguard Worker {
193*61046927SAndroid Build Coastguard Worker VK_FROM_HANDLE(nvk_instance, instance, _instance);
194*61046927SAndroid Build Coastguard Worker
195*61046927SAndroid Build Coastguard Worker if (!instance)
196*61046927SAndroid Build Coastguard Worker return;
197*61046927SAndroid Build Coastguard Worker
198*61046927SAndroid Build Coastguard Worker driDestroyOptionCache(&instance->dri_options);
199*61046927SAndroid Build Coastguard Worker driDestroyOptionInfo(&instance->available_dri_options);
200*61046927SAndroid Build Coastguard Worker
201*61046927SAndroid Build Coastguard Worker vk_instance_finish(&instance->vk);
202*61046927SAndroid Build Coastguard Worker vk_free(&instance->vk.alloc, instance);
203*61046927SAndroid Build Coastguard Worker }
204*61046927SAndroid Build Coastguard Worker
205*61046927SAndroid Build Coastguard Worker VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL
nvk_GetInstanceProcAddr(VkInstance _instance,const char * pName)206*61046927SAndroid Build Coastguard Worker nvk_GetInstanceProcAddr(VkInstance _instance, const char *pName)
207*61046927SAndroid Build Coastguard Worker {
208*61046927SAndroid Build Coastguard Worker VK_FROM_HANDLE(nvk_instance, instance, _instance);
209*61046927SAndroid Build Coastguard Worker return vk_instance_get_proc_addr(&instance->vk,
210*61046927SAndroid Build Coastguard Worker &nvk_instance_entrypoints,
211*61046927SAndroid Build Coastguard Worker pName);
212*61046927SAndroid Build Coastguard Worker }
213*61046927SAndroid Build Coastguard Worker
214*61046927SAndroid Build Coastguard Worker PUBLIC VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL
vk_icdGetInstanceProcAddr(VkInstance instance,const char * pName)215*61046927SAndroid Build Coastguard Worker vk_icdGetInstanceProcAddr(VkInstance instance, const char *pName)
216*61046927SAndroid Build Coastguard Worker {
217*61046927SAndroid Build Coastguard Worker return nvk_GetInstanceProcAddr(instance, pName);
218*61046927SAndroid Build Coastguard Worker }
219