007267bdb5
This reverts commit0db3a8846a
. Reason for revert: fuchsia change reverted Original change's description: > Reland "Make GrVkBackendContext no longer derive from SkRefCnt." > > This reverts commit059a9ab4bc
. > > Reason for revert: Fix landed in Fuchsia > > Original change's description: > > Revert "Make GrVkBackendContext no longer derive from SkRefCnt." > > > > This reverts commit93ae233773
. > > > > Reason for revert: <INSERT REASONING HERE> > > > > Original change's description: > > > Make GrVkBackendContext no longer derive from SkRefCnt. > > > > > > Also moves the helper Create functions to VkTestUtils since no clients > > > are using them anymore. > > > > > > Bug: skia: > > > Change-Id: I7e8e4912e7ef6fb00a7e2a00407aed5e83211799 > > > Reviewed-on: https://skia-review.googlesource.com/135323 > > > Reviewed-by: Jim Van Verth <jvanverth@google.com> > > > Reviewed-by: Brian Salomon <bsalomon@google.com> > > > Commit-Queue: Greg Daniel <egdaniel@google.com> > > > > TBR=egdaniel@google.com,jvanverth@google.com,bsalomon@google.com > > > > # Not skipping CQ checks because original CL landed > 1 day ago. > > > > Bug: skia: > > Change-Id: If7201917631dc22753ea3fa6e9d2984463e38e4c > > Reviewed-on: https://skia-review.googlesource.com/137903 > > Reviewed-by: Greg Daniel <egdaniel@google.com> > > Commit-Queue: Greg Daniel <egdaniel@google.com> > > TBR=egdaniel@google.com,jvanverth@google.com,bsalomon@google.com > > # Not skipping CQ checks because original CL landed > 1 day ago. > > Bug: skia: > Change-Id: Ia4b7c0bb2c7b5dba809d85c69f0b41b473140526 > Reviewed-on: https://skia-review.googlesource.com/138181 > Reviewed-by: Greg Daniel <egdaniel@google.com> > Commit-Queue: Greg Daniel <egdaniel@google.com> TBR=egdaniel@google.com,jvanverth@google.com,bsalomon@google.com Change-Id: I3f7bc4a5e4e09512fe165303685c123ec3527e58 No-Presubmit: true No-Tree-Checks: true No-Try: true Bug: skia: Reviewed-on: https://skia-review.googlesource.com/138422 Reviewed-by: Greg Daniel <egdaniel@google.com> Commit-Queue: Greg Daniel <egdaniel@google.com>
98 lines
4.2 KiB
C++
98 lines
4.2 KiB
C++
/*
|
|
* Copyright 2016 Google Inc.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
#ifndef GrVkBackendContext_DEFINED
|
|
#define GrVkBackendContext_DEFINED
|
|
|
|
#include "SkRefCnt.h"
|
|
|
|
#include "vk/GrVkDefines.h"
|
|
#include "vk/GrVkInterface.h"
|
|
#include "vk/GrVkMemoryAllocator.h"
|
|
|
|
enum GrVkExtensionFlags {
|
|
kEXT_debug_report_GrVkExtensionFlag = 0x0001,
|
|
kNV_glsl_shader_GrVkExtensionFlag = 0x0002,
|
|
kKHR_surface_GrVkExtensionFlag = 0x0004,
|
|
kKHR_swapchain_GrVkExtensionFlag = 0x0008,
|
|
kKHR_win32_surface_GrVkExtensionFlag = 0x0010,
|
|
kKHR_android_surface_GrVkExtensionFlag = 0x0020,
|
|
kKHR_xcb_surface_GrVkExtensionFlag = 0x0040,
|
|
};
|
|
|
|
enum GrVkFeatureFlags {
|
|
kGeometryShader_GrVkFeatureFlag = 0x0001,
|
|
kDualSrcBlend_GrVkFeatureFlag = 0x0002,
|
|
kSampleRateShading_GrVkFeatureFlag = 0x0004,
|
|
};
|
|
|
|
// The BackendContext contains all of the base Vulkan objects needed by the GrVkGpu. The assumption
|
|
// is that the client will set these up and pass them to the GrVkGpu constructor. The VkDevice
|
|
// created must support at least one graphics queue, which is passed in as well.
|
|
// The QueueFamilyIndex must match the family of the given queue. It is needed for CommandPool
|
|
// creation, and any GrBackendObjects handed to us (e.g., for wrapped textures) need to be created
|
|
// in or transitioned to that family.
|
|
struct SK_API GrVkBackendContext : public SkRefCnt {
|
|
VkInstance fInstance;
|
|
VkPhysicalDevice fPhysicalDevice;
|
|
VkDevice fDevice;
|
|
VkQueue fQueue;
|
|
uint32_t fGraphicsQueueIndex;
|
|
uint32_t fMinAPIVersion;
|
|
uint32_t fExtensions;
|
|
uint32_t fFeatures;
|
|
sk_sp<const GrVkInterface> fInterface;
|
|
sk_sp<GrVkMemoryAllocator> fMemoryAllocator;
|
|
|
|
/**
|
|
* Controls whether this object destroys the instance and device upon destruction. The default
|
|
* is temporarily 'true' to avoid breaking existing clients but will be changed to 'false'.
|
|
*/
|
|
bool fOwnsInstanceAndDevice = true;
|
|
|
|
#if GR_TEST_UTILS || defined(SK_BUILD_FOR_ANDROID_FRAMEWORK)
|
|
using CanPresentFn = std::function<bool(VkInstance, VkPhysicalDevice,
|
|
uint32_t queueFamilyIndex)>;
|
|
|
|
/**
|
|
* Helper function to create the Vulkan objects needed for a Vulkan-backed GrContext.
|
|
* Note that the version that uses the unified "GetProc" instead of separate "GetInstanceProc"
|
|
* and "GetDeviceProc" functions will be removed.
|
|
*
|
|
* If presentQueueIndex is non-NULL, will try to set up presentQueue as part of device
|
|
* creation using the platform-specific canPresent() function.
|
|
*
|
|
* This will set fOwnsInstanceAndDevice to 'true'. If it is subsequently set to 'false' then
|
|
* the client owns the lifetime of the created VkDevice and VkInstance.
|
|
*/
|
|
static const GrVkBackendContext* Create(uint32_t* presentQueueIndex = nullptr,
|
|
CanPresentFn = CanPresentFn(),
|
|
GrVkInterface::GetProc getProc = nullptr);
|
|
|
|
static const GrVkBackendContext* Create(const GrVkInterface::GetInstanceProc& getInstanceProc,
|
|
const GrVkInterface::GetDeviceProc& getDeviceProc,
|
|
uint32_t* presentQueueIndex = nullptr,
|
|
CanPresentFn canPresent = CanPresentFn()) {
|
|
if (!getInstanceProc || !getDeviceProc) {
|
|
return nullptr;
|
|
}
|
|
auto getProc = [&getInstanceProc, &getDeviceProc](const char* proc_name,
|
|
VkInstance instance, VkDevice device) {
|
|
if (device != VK_NULL_HANDLE) {
|
|
return getDeviceProc(device, proc_name);
|
|
}
|
|
return getInstanceProc(instance, proc_name);
|
|
};
|
|
return Create(presentQueueIndex, canPresent, getProc);
|
|
}
|
|
#endif // GR_TEST_UTILS || defined(SK_BUILD_FOR_ANDROID_FRAMEWORK)
|
|
|
|
~GrVkBackendContext() override;
|
|
};
|
|
|
|
#endif
|