blob: 5bbd00cf94be74006b92ef57d6f182e2466ce9fa [file] [log] [blame]
// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef GPU_VULKAN_VULKAN_IMPLEMENTATION_H_
#define GPU_VULKAN_VULKAN_IMPLEMENTATION_H_
#include <vulkan/vulkan_core.h>
#include <memory>
#include <vector>
#include "base/component_export.h"
#include "build/build_config.h"
#include "gpu/vulkan/semaphore_handle.h"
#include "ui/gfx/buffer_types.h"
#include "ui/gfx/color_space.h"
#include "ui/gfx/geometry/size.h"
#include "ui/gfx/gpu_memory_buffer_handle.h"
#include "ui/gfx/native_widget_types.h"
#if BUILDFLAG(IS_ANDROID)
#include "base/android/scoped_hardware_buffer_handle.h"
#endif
namespace gfx {
class GpuFence;
} // namespace gfx
namespace gpu {
class VulkanDeviceQueue;
class VulkanSurface;
class VulkanImage;
class VulkanInstance;
struct GPUInfo;
struct VulkanYCbCrInfo;
// Base class which provides functions for creating vulkan objects for different
// platforms that use platform-specific extensions (e.g. for creation of
// VkSurfaceKHR objects). It also provides helper/utility functions.
class COMPONENT_EXPORT(VULKAN) VulkanImplementation {
public:
explicit VulkanImplementation(bool use_swiftshader = false,
bool allow_protected_memory = false);
VulkanImplementation(const VulkanImplementation&) = delete;
VulkanImplementation& operator=(const VulkanImplementation&) = delete;
virtual ~VulkanImplementation();
// Initialize VulkanInstance. If using_surface, VK_KHR_surface instance
// extension will be required when initialize VkInstance. This extension is
// required for presenting with VkSwapchain API.
virtual bool InitializeVulkanInstance(bool using_surface = true) = 0;
virtual VulkanInstance* GetVulkanInstance() = 0;
virtual std::unique_ptr<VulkanSurface> CreateViewSurface(
gfx::AcceleratedWidget window) = 0;
virtual bool GetPhysicalDevicePresentationSupport(
VkPhysicalDevice device,
const std::vector<VkQueueFamilyProperties>& queue_family_properties,
uint32_t queue_family_index) = 0;
virtual std::vector<const char*> GetRequiredDeviceExtensions() = 0;
virtual std::vector<const char*> GetOptionalDeviceExtensions() = 0;
// Creates a VkFence that is exportable to a gfx::GpuFence.
virtual VkFence CreateVkFenceForGpuFence(VkDevice vk_device) = 0;
// Exports a VkFence to a gfx::GpuFence.
//
// The fence should have been created via CreateVkFenceForGpuFence().
virtual std::unique_ptr<gfx::GpuFence> ExportVkFenceToGpuFence(
VkDevice vk_device,
VkFence vk_fence) = 0;
// Creates a semaphore that can be exported using GetSemaphoreHandle().
virtual VkSemaphore CreateExternalSemaphore(VkDevice vk_device);
// Import a VkSemaphore from a platform-specific handle.
// Handle types that don't allow permanent import are imported with
// temporary permanence (VK_SEMAPHORE_IMPORT_TEMPORARY_BIT).
virtual VkSemaphore ImportSemaphoreHandle(VkDevice vk_device,
SemaphoreHandle handle);
// Export a platform-specific handle for a Vulkan semaphore. Returns a null
// handle in case of a failure.
virtual SemaphoreHandle GetSemaphoreHandle(VkDevice vk_device,
VkSemaphore vk_semaphore);
// Returns VkExternalSemaphoreHandleTypeFlagBits that should be used when
// creating and exporting external semaphores.
virtual VkExternalSemaphoreHandleTypeFlagBits
GetExternalSemaphoreHandleType() = 0;
// Returns true if the GpuMemoryBuffer of the specified type can be imported
// into VkImage using CreateImageFromGpuMemoryHandle().
virtual bool CanImportGpuMemoryBuffer(
VulkanDeviceQueue* device_queue,
gfx::GpuMemoryBufferType memory_buffer_type) = 0;
// Creates a VkImage from a GpuMemoryBuffer. Implementation must verify that
// the specified |size| fits in the size specified when |gmb_handle| was
// allocated.
virtual std::unique_ptr<VulkanImage> CreateImageFromGpuMemoryHandle(
VulkanDeviceQueue* device_queue,
gfx::GpuMemoryBufferHandle gmb_handle,
gfx::Size size,
VkFormat vk_format,
const gfx::ColorSpace& color_space) = 0;
// Returns whether external semaphores are supported by this device.
virtual bool IsExternalSemaphoreSupported(VulkanDeviceQueue* device_queue);
#if BUILDFLAG(IS_ANDROID)
// Get the sampler ycbcr conversion information from the AHB.
virtual bool GetSamplerYcbcrConversionInfo(
const VkDevice& vk_device,
base::android::ScopedHardwareBufferHandle ahb_handle,
VulkanYCbCrInfo* ycbcr_info) = 0;
#endif
#if BUILDFLAG(IS_FUCHSIA)
// Registers a sysmem buffer collection. `service_handle` contains a handle
// for the eventpair that controls the lifetime of the collection. The
// implementation must drop the collection when all peer handles for
// that eventpair are destroyed (i.e. when `ZX_EVENTPAIR_PEER_CLOSED` is
// signaled on that handle). Once a collection is registered the individual
// buffers in the collection can be referenced by using the peer of
// `service_handle` as `buffer_collection_handle` in `gmb_handle` passed to
// CreateImageFromGpuMemoryHandle().
virtual void RegisterSysmemBufferCollection(
VkDevice device,
zx::eventpair service_handle,
zx::channel sysmem_token,
gfx::BufferFormat format,
gfx::BufferUsage usage,
gfx::Size size,
size_t min_buffer_count,
bool register_with_image_pipe) = 0;
#endif // BUILDFLAG(IS_FUCHSIA)
bool use_swiftshader() const { return use_swiftshader_; }
bool allow_protected_memory() const { return allow_protected_memory_; }
private:
const bool use_swiftshader_;
const bool allow_protected_memory_;
};
COMPONENT_EXPORT(VULKAN)
std::unique_ptr<VulkanDeviceQueue> CreateVulkanDeviceQueue(
VulkanImplementation* vulkan_implementation,
uint32_t option,
const GPUInfo* gpu_info = nullptr,
uint32_t heap_memory_limit = 0,
const bool is_thread_safe = false);
} // namespace gpu
#endif // GPU_VULKAN_VULKAN_IMPLEMENTATION_H_