blob: a4fd336ff7d55ec7aa590ec4600235b86632abe9 [file] [log] [blame]
jvanverth633b3562016-03-23 11:01:22 -07001/*
2 * Copyright 2016 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#ifndef GrVkBackendContext_DEFINED
9#define GrVkBackendContext_DEFINED
10
Mike Kleinc0bd9f92019-04-23 12:05:21 -050011#include "include/core/SkRefCnt.h"
12#include "include/gpu/vk/GrVkMemoryAllocator.h"
13#include "include/gpu/vk/GrVkTypes.h"
Greg Danielde811432018-05-30 22:58:20 +000014
Greg Daniel98bffae2018-08-01 13:25:41 -040015class GrVkExtensions;
16
jvanverthfd7bd452016-03-25 06:29:52 -070017enum GrVkExtensionFlags {
Jim Van Verth6a40abc2017-11-02 16:56:09 +000018 kEXT_debug_report_GrVkExtensionFlag = 0x0001,
19 kNV_glsl_shader_GrVkExtensionFlag = 0x0002,
20 kKHR_surface_GrVkExtensionFlag = 0x0004,
21 kKHR_swapchain_GrVkExtensionFlag = 0x0008,
22 kKHR_win32_surface_GrVkExtensionFlag = 0x0010,
23 kKHR_android_surface_GrVkExtensionFlag = 0x0020,
24 kKHR_xcb_surface_GrVkExtensionFlag = 0x0040,
jvanverthfd7bd452016-03-25 06:29:52 -070025};
26
27enum GrVkFeatureFlags {
28 kGeometryShader_GrVkFeatureFlag = 0x0001,
29 kDualSrcBlend_GrVkFeatureFlag = 0x0002,
30 kSampleRateShading_GrVkFeatureFlag = 0x0004,
31};
32
Greg Daniela0651ac2018-08-08 09:23:18 -040033// It is not guarenteed VkPhysicalDeviceProperties2 will be in the client's header so we forward
34// declare it here to be safe.
35struct VkPhysicalDeviceFeatures2;
36
jvanverth633b3562016-03-23 11:01:22 -070037// The BackendContext contains all of the base Vulkan objects needed by the GrVkGpu. The assumption
38// is that the client will set these up and pass them to the GrVkGpu constructor. The VkDevice
Ben Wagner63fd7602017-10-09 15:45:33 -040039// created must support at least one graphics queue, which is passed in as well.
40// The QueueFamilyIndex must match the family of the given queue. It is needed for CommandPool
Greg Danielf730c182018-07-02 20:15:37 +000041// creation, and any GrBackendObjects handed to us (e.g., for wrapped textures) needs to be created
42// in or transitioned to that family. The refs held by members of this struct must be released
43// (either by deleting the struct or manually releasing the refs) before the underlying vulkan
44// device and instance are destroyed.
45struct SK_API GrVkBackendContext {
Greg Daniel4d74f602019-06-05 11:28:38 -040046 VkInstance fInstance;
47 VkPhysicalDevice fPhysicalDevice;
48 VkDevice fDevice;
49 VkQueue fQueue;
50 uint32_t fGraphicsQueueIndex;
51 uint32_t fMinAPIVersion; // Deprecated. Set fInstanceVersion instead.
52 uint32_t fInstanceVersion = 0; // Deprecated. Set fMaxApiVersion instead
Greg Daniel41f0e282019-01-28 13:15:05 -050053 // The max api version set here should match the value set in VkApplicationInfo::apiVersion when
54 // then VkInstance was created.
Greg Daniel4d74f602019-06-05 11:28:38 -040055 uint32_t fMaxAPIVersion = 0;
56 uint32_t fExtensions = 0; // Deprecated. Use fVkExtensions instead.
57 const GrVkExtensions* fVkExtensions = nullptr;
58 uint32_t fFeatures; // Deprecated. Use fDeviceFeatures[2] instead.
Greg Daniela0651ac2018-08-08 09:23:18 -040059 // The client can create their VkDevice with either a VkPhysicalDeviceFeatures or
60 // VkPhysicalDeviceFeatures2 struct, thus we have to support taking both. The
61 // VkPhysicalDeviceFeatures2 struct is needed so we know if the client enabled any extension
62 // specific features. If fDeviceFeatures2 is not null then we ignore fDeviceFeatures. If both
63 // fDeviceFeatures and fDeviceFeatures2 are null we will assume no features are enabled.
Greg Daniel4d74f602019-06-05 11:28:38 -040064 const VkPhysicalDeviceFeatures* fDeviceFeatures = nullptr;
65 const VkPhysicalDeviceFeatures2* fDeviceFeatures2 = nullptr;
66 sk_sp<GrVkMemoryAllocator> fMemoryAllocator;
67 GrVkGetProc fGetProc = nullptr;
Greg Danielf730c182018-07-02 20:15:37 +000068 // This is deprecated and should be set to false. The client is responsible for managing the
69 // lifetime of the VkInstance and VkDevice objects.
Greg Daniel4d74f602019-06-05 11:28:38 -040070 bool fOwnsInstanceAndDevice = false;
Emircan Uysaler23ca4e72019-06-24 10:53:09 -040071 // Indicates that we are working with protected content and all CommandPool and Queue operations
72 // should be done in a protected context.
73 GrProtected fProtectedContext = GrProtected::kNo;
jvanverth633b3562016-03-23 11:01:22 -070074};
75
76#endif