• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright 2015 Google Inc.
3  *
4  * Use of this source code is governed by a BSD-style license that can be
5  * found in the LICENSE file.
6  */
7 
8 #include "include/gpu/vk/GrVkBackendContext.h"
9 #include "include/gpu/vk/GrVkExtensions.h"
10 #include "src/gpu/vk/GrVkInterface.h"
11 #include "src/gpu/vk/GrVkUtil.h"
12 
13 #define ACQUIRE_PROC(name, instance, device) \
14     fFunctions.f##name = reinterpret_cast<PFN_vk##name>(getProc("vk" #name, instance, device))
15 
16 #define ACQUIRE_PROC_SUFFIX(name, suffix, instance, device) \
17     fFunctions.f##name =                                    \
18             reinterpret_cast<PFN_vk##name##suffix>(getProc("vk" #name #suffix, instance, device))
19 
GrVkInterface(GrVkGetProc getProc,VkInstance instance,VkDevice device,uint32_t instanceVersion,uint32_t physicalDeviceVersion,const GrVkExtensions * extensions)20 GrVkInterface::GrVkInterface(GrVkGetProc getProc,
21                              VkInstance instance,
22                              VkDevice device,
23                              uint32_t instanceVersion,
24                              uint32_t physicalDeviceVersion,
25                              const GrVkExtensions* extensions) {
26     if (getProc == nullptr) {
27         return;
28     }
29     // Global/Loader Procs.
30     ACQUIRE_PROC(CreateInstance, VK_NULL_HANDLE, VK_NULL_HANDLE);
31     ACQUIRE_PROC(EnumerateInstanceExtensionProperties, VK_NULL_HANDLE, VK_NULL_HANDLE);
32     ACQUIRE_PROC(EnumerateInstanceLayerProperties, VK_NULL_HANDLE, VK_NULL_HANDLE);
33 
34     // Instance Procs.
35     ACQUIRE_PROC(EnumeratePhysicalDevices, instance, VK_NULL_HANDLE);
36     ACQUIRE_PROC(GetPhysicalDeviceFeatures, instance, VK_NULL_HANDLE);
37     ACQUIRE_PROC(GetPhysicalDeviceFormatProperties, instance, VK_NULL_HANDLE);
38     ACQUIRE_PROC(GetPhysicalDeviceImageFormatProperties, instance, VK_NULL_HANDLE);
39     ACQUIRE_PROC(GetPhysicalDeviceProperties, instance, VK_NULL_HANDLE);
40     ACQUIRE_PROC(GetPhysicalDeviceQueueFamilyProperties, instance, VK_NULL_HANDLE);
41     ACQUIRE_PROC(GetPhysicalDeviceMemoryProperties, instance, VK_NULL_HANDLE);
42     ACQUIRE_PROC(GetPhysicalDeviceSparseImageFormatProperties, instance, VK_NULL_HANDLE);
43     ACQUIRE_PROC(DestroyInstance, instance, VK_NULL_HANDLE);
44     ACQUIRE_PROC(CreateDevice, instance, VK_NULL_HANDLE);
45     ACQUIRE_PROC(DestroyDevice, instance, VK_NULL_HANDLE);
46     ACQUIRE_PROC(EnumerateDeviceExtensionProperties, instance, VK_NULL_HANDLE);
47     ACQUIRE_PROC(EnumerateDeviceLayerProperties, instance, VK_NULL_HANDLE);
48 
49     // Device Procs.
50     ACQUIRE_PROC(GetDeviceQueue, VK_NULL_HANDLE, device);
51     ACQUIRE_PROC(QueueSubmit, VK_NULL_HANDLE, device);
52     ACQUIRE_PROC(QueueWaitIdle, VK_NULL_HANDLE, device);
53     ACQUIRE_PROC(DeviceWaitIdle, VK_NULL_HANDLE, device);
54     ACQUIRE_PROC(AllocateMemory, VK_NULL_HANDLE, device);
55     ACQUIRE_PROC(FreeMemory, VK_NULL_HANDLE, device);
56     ACQUIRE_PROC(MapMemory, VK_NULL_HANDLE, device);
57     ACQUIRE_PROC(UnmapMemory, VK_NULL_HANDLE, device);
58     ACQUIRE_PROC(FlushMappedMemoryRanges, VK_NULL_HANDLE, device);
59     ACQUIRE_PROC(InvalidateMappedMemoryRanges, VK_NULL_HANDLE, device);
60     ACQUIRE_PROC(GetDeviceMemoryCommitment, VK_NULL_HANDLE, device);
61     ACQUIRE_PROC(BindBufferMemory, VK_NULL_HANDLE, device);
62     ACQUIRE_PROC(BindImageMemory, VK_NULL_HANDLE, device);
63     ACQUIRE_PROC(GetBufferMemoryRequirements, VK_NULL_HANDLE, device);
64     ACQUIRE_PROC(GetImageMemoryRequirements, VK_NULL_HANDLE, device);
65     ACQUIRE_PROC(GetImageSparseMemoryRequirements, VK_NULL_HANDLE, device);
66     ACQUIRE_PROC(QueueBindSparse, VK_NULL_HANDLE, device);
67     ACQUIRE_PROC(CreateFence, VK_NULL_HANDLE, device);
68     ACQUIRE_PROC(DestroyFence, VK_NULL_HANDLE, device);
69     ACQUIRE_PROC(ResetFences, VK_NULL_HANDLE, device);
70     ACQUIRE_PROC(GetFenceStatus, VK_NULL_HANDLE, device);
71     ACQUIRE_PROC(WaitForFences, VK_NULL_HANDLE, device);
72     ACQUIRE_PROC(CreateSemaphore, VK_NULL_HANDLE, device);
73     ACQUIRE_PROC(DestroySemaphore, VK_NULL_HANDLE, device);
74     ACQUIRE_PROC(CreateEvent, VK_NULL_HANDLE, device);
75     ACQUIRE_PROC(DestroyEvent, VK_NULL_HANDLE, device);
76     ACQUIRE_PROC(GetEventStatus, VK_NULL_HANDLE, device);
77     ACQUIRE_PROC(SetEvent, VK_NULL_HANDLE, device);
78     ACQUIRE_PROC(ResetEvent, VK_NULL_HANDLE, device);
79     ACQUIRE_PROC(CreateQueryPool, VK_NULL_HANDLE, device);
80     ACQUIRE_PROC(DestroyQueryPool, VK_NULL_HANDLE, device);
81     ACQUIRE_PROC(GetQueryPoolResults, VK_NULL_HANDLE, device);
82     ACQUIRE_PROC(CreateBuffer, VK_NULL_HANDLE, device);
83     ACQUIRE_PROC(DestroyBuffer, VK_NULL_HANDLE, device);
84     ACQUIRE_PROC(CreateBufferView, VK_NULL_HANDLE, device);
85     ACQUIRE_PROC(DestroyBufferView, VK_NULL_HANDLE, device);
86     ACQUIRE_PROC(CreateImage, VK_NULL_HANDLE, device);
87     ACQUIRE_PROC(DestroyImage, VK_NULL_HANDLE, device);
88     ACQUIRE_PROC(GetImageSubresourceLayout, VK_NULL_HANDLE, device);
89     ACQUIRE_PROC(CreateImageView, VK_NULL_HANDLE, device);
90     ACQUIRE_PROC(DestroyImageView, VK_NULL_HANDLE, device);
91     ACQUIRE_PROC(CreateShaderModule, VK_NULL_HANDLE, device);
92     ACQUIRE_PROC(DestroyShaderModule, VK_NULL_HANDLE, device);
93     ACQUIRE_PROC(CreatePipelineCache, VK_NULL_HANDLE, device);
94     ACQUIRE_PROC(DestroyPipelineCache, VK_NULL_HANDLE, device);
95     ACQUIRE_PROC(GetPipelineCacheData, VK_NULL_HANDLE, device);
96     ACQUIRE_PROC(MergePipelineCaches, VK_NULL_HANDLE, device);
97     ACQUIRE_PROC(CreateGraphicsPipelines, VK_NULL_HANDLE, device);
98     ACQUIRE_PROC(CreateComputePipelines, VK_NULL_HANDLE, device);
99     ACQUIRE_PROC(DestroyPipeline, VK_NULL_HANDLE, device);
100     ACQUIRE_PROC(CreatePipelineLayout, VK_NULL_HANDLE, device);
101     ACQUIRE_PROC(DestroyPipelineLayout, VK_NULL_HANDLE, device);
102     ACQUIRE_PROC(CreateSampler, VK_NULL_HANDLE, device);
103     ACQUIRE_PROC(DestroySampler, VK_NULL_HANDLE, device);
104     ACQUIRE_PROC(CreateDescriptorSetLayout, VK_NULL_HANDLE, device);
105     ACQUIRE_PROC(DestroyDescriptorSetLayout, VK_NULL_HANDLE, device);
106     ACQUIRE_PROC(CreateDescriptorPool, VK_NULL_HANDLE, device);
107     ACQUIRE_PROC(DestroyDescriptorPool, VK_NULL_HANDLE, device);
108     ACQUIRE_PROC(ResetDescriptorPool, VK_NULL_HANDLE, device);
109     ACQUIRE_PROC(AllocateDescriptorSets, VK_NULL_HANDLE, device);
110     ACQUIRE_PROC(FreeDescriptorSets, VK_NULL_HANDLE, device);
111     ACQUIRE_PROC(UpdateDescriptorSets, VK_NULL_HANDLE, device);
112     ACQUIRE_PROC(CreateFramebuffer, VK_NULL_HANDLE, device);
113     ACQUIRE_PROC(DestroyFramebuffer, VK_NULL_HANDLE, device);
114     ACQUIRE_PROC(CreateRenderPass, VK_NULL_HANDLE, device);
115     ACQUIRE_PROC(DestroyRenderPass, VK_NULL_HANDLE, device);
116     ACQUIRE_PROC(GetRenderAreaGranularity, VK_NULL_HANDLE, device);
117     ACQUIRE_PROC(CreateCommandPool, VK_NULL_HANDLE, device);
118     ACQUIRE_PROC(DestroyCommandPool, VK_NULL_HANDLE, device);
119     ACQUIRE_PROC(ResetCommandPool, VK_NULL_HANDLE, device);
120     ACQUIRE_PROC(AllocateCommandBuffers, VK_NULL_HANDLE, device);
121     ACQUIRE_PROC(FreeCommandBuffers, VK_NULL_HANDLE, device);
122     ACQUIRE_PROC(BeginCommandBuffer, VK_NULL_HANDLE, device);
123     ACQUIRE_PROC(EndCommandBuffer, VK_NULL_HANDLE, device);
124     ACQUIRE_PROC(ResetCommandBuffer, VK_NULL_HANDLE, device);
125     ACQUIRE_PROC(CmdBindPipeline, VK_NULL_HANDLE, device);
126     ACQUIRE_PROC(CmdSetViewport, VK_NULL_HANDLE, device);
127     ACQUIRE_PROC(CmdSetScissor, VK_NULL_HANDLE, device);
128     ACQUIRE_PROC(CmdSetLineWidth, VK_NULL_HANDLE, device);
129     ACQUIRE_PROC(CmdSetDepthBias, VK_NULL_HANDLE, device);
130     ACQUIRE_PROC(CmdSetBlendConstants, VK_NULL_HANDLE, device);
131     ACQUIRE_PROC(CmdSetDepthBounds, VK_NULL_HANDLE, device);
132     ACQUIRE_PROC(CmdSetStencilCompareMask, VK_NULL_HANDLE, device);
133     ACQUIRE_PROC(CmdSetStencilWriteMask, VK_NULL_HANDLE, device);
134     ACQUIRE_PROC(CmdSetStencilReference, VK_NULL_HANDLE, device);
135     ACQUIRE_PROC(CmdBindDescriptorSets, VK_NULL_HANDLE, device);
136     ACQUIRE_PROC(CmdBindIndexBuffer, VK_NULL_HANDLE, device);
137     ACQUIRE_PROC(CmdBindVertexBuffers, VK_NULL_HANDLE, device);
138     ACQUIRE_PROC(CmdDraw, VK_NULL_HANDLE, device);
139     ACQUIRE_PROC(CmdDrawIndexed, VK_NULL_HANDLE, device);
140     ACQUIRE_PROC(CmdDrawIndirect, VK_NULL_HANDLE, device);
141     ACQUIRE_PROC(CmdDrawIndexedIndirect, VK_NULL_HANDLE, device);
142     ACQUIRE_PROC(CmdDispatch, VK_NULL_HANDLE, device);
143     ACQUIRE_PROC(CmdDispatchIndirect, VK_NULL_HANDLE, device);
144     ACQUIRE_PROC(CmdCopyBuffer, VK_NULL_HANDLE, device);
145     ACQUIRE_PROC(CmdCopyImage, VK_NULL_HANDLE, device);
146     ACQUIRE_PROC(CmdBlitImage, VK_NULL_HANDLE, device);
147     ACQUIRE_PROC(CmdCopyBufferToImage, VK_NULL_HANDLE, device);
148     ACQUIRE_PROC(CmdCopyImageToBuffer, VK_NULL_HANDLE, device);
149     ACQUIRE_PROC(CmdUpdateBuffer, VK_NULL_HANDLE, device);
150     ACQUIRE_PROC(CmdFillBuffer, VK_NULL_HANDLE, device);
151     ACQUIRE_PROC(CmdClearColorImage, VK_NULL_HANDLE, device);
152     ACQUIRE_PROC(CmdClearDepthStencilImage, VK_NULL_HANDLE, device);
153     ACQUIRE_PROC(CmdClearAttachments, VK_NULL_HANDLE, device);
154     ACQUIRE_PROC(CmdResolveImage, VK_NULL_HANDLE, device);
155     ACQUIRE_PROC(CmdSetEvent, VK_NULL_HANDLE, device);
156     ACQUIRE_PROC(CmdResetEvent, VK_NULL_HANDLE, device);
157     ACQUIRE_PROC(CmdWaitEvents, VK_NULL_HANDLE, device);
158     ACQUIRE_PROC(CmdPipelineBarrier, VK_NULL_HANDLE, device);
159     ACQUIRE_PROC(CmdBeginQuery, VK_NULL_HANDLE, device);
160     ACQUIRE_PROC(CmdEndQuery, VK_NULL_HANDLE, device);
161     ACQUIRE_PROC(CmdResetQueryPool, VK_NULL_HANDLE, device);
162     ACQUIRE_PROC(CmdWriteTimestamp, VK_NULL_HANDLE, device);
163     ACQUIRE_PROC(CmdCopyQueryPoolResults, VK_NULL_HANDLE, device);
164     ACQUIRE_PROC(CmdPushConstants, VK_NULL_HANDLE, device);
165     ACQUIRE_PROC(CmdBeginRenderPass, VK_NULL_HANDLE, device);
166     ACQUIRE_PROC(CmdNextSubpass, VK_NULL_HANDLE, device);
167     ACQUIRE_PROC(CmdEndRenderPass, VK_NULL_HANDLE, device);
168     ACQUIRE_PROC(CmdExecuteCommands, VK_NULL_HANDLE, device);
169     ACQUIRE_PROC(CmdDrawBlurImageHUAWEI, VK_NULL_HANDLE, device);
170     ACQUIRE_PROC(GetBlurImageSizeHUAWEI, VK_NULL_HANDLE, device);
171     ACQUIRE_PROC(GetDeviceFaultInfoEXT, VK_NULL_HANDLE, device);
172 #ifdef SUPPORT_OPAQUE_OPTIMIZATION
173     ACQUIRE_PROC(CmdSetOpaqueRegionHUAWEI, VK_NULL_HANDLE, device);
174 #endif
175 
176     // Functions for VK_KHR_get_physical_device_properties2
177     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0)) {
178         ACQUIRE_PROC(GetPhysicalDeviceFeatures2, instance, VK_NULL_HANDLE);
179         ACQUIRE_PROC(GetPhysicalDeviceProperties2, instance, VK_NULL_HANDLE);
180         ACQUIRE_PROC(GetPhysicalDeviceFormatProperties2, instance, VK_NULL_HANDLE);
181         ACQUIRE_PROC(GetPhysicalDeviceImageFormatProperties2, instance, VK_NULL_HANDLE);
182         ACQUIRE_PROC(GetPhysicalDeviceQueueFamilyProperties2, instance, VK_NULL_HANDLE);
183         ACQUIRE_PROC(GetPhysicalDeviceMemoryProperties2, instance, VK_NULL_HANDLE);
184         ACQUIRE_PROC(GetPhysicalDeviceSparseImageFormatProperties2, instance, VK_NULL_HANDLE);
185     } else if (extensions->hasExtension(VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_EXTENSION_NAME,
186                                         1)) {
187         ACQUIRE_PROC_SUFFIX(GetPhysicalDeviceFeatures2, KHR, instance, VK_NULL_HANDLE);
188         ACQUIRE_PROC_SUFFIX(GetPhysicalDeviceProperties2, KHR, instance, VK_NULL_HANDLE);
189         ACQUIRE_PROC_SUFFIX(GetPhysicalDeviceFormatProperties2, KHR, instance, VK_NULL_HANDLE);
190         ACQUIRE_PROC_SUFFIX(GetPhysicalDeviceImageFormatProperties2, KHR, instance, VK_NULL_HANDLE);
191         ACQUIRE_PROC_SUFFIX(GetPhysicalDeviceQueueFamilyProperties2, KHR, instance, VK_NULL_HANDLE);
192         ACQUIRE_PROC_SUFFIX(GetPhysicalDeviceMemoryProperties2, KHR, instance, VK_NULL_HANDLE);
193         ACQUIRE_PROC_SUFFIX(GetPhysicalDeviceSparseImageFormatProperties2, KHR, instance,
194                             VK_NULL_HANDLE);
195     }
196 
197     // Functions for VK_KHR_get_memory_requirements2
198     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0)) {
199         ACQUIRE_PROC(GetImageMemoryRequirements2, VK_NULL_HANDLE, device);
200         ACQUIRE_PROC(GetBufferMemoryRequirements2, VK_NULL_HANDLE, device);
201         ACQUIRE_PROC(GetImageSparseMemoryRequirements2, VK_NULL_HANDLE, device);
202     } else if (extensions->hasExtension(VK_KHR_GET_MEMORY_REQUIREMENTS_2_EXTENSION_NAME, 1)) {
203         ACQUIRE_PROC_SUFFIX(GetImageMemoryRequirements2, KHR, VK_NULL_HANDLE, device);
204         ACQUIRE_PROC_SUFFIX(GetBufferMemoryRequirements2, KHR, VK_NULL_HANDLE, device);
205         ACQUIRE_PROC_SUFFIX(GetImageSparseMemoryRequirements2, KHR, VK_NULL_HANDLE, device);
206     }
207 
208     // Functions for VK_KHR_bind_memory2
209     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0)) {
210         ACQUIRE_PROC(BindBufferMemory2, VK_NULL_HANDLE, device);
211         ACQUIRE_PROC(BindImageMemory2, VK_NULL_HANDLE, device);
212     } else if (extensions->hasExtension(VK_KHR_BIND_MEMORY_2_EXTENSION_NAME, 1)) {
213         ACQUIRE_PROC_SUFFIX(BindBufferMemory2, KHR, VK_NULL_HANDLE, device);
214         ACQUIRE_PROC_SUFFIX(BindImageMemory2, KHR, VK_NULL_HANDLE, device);
215     }
216 
217     // Functions for VK_KHR_maintenance1 or vulkan 1.1
218     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0)) {
219         ACQUIRE_PROC(TrimCommandPool, VK_NULL_HANDLE, device);
220     } else if (extensions->hasExtension(VK_KHR_MAINTENANCE1_EXTENSION_NAME, 1)) {
221         ACQUIRE_PROC_SUFFIX(TrimCommandPool, KHR, VK_NULL_HANDLE, device);
222     }
223 
224     // Functions for VK_KHR_maintenance3 or vulkan 1.1
225     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0)) {
226         ACQUIRE_PROC(GetDescriptorSetLayoutSupport, VK_NULL_HANDLE, device);
227     } else if (extensions->hasExtension(VK_KHR_MAINTENANCE3_EXTENSION_NAME, 1)) {
228         ACQUIRE_PROC_SUFFIX(GetDescriptorSetLayoutSupport, KHR, VK_NULL_HANDLE, device);
229     }
230 
231     // Functions for VK_KHR_external_memory_capabilities
232     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0)) {
233         ACQUIRE_PROC(GetPhysicalDeviceExternalBufferProperties, instance, VK_NULL_HANDLE);
234     } else if (extensions->hasExtension(VK_KHR_EXTERNAL_MEMORY_CAPABILITIES_EXTENSION_NAME, 1)) {
235         ACQUIRE_PROC_SUFFIX(GetPhysicalDeviceExternalBufferProperties, KHR, instance,
236                             VK_NULL_HANDLE);
237     }
238 
239     // Functions for VK_KHR_sampler_ycbcr_conversion
240     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0)) {
241         ACQUIRE_PROC(CreateSamplerYcbcrConversion, VK_NULL_HANDLE, device);
242         ACQUIRE_PROC(DestroySamplerYcbcrConversion, VK_NULL_HANDLE, device);
243     } else if (extensions->hasExtension(VK_KHR_SAMPLER_YCBCR_CONVERSION_EXTENSION_NAME, 1)) {
244         ACQUIRE_PROC_SUFFIX(CreateSamplerYcbcrConversion, KHR, VK_NULL_HANDLE, device);
245         ACQUIRE_PROC_SUFFIX(DestroySamplerYcbcrConversion, KHR, VK_NULL_HANDLE, device);
246     }
247 
248 #ifdef SKIA_USE_XEG
249     ACQUIRE_PROC(GetPerFrameLoad, VK_NULL_HANDLE, device);
250 #endif
251 
252 #ifdef SK_BUILD_FOR_ANDROID
253     // Functions for VK_ANDROID_external_memory_android_hardware_buffer
254     if (extensions->hasExtension(
255             VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_EXTENSION_NAME, 2)) {
256         ACQUIRE_PROC_SUFFIX(GetAndroidHardwareBufferProperties, ANDROID, VK_NULL_HANDLE, device);
257         ACQUIRE_PROC_SUFFIX(GetMemoryAndroidHardwareBuffer, ANDROID, VK_NULL_HANDLE, device);
258     }
259 #endif
260 
261 }
262 
263 #ifdef SK_DEBUG
264     static int kIsDebug = 1;
265 #else
266     static int kIsDebug = 0;
267 #endif
268 
269 #define RETURN_FALSE_INTERFACE                                                                   \
270     if (kIsDebug) { SkDebugf("%s:%d GrVkInterface::validate() failed.\n", __FILE__, __LINE__); } \
271     return false;
272 
validate(uint32_t instanceVersion,uint32_t physicalDeviceVersion,const GrVkExtensions * extensions) const273 bool GrVkInterface::validate(uint32_t instanceVersion, uint32_t physicalDeviceVersion,
274                              const GrVkExtensions* extensions) const {
275     // functions that are always required
276     if (nullptr == fFunctions.fCreateInstance ||
277         nullptr == fFunctions.fDestroyInstance ||
278         nullptr == fFunctions.fEnumeratePhysicalDevices ||
279         nullptr == fFunctions.fGetPhysicalDeviceFeatures ||
280         nullptr == fFunctions.fGetPhysicalDeviceFormatProperties ||
281         nullptr == fFunctions.fGetPhysicalDeviceImageFormatProperties ||
282         nullptr == fFunctions.fGetPhysicalDeviceProperties ||
283         nullptr == fFunctions.fGetPhysicalDeviceQueueFamilyProperties ||
284         nullptr == fFunctions.fGetPhysicalDeviceMemoryProperties ||
285         nullptr == fFunctions.fCreateDevice ||
286         nullptr == fFunctions.fDestroyDevice ||
287         nullptr == fFunctions.fEnumerateInstanceExtensionProperties ||
288         nullptr == fFunctions.fEnumerateDeviceExtensionProperties ||
289         nullptr == fFunctions.fEnumerateInstanceLayerProperties ||
290         nullptr == fFunctions.fEnumerateDeviceLayerProperties ||
291         nullptr == fFunctions.fGetDeviceQueue ||
292         nullptr == fFunctions.fQueueSubmit ||
293         nullptr == fFunctions.fQueueWaitIdle ||
294         nullptr == fFunctions.fDeviceWaitIdle ||
295         nullptr == fFunctions.fAllocateMemory ||
296         nullptr == fFunctions.fFreeMemory ||
297         nullptr == fFunctions.fMapMemory ||
298         nullptr == fFunctions.fUnmapMemory ||
299         nullptr == fFunctions.fFlushMappedMemoryRanges ||
300         nullptr == fFunctions.fInvalidateMappedMemoryRanges ||
301         nullptr == fFunctions.fGetDeviceMemoryCommitment ||
302         nullptr == fFunctions.fBindBufferMemory ||
303         nullptr == fFunctions.fBindImageMemory ||
304         nullptr == fFunctions.fGetBufferMemoryRequirements ||
305         nullptr == fFunctions.fGetImageMemoryRequirements ||
306         nullptr == fFunctions.fGetImageSparseMemoryRequirements ||
307         nullptr == fFunctions.fGetPhysicalDeviceSparseImageFormatProperties ||
308         nullptr == fFunctions.fQueueBindSparse ||
309         nullptr == fFunctions.fCreateFence ||
310         nullptr == fFunctions.fDestroyFence ||
311         nullptr == fFunctions.fResetFences ||
312         nullptr == fFunctions.fGetFenceStatus ||
313         nullptr == fFunctions.fWaitForFences ||
314         nullptr == fFunctions.fCreateSemaphore ||
315         nullptr == fFunctions.fDestroySemaphore ||
316         nullptr == fFunctions.fCreateEvent ||
317         nullptr == fFunctions.fDestroyEvent ||
318         nullptr == fFunctions.fGetEventStatus ||
319         nullptr == fFunctions.fSetEvent ||
320         nullptr == fFunctions.fResetEvent ||
321         nullptr == fFunctions.fCreateQueryPool ||
322         nullptr == fFunctions.fDestroyQueryPool ||
323         nullptr == fFunctions.fGetQueryPoolResults ||
324         nullptr == fFunctions.fCreateBuffer ||
325         nullptr == fFunctions.fDestroyBuffer ||
326         nullptr == fFunctions.fCreateBufferView ||
327         nullptr == fFunctions.fDestroyBufferView ||
328         nullptr == fFunctions.fCreateImage ||
329         nullptr == fFunctions.fDestroyImage ||
330         nullptr == fFunctions.fGetImageSubresourceLayout ||
331         nullptr == fFunctions.fCreateImageView ||
332         nullptr == fFunctions.fDestroyImageView ||
333         nullptr == fFunctions.fCreateShaderModule ||
334         nullptr == fFunctions.fDestroyShaderModule ||
335         nullptr == fFunctions.fCreatePipelineCache ||
336         nullptr == fFunctions.fDestroyPipelineCache ||
337         nullptr == fFunctions.fGetPipelineCacheData ||
338         nullptr == fFunctions.fMergePipelineCaches ||
339         nullptr == fFunctions.fCreateGraphicsPipelines ||
340         nullptr == fFunctions.fCreateComputePipelines ||
341         nullptr == fFunctions.fDestroyPipeline ||
342         nullptr == fFunctions.fCreatePipelineLayout ||
343         nullptr == fFunctions.fDestroyPipelineLayout ||
344         nullptr == fFunctions.fCreateSampler ||
345         nullptr == fFunctions.fDestroySampler ||
346         nullptr == fFunctions.fCreateDescriptorSetLayout ||
347         nullptr == fFunctions.fDestroyDescriptorSetLayout ||
348         nullptr == fFunctions.fCreateDescriptorPool ||
349         nullptr == fFunctions.fDestroyDescriptorPool ||
350         nullptr == fFunctions.fResetDescriptorPool ||
351         nullptr == fFunctions.fAllocateDescriptorSets ||
352         nullptr == fFunctions.fFreeDescriptorSets ||
353         nullptr == fFunctions.fUpdateDescriptorSets ||
354         nullptr == fFunctions.fCreateFramebuffer ||
355         nullptr == fFunctions.fDestroyFramebuffer ||
356         nullptr == fFunctions.fCreateRenderPass ||
357         nullptr == fFunctions.fDestroyRenderPass ||
358         nullptr == fFunctions.fGetRenderAreaGranularity ||
359         nullptr == fFunctions.fCreateCommandPool ||
360         nullptr == fFunctions.fDestroyCommandPool ||
361         nullptr == fFunctions.fResetCommandPool ||
362         nullptr == fFunctions.fAllocateCommandBuffers ||
363         nullptr == fFunctions.fFreeCommandBuffers ||
364         nullptr == fFunctions.fBeginCommandBuffer ||
365         nullptr == fFunctions.fEndCommandBuffer ||
366         nullptr == fFunctions.fResetCommandBuffer ||
367         nullptr == fFunctions.fCmdBindPipeline ||
368         nullptr == fFunctions.fCmdSetViewport ||
369         nullptr == fFunctions.fCmdSetScissor ||
370         nullptr == fFunctions.fCmdSetLineWidth ||
371         nullptr == fFunctions.fCmdSetDepthBias ||
372         nullptr == fFunctions.fCmdSetBlendConstants ||
373         nullptr == fFunctions.fCmdSetDepthBounds ||
374         nullptr == fFunctions.fCmdSetStencilCompareMask ||
375         nullptr == fFunctions.fCmdSetStencilWriteMask ||
376         nullptr == fFunctions.fCmdSetStencilReference ||
377         nullptr == fFunctions.fCmdBindDescriptorSets ||
378         nullptr == fFunctions.fCmdBindIndexBuffer ||
379         nullptr == fFunctions.fCmdBindVertexBuffers ||
380         nullptr == fFunctions.fCmdDraw ||
381         nullptr == fFunctions.fCmdDrawIndexed ||
382         nullptr == fFunctions.fCmdDrawIndirect ||
383         nullptr == fFunctions.fCmdDrawIndexedIndirect ||
384         nullptr == fFunctions.fCmdDispatch ||
385         nullptr == fFunctions.fCmdDispatchIndirect ||
386         nullptr == fFunctions.fCmdCopyBuffer ||
387         nullptr == fFunctions.fCmdCopyImage ||
388         nullptr == fFunctions.fCmdBlitImage ||
389         nullptr == fFunctions.fCmdCopyBufferToImage ||
390         nullptr == fFunctions.fCmdCopyImageToBuffer ||
391         nullptr == fFunctions.fCmdUpdateBuffer ||
392         nullptr == fFunctions.fCmdFillBuffer ||
393         nullptr == fFunctions.fCmdClearColorImage ||
394         nullptr == fFunctions.fCmdClearDepthStencilImage ||
395         nullptr == fFunctions.fCmdClearAttachments ||
396         nullptr == fFunctions.fCmdResolveImage ||
397         nullptr == fFunctions.fCmdSetEvent ||
398         nullptr == fFunctions.fCmdResetEvent ||
399         nullptr == fFunctions.fCmdWaitEvents ||
400         nullptr == fFunctions.fCmdPipelineBarrier ||
401         nullptr == fFunctions.fCmdBeginQuery ||
402         nullptr == fFunctions.fCmdEndQuery ||
403         nullptr == fFunctions.fCmdResetQueryPool ||
404         nullptr == fFunctions.fCmdWriteTimestamp ||
405         nullptr == fFunctions.fCmdCopyQueryPoolResults ||
406         nullptr == fFunctions.fCmdPushConstants ||
407         nullptr == fFunctions.fCmdBeginRenderPass ||
408         nullptr == fFunctions.fCmdNextSubpass ||
409         nullptr == fFunctions.fCmdEndRenderPass ||
410         nullptr == fFunctions.fCmdExecuteCommands) {
411         RETURN_FALSE_INTERFACE
412     }
413 
414     // Functions for VK_KHR_get_physical_device_properties2 or vulkan 1.1
415     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0) ||
416         extensions->hasExtension(VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_EXTENSION_NAME, 1)) {
417         if (nullptr == fFunctions.fGetPhysicalDeviceFeatures2 ||
418             nullptr == fFunctions.fGetPhysicalDeviceProperties2 ||
419             nullptr == fFunctions.fGetPhysicalDeviceFormatProperties2 ||
420             nullptr == fFunctions.fGetPhysicalDeviceImageFormatProperties2 ||
421             nullptr == fFunctions.fGetPhysicalDeviceQueueFamilyProperties2 ||
422             nullptr == fFunctions.fGetPhysicalDeviceMemoryProperties2 ||
423             nullptr == fFunctions.fGetPhysicalDeviceSparseImageFormatProperties2) {
424             RETURN_FALSE_INTERFACE
425         }
426     }
427 
428     // Functions for VK_KHR_get_memory_requirements2 or vulkan 1.1
429     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0) ||
430         extensions->hasExtension(VK_KHR_GET_MEMORY_REQUIREMENTS_2_EXTENSION_NAME, 1)) {
431         if (nullptr == fFunctions.fGetImageMemoryRequirements2 ||
432             nullptr == fFunctions.fGetBufferMemoryRequirements2 ||
433             nullptr == fFunctions.fGetImageSparseMemoryRequirements2) {
434             RETURN_FALSE_INTERFACE
435         }
436     }
437 
438     // Functions for VK_KHR_bind_memory2
439     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0) ||
440         extensions->hasExtension(VK_KHR_BIND_MEMORY_2_EXTENSION_NAME, 1)) {
441         if (nullptr == fFunctions.fBindBufferMemory2 ||
442             nullptr == fFunctions.fBindImageMemory2) {
443             RETURN_FALSE_INTERFACE
444         }
445     }
446 
447     // Functions for VK_KHR_maintenance1 or vulkan 1.1
448     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0) ||
449         extensions->hasExtension(VK_KHR_MAINTENANCE1_EXTENSION_NAME, 1)) {
450         if (nullptr == fFunctions.fTrimCommandPool) {
451             RETURN_FALSE_INTERFACE
452         }
453     }
454 
455     // Functions for VK_KHR_maintenance3 or vulkan 1.1
456     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0) ||
457         extensions->hasExtension(VK_KHR_MAINTENANCE3_EXTENSION_NAME, 1)) {
458         if (nullptr == fFunctions.fGetDescriptorSetLayoutSupport) {
459             RETURN_FALSE_INTERFACE
460         }
461     }
462 
463     // Functions for VK_KHR_external_memory_capabilities
464     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0) ||
465         extensions->hasExtension(VK_KHR_EXTERNAL_MEMORY_CAPABILITIES_EXTENSION_NAME, 1)) {
466         if (nullptr == fFunctions.fGetPhysicalDeviceExternalBufferProperties) {
467             RETURN_FALSE_INTERFACE
468         }
469     }
470 
471     // Functions for VK_KHR_sampler_ycbcr_conversion
472     if (physicalDeviceVersion >= VK_MAKE_VERSION(1, 1, 0) ||
473         extensions->hasExtension(VK_KHR_SAMPLER_YCBCR_CONVERSION_EXTENSION_NAME, 1)) {
474         if (nullptr == fFunctions.fCreateSamplerYcbcrConversion ||
475             nullptr == fFunctions.fDestroySamplerYcbcrConversion) {
476             RETURN_FALSE_INTERFACE
477         }
478     }
479 
480 #ifdef SK_BUILD_FOR_ANDROID
481     // Functions for VK_ANDROID_external_memory_android_hardware_buffer
482     if (extensions->hasExtension(
483             VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_EXTENSION_NAME, 2)) {
484         if (nullptr == fFunctions.fGetAndroidHardwareBufferProperties ||
485             nullptr == fFunctions.fGetMemoryAndroidHardwareBuffer) {
486             RETURN_FALSE_INTERFACE
487         }
488     }
489 #endif
490 
491     return true;
492 }
493 
494