blob: 4188943b1763ff3ab407bc0273b9d460de6a51c9 [file] [log] [blame]
/*
* Copyright 2015 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#include "vk/GrVkInterface.h"
#include "vk/GrVkBackendContext.h"
#include "vk/GrVkUtil.h"
#define ACQUIRE_PROC(name, instance, device) fFunctions.f##name = \
reinterpret_cast<PFN_vk##name>(getProc("vk"#name, instance, device));
GrVkInterface::GetProc make_unified_getter(const GrVkInterface::GetInstanceProc& iproc,
const GrVkInterface::GetDeviceProc& dproc) {
return [&iproc, &dproc](const char* proc_name, VkInstance instance, VkDevice device) {
if (device != VK_NULL_HANDLE) {
return dproc(device, proc_name);
}
return iproc(instance, proc_name);
};
}
GrVkInterface::GrVkInterface(const GetInstanceProc& getInstanceProc,
const GetDeviceProc& getDeviceProc,
VkInstance instance,
VkDevice device,
uint32_t extensionFlags)
: GrVkInterface(make_unified_getter(getInstanceProc, getDeviceProc),
instance,
device,
extensionFlags) {}
GrVkInterface::GrVkInterface(GetProc getProc,
VkInstance instance,
VkDevice device,
uint32_t extensionFlags) {
if (getProc == nullptr) {
return;
}
// Global/Loader Procs.
ACQUIRE_PROC(CreateInstance, VK_NULL_HANDLE, VK_NULL_HANDLE);
ACQUIRE_PROC(EnumerateInstanceExtensionProperties, VK_NULL_HANDLE, VK_NULL_HANDLE);
ACQUIRE_PROC(EnumerateInstanceLayerProperties, VK_NULL_HANDLE, VK_NULL_HANDLE);
// Instance Procs.
ACQUIRE_PROC(EnumeratePhysicalDevices, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(GetPhysicalDeviceFeatures, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(GetPhysicalDeviceFormatProperties, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(GetPhysicalDeviceImageFormatProperties, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(GetPhysicalDeviceProperties, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(GetPhysicalDeviceQueueFamilyProperties, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(GetPhysicalDeviceMemoryProperties, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(GetPhysicalDeviceSparseImageFormatProperties, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(DestroyInstance, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(CreateDevice, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(DestroyDevice, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(EnumerateDeviceExtensionProperties, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(EnumerateDeviceLayerProperties, instance, VK_NULL_HANDLE);
if (extensionFlags & kEXT_debug_report_GrVkExtensionFlag) {
// Also instance Procs.
ACQUIRE_PROC(CreateDebugReportCallbackEXT, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(DebugReportMessageEXT, instance, VK_NULL_HANDLE);
ACQUIRE_PROC(DestroyDebugReportCallbackEXT, instance, VK_NULL_HANDLE);
}
// Device Procs.
ACQUIRE_PROC(GetDeviceQueue, VK_NULL_HANDLE, device);
ACQUIRE_PROC(QueueSubmit, VK_NULL_HANDLE, device);
ACQUIRE_PROC(QueueWaitIdle, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DeviceWaitIdle, VK_NULL_HANDLE, device);
ACQUIRE_PROC(AllocateMemory, VK_NULL_HANDLE, device);
ACQUIRE_PROC(FreeMemory, VK_NULL_HANDLE, device);
ACQUIRE_PROC(MapMemory, VK_NULL_HANDLE, device);
ACQUIRE_PROC(UnmapMemory, VK_NULL_HANDLE, device);
ACQUIRE_PROC(FlushMappedMemoryRanges, VK_NULL_HANDLE, device);
ACQUIRE_PROC(InvalidateMappedMemoryRanges, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetDeviceMemoryCommitment, VK_NULL_HANDLE, device);
ACQUIRE_PROC(BindBufferMemory, VK_NULL_HANDLE, device);
ACQUIRE_PROC(BindImageMemory, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetBufferMemoryRequirements, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetImageMemoryRequirements, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetImageSparseMemoryRequirements, VK_NULL_HANDLE, device);
ACQUIRE_PROC(QueueBindSparse, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateFence, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyFence, VK_NULL_HANDLE, device);
ACQUIRE_PROC(ResetFences, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetFenceStatus, VK_NULL_HANDLE, device);
ACQUIRE_PROC(WaitForFences, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateSemaphore, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroySemaphore, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateEvent, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyEvent, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetEventStatus, VK_NULL_HANDLE, device);
ACQUIRE_PROC(SetEvent, VK_NULL_HANDLE, device);
ACQUIRE_PROC(ResetEvent, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateQueryPool, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyQueryPool, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetQueryPoolResults, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateBufferView, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyBufferView, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateImage, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyImage, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetImageSubresourceLayout, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateImageView, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyImageView, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateShaderModule, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyShaderModule, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreatePipelineCache, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyPipelineCache, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetPipelineCacheData, VK_NULL_HANDLE, device);
ACQUIRE_PROC(MergePipelineCaches, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateGraphicsPipelines, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateComputePipelines, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyPipeline, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreatePipelineLayout, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyPipelineLayout, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateSampler, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroySampler, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateDescriptorSetLayout, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyDescriptorSetLayout, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateDescriptorPool, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyDescriptorPool, VK_NULL_HANDLE, device);
ACQUIRE_PROC(ResetDescriptorPool, VK_NULL_HANDLE, device);
ACQUIRE_PROC(AllocateDescriptorSets, VK_NULL_HANDLE, device);
ACQUIRE_PROC(FreeDescriptorSets, VK_NULL_HANDLE, device);
ACQUIRE_PROC(UpdateDescriptorSets, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateFramebuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyFramebuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateRenderPass, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyRenderPass, VK_NULL_HANDLE, device);
ACQUIRE_PROC(GetRenderAreaGranularity, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CreateCommandPool, VK_NULL_HANDLE, device);
ACQUIRE_PROC(DestroyCommandPool, VK_NULL_HANDLE, device);
ACQUIRE_PROC(ResetCommandPool, VK_NULL_HANDLE, device);
ACQUIRE_PROC(AllocateCommandBuffers, VK_NULL_HANDLE, device);
ACQUIRE_PROC(FreeCommandBuffers, VK_NULL_HANDLE, device);
ACQUIRE_PROC(BeginCommandBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(EndCommandBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(ResetCommandBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdBindPipeline, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetViewport, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetScissor, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetLineWidth, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetDepthBias, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetBlendConstants, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetDepthBounds, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetStencilCompareMask, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetStencilWriteMask, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetStencilReference, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdBindDescriptorSets, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdBindIndexBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdBindVertexBuffers, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdDraw, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdDrawIndexed, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdDrawIndirect, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdDrawIndexedIndirect, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdDispatch, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdDispatchIndirect, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdCopyBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdCopyImage, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdBlitImage, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdCopyBufferToImage, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdCopyImageToBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdUpdateBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdFillBuffer, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdClearColorImage, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdClearDepthStencilImage, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdClearAttachments, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdResolveImage, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdSetEvent, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdResetEvent, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdWaitEvents, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdPipelineBarrier, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdBeginQuery, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdEndQuery, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdResetQueryPool, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdWriteTimestamp, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdCopyQueryPoolResults, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdPushConstants, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdBeginRenderPass, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdNextSubpass, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdEndRenderPass, VK_NULL_HANDLE, device);
ACQUIRE_PROC(CmdExecuteCommands, VK_NULL_HANDLE, device);
}
#ifdef SK_DEBUG
static int kIsDebug = 1;
#else
static int kIsDebug = 0;
#endif
#define RETURN_FALSE_INTERFACE \
if (kIsDebug) { SkDebugf("%s:%d GrVkInterface::validate() failed.\n", __FILE__, __LINE__); } \
return false;
bool GrVkInterface::validate(uint32_t extensionFlags) const {
// functions that are always required
if (NULL == fFunctions.fCreateInstance ||
NULL == fFunctions.fDestroyInstance ||
NULL == fFunctions.fEnumeratePhysicalDevices ||
NULL == fFunctions.fGetPhysicalDeviceFeatures ||
NULL == fFunctions.fGetPhysicalDeviceFormatProperties ||
NULL == fFunctions.fGetPhysicalDeviceImageFormatProperties ||
NULL == fFunctions.fGetPhysicalDeviceProperties ||
NULL == fFunctions.fGetPhysicalDeviceQueueFamilyProperties ||
NULL == fFunctions.fGetPhysicalDeviceMemoryProperties ||
NULL == fFunctions.fCreateDevice ||
NULL == fFunctions.fDestroyDevice ||
NULL == fFunctions.fEnumerateInstanceExtensionProperties ||
NULL == fFunctions.fEnumerateDeviceExtensionProperties ||
NULL == fFunctions.fEnumerateInstanceLayerProperties ||
NULL == fFunctions.fEnumerateDeviceLayerProperties ||
NULL == fFunctions.fGetDeviceQueue ||
NULL == fFunctions.fQueueSubmit ||
NULL == fFunctions.fQueueWaitIdle ||
NULL == fFunctions.fDeviceWaitIdle ||
NULL == fFunctions.fAllocateMemory ||
NULL == fFunctions.fFreeMemory ||
NULL == fFunctions.fMapMemory ||
NULL == fFunctions.fUnmapMemory ||
NULL == fFunctions.fFlushMappedMemoryRanges ||
NULL == fFunctions.fInvalidateMappedMemoryRanges ||
NULL == fFunctions.fGetDeviceMemoryCommitment ||
NULL == fFunctions.fBindBufferMemory ||
NULL == fFunctions.fBindImageMemory ||
NULL == fFunctions.fGetBufferMemoryRequirements ||
NULL == fFunctions.fGetImageMemoryRequirements ||
NULL == fFunctions.fGetImageSparseMemoryRequirements ||
NULL == fFunctions.fGetPhysicalDeviceSparseImageFormatProperties ||
NULL == fFunctions.fQueueBindSparse ||
NULL == fFunctions.fCreateFence ||
NULL == fFunctions.fDestroyFence ||
NULL == fFunctions.fResetFences ||
NULL == fFunctions.fGetFenceStatus ||
NULL == fFunctions.fWaitForFences ||
NULL == fFunctions.fCreateSemaphore ||
NULL == fFunctions.fDestroySemaphore ||
NULL == fFunctions.fCreateEvent ||
NULL == fFunctions.fDestroyEvent ||
NULL == fFunctions.fGetEventStatus ||
NULL == fFunctions.fSetEvent ||
NULL == fFunctions.fResetEvent ||
NULL == fFunctions.fCreateQueryPool ||
NULL == fFunctions.fDestroyQueryPool ||
NULL == fFunctions.fGetQueryPoolResults ||
NULL == fFunctions.fCreateBuffer ||
NULL == fFunctions.fDestroyBuffer ||
NULL == fFunctions.fCreateBufferView ||
NULL == fFunctions.fDestroyBufferView ||
NULL == fFunctions.fCreateImage ||
NULL == fFunctions.fDestroyImage ||
NULL == fFunctions.fGetImageSubresourceLayout ||
NULL == fFunctions.fCreateImageView ||
NULL == fFunctions.fDestroyImageView ||
NULL == fFunctions.fCreateShaderModule ||
NULL == fFunctions.fDestroyShaderModule ||
NULL == fFunctions.fCreatePipelineCache ||
NULL == fFunctions.fDestroyPipelineCache ||
NULL == fFunctions.fGetPipelineCacheData ||
NULL == fFunctions.fMergePipelineCaches ||
NULL == fFunctions.fCreateGraphicsPipelines ||
NULL == fFunctions.fCreateComputePipelines ||
NULL == fFunctions.fDestroyPipeline ||
NULL == fFunctions.fCreatePipelineLayout ||
NULL == fFunctions.fDestroyPipelineLayout ||
NULL == fFunctions.fCreateSampler ||
NULL == fFunctions.fDestroySampler ||
NULL == fFunctions.fCreateDescriptorSetLayout ||
NULL == fFunctions.fDestroyDescriptorSetLayout ||
NULL == fFunctions.fCreateDescriptorPool ||
NULL == fFunctions.fDestroyDescriptorPool ||
NULL == fFunctions.fResetDescriptorPool ||
NULL == fFunctions.fAllocateDescriptorSets ||
NULL == fFunctions.fFreeDescriptorSets ||
NULL == fFunctions.fUpdateDescriptorSets ||
NULL == fFunctions.fCreateFramebuffer ||
NULL == fFunctions.fDestroyFramebuffer ||
NULL == fFunctions.fCreateRenderPass ||
NULL == fFunctions.fDestroyRenderPass ||
NULL == fFunctions.fGetRenderAreaGranularity ||
NULL == fFunctions.fCreateCommandPool ||
NULL == fFunctions.fDestroyCommandPool ||
NULL == fFunctions.fResetCommandPool ||
NULL == fFunctions.fAllocateCommandBuffers ||
NULL == fFunctions.fFreeCommandBuffers ||
NULL == fFunctions.fBeginCommandBuffer ||
NULL == fFunctions.fEndCommandBuffer ||
NULL == fFunctions.fResetCommandBuffer ||
NULL == fFunctions.fCmdBindPipeline ||
NULL == fFunctions.fCmdSetViewport ||
NULL == fFunctions.fCmdSetScissor ||
NULL == fFunctions.fCmdSetLineWidth ||
NULL == fFunctions.fCmdSetDepthBias ||
NULL == fFunctions.fCmdSetBlendConstants ||
NULL == fFunctions.fCmdSetDepthBounds ||
NULL == fFunctions.fCmdSetStencilCompareMask ||
NULL == fFunctions.fCmdSetStencilWriteMask ||
NULL == fFunctions.fCmdSetStencilReference ||
NULL == fFunctions.fCmdBindDescriptorSets ||
NULL == fFunctions.fCmdBindIndexBuffer ||
NULL == fFunctions.fCmdBindVertexBuffers ||
NULL == fFunctions.fCmdDraw ||
NULL == fFunctions.fCmdDrawIndexed ||
NULL == fFunctions.fCmdDrawIndirect ||
NULL == fFunctions.fCmdDrawIndexedIndirect ||
NULL == fFunctions.fCmdDispatch ||
NULL == fFunctions.fCmdDispatchIndirect ||
NULL == fFunctions.fCmdCopyBuffer ||
NULL == fFunctions.fCmdCopyImage ||
NULL == fFunctions.fCmdBlitImage ||
NULL == fFunctions.fCmdCopyBufferToImage ||
NULL == fFunctions.fCmdCopyImageToBuffer ||
NULL == fFunctions.fCmdUpdateBuffer ||
NULL == fFunctions.fCmdFillBuffer ||
NULL == fFunctions.fCmdClearColorImage ||
NULL == fFunctions.fCmdClearDepthStencilImage ||
NULL == fFunctions.fCmdClearAttachments ||
NULL == fFunctions.fCmdResolveImage ||
NULL == fFunctions.fCmdSetEvent ||
NULL == fFunctions.fCmdResetEvent ||
NULL == fFunctions.fCmdWaitEvents ||
NULL == fFunctions.fCmdPipelineBarrier ||
NULL == fFunctions.fCmdBeginQuery ||
NULL == fFunctions.fCmdEndQuery ||
NULL == fFunctions.fCmdResetQueryPool ||
NULL == fFunctions.fCmdWriteTimestamp ||
NULL == fFunctions.fCmdCopyQueryPoolResults ||
NULL == fFunctions.fCmdPushConstants ||
NULL == fFunctions.fCmdBeginRenderPass ||
NULL == fFunctions.fCmdNextSubpass ||
NULL == fFunctions.fCmdEndRenderPass ||
NULL == fFunctions.fCmdExecuteCommands) {
RETURN_FALSE_INTERFACE
}
if (extensionFlags & kEXT_debug_report_GrVkExtensionFlag) {
if (NULL == fFunctions.fCreateDebugReportCallbackEXT ||
NULL == fFunctions.fDebugReportMessageEXT ||
NULL == fFunctions.fDestroyDebugReportCallbackEXT) {
RETURN_FALSE_INTERFACE
}
}
return true;
}