blob: 9c2fe4f8e7fb5eb82a7481a554a3a1ec08d042db [file] [log] [blame]
Greg Daniel164a9f02016-02-22 09:56:40 -05001/*
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#ifndef GrVkUtil_DEFINED
9#define GrVkUtil_DEFINED
10
Mike Kleinc0bd9f92019-04-23 12:05:21 -050011#include "include/gpu/GrTypes.h"
12#include "include/gpu/vk/GrVkTypes.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050013#include "include/private/SkMacros.h"
Greg Danielf91aeb22019-06-18 09:58:02 -040014#include "src/gpu/GrColor.h"
Robert Phillips28a5a432019-06-07 12:46:21 -040015#include "src/gpu/GrDataUtils.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050016#include "src/gpu/vk/GrVkInterface.h"
17#include "src/sksl/ir/SkSLProgram.h"
Greg Daniel164a9f02016-02-22 09:56:40 -050018
egdaniel88987d82016-09-19 10:17:34 -070019class GrVkGpu;
Greg Daniel164a9f02016-02-22 09:56:40 -050020
Greg Daniel164a9f02016-02-22 09:56:40 -050021// makes a Vk call on the interface
Brian Salomon23356442018-11-30 15:33:19 -050022#define GR_VK_CALL(IFACE, X) (IFACE)->fFunctions.f##X
Greg Daniel164a9f02016-02-22 09:56:40 -050023// same as GR_VK_CALL but checks for success
24#ifdef SK_DEBUG
Brian Salomon23356442018-11-30 15:33:19 -050025#define GR_VK_CALL_ERRCHECK(IFACE, X) \
Greg Daniel164a9f02016-02-22 09:56:40 -050026 VkResult SK_MACRO_APPEND_LINE(ret) = GR_VK_CALL(IFACE, X); \
Brian Salomon23356442018-11-30 15:33:19 -050027 SkASSERT(VK_SUCCESS == SK_MACRO_APPEND_LINE(ret))
Greg Daniel164a9f02016-02-22 09:56:40 -050028#else
Brian Salomon23356442018-11-30 15:33:19 -050029#define GR_VK_CALL_ERRCHECK(IFACE, X) (void) GR_VK_CALL(IFACE, X)
Greg Daniel164a9f02016-02-22 09:56:40 -050030#endif
31
Greg Daniel81b80592017-12-13 10:20:04 -050032bool GrVkFormatIsSupported(VkFormat);
33
Sergey Ulanov2739fd22019-08-11 22:46:33 -070034bool GrVkFormatNeedsYcbcrSampler(VkFormat format);
35
Greg Daniel7e000222018-12-03 10:08:21 -050036#ifdef SK_DEBUG
Greg Daniel81b80592017-12-13 10:20:04 -050037/**
Robert Phillipsc80b0e92019-07-23 10:27:09 -040038 * Returns true if the passed in VkFormat and GrColorType are compatible with each other.
Greg Daniel81b80592017-12-13 10:20:04 -050039 */
Robert Phillipsc80b0e92019-07-23 10:27:09 -040040bool GrVkFormatColorTypePairIsValid(VkFormat, GrColorType);
Greg Daniel7e000222018-12-03 10:08:21 -050041#endif
Greg Daniel81b80592017-12-13 10:20:04 -050042
Greg Daniel164a9f02016-02-22 09:56:40 -050043bool GrSampleCountToVkSampleCount(uint32_t samples, VkSampleCountFlagBits* vkSamples);
44
egdaniel88987d82016-09-19 10:17:34 -070045bool GrCompileVkShaderModule(const GrVkGpu* gpu,
Brian Osmanfd7657c2019-04-25 11:34:07 -040046 const SkSL::String& shaderString,
egdaniel88987d82016-09-19 10:17:34 -070047 VkShaderStageFlagBits stage,
48 VkShaderModule* shaderModule,
Ethan Nicholas941e7e22016-12-12 15:33:30 -050049 VkPipelineShaderStageCreateInfo* stageInfo,
50 const SkSL::Program::Settings& settings,
Ethan Nicholas92e01cf2018-12-19 13:12:10 -050051 SkSL::String* outSPIRV,
Ethan Nicholas941e7e22016-12-12 15:33:30 -050052 SkSL::Program::Inputs* outInputs);
egdaniel88987d82016-09-19 10:17:34 -070053
Ethan Nicholas92e01cf2018-12-19 13:12:10 -050054bool GrInstallVkShaderModule(const GrVkGpu* gpu,
55 const SkSL::String& spirv,
56 VkShaderStageFlagBits stage,
57 VkShaderModule* shaderModule,
58 VkPipelineShaderStageCreateInfo* stageInfo);
59
Robert Phillips1f098982019-05-15 10:27:36 -040060size_t GrVkBytesPerFormat(VkFormat);
61
62/**
63 * Returns true if the format is compressed.
64 */
65bool GrVkFormatIsCompressed(VkFormat);
66
67/**
Brian Salomonbb8dde82019-06-27 10:52:13 -040068 * Maps a vk format into the CompressionType enum if applicable.
Robert Phillips1f098982019-05-15 10:27:36 -040069 */
Brian Salomonbb8dde82019-06-27 10:52:13 -040070bool GrVkFormatToCompressionType(VkFormat vkFormat, SkImage::CompressionType* compressionType);
Robert Phillips28a5a432019-06-07 12:46:21 -040071
Robert Phillipsbac46722019-08-01 15:09:17 -040072#if GR_TEST_UTILS
73static constexpr const char* GrVkFormatToStr(VkFormat vkFormat) {
74 switch (vkFormat) {
75 case VK_FORMAT_R8G8B8A8_UNORM: return "R8G8B8A8_UNORM";
76 case VK_FORMAT_R8_UNORM: return "R8_UNORM";
77 case VK_FORMAT_B8G8R8A8_UNORM: return "B8G8R8A8_UNORM";
78 case VK_FORMAT_R5G6B5_UNORM_PACK16: return "R5G6B5_UNORM_PACK16";
79 case VK_FORMAT_R16G16B16A16_SFLOAT: return "R16G16B16A16_SFLOAT";
80 case VK_FORMAT_R16_SFLOAT: return "R16_SFLOAT";
81 case VK_FORMAT_R8G8B8_UNORM: return "R8G8B8_UNORM";
82 case VK_FORMAT_R8G8_UNORM: return "R8G8_UNORM";
83 case VK_FORMAT_A2B10G10R10_UNORM_PACK32: return "A2B10G10R10_UNORM_PACK32";
84 case VK_FORMAT_B4G4R4A4_UNORM_PACK16: return "B4G4R4A4_UNORM_PACK16";
85 case VK_FORMAT_R4G4B4A4_UNORM_PACK16: return "R4G4B4A4_UNORM_PACK16";
86 case VK_FORMAT_R32G32B32A32_SFLOAT: return "R32G32B32A32_SFLOAT";
87 case VK_FORMAT_R8G8B8A8_SRGB: return "R8G8B8A8_SRGB";
88 case VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK: return "ETC2_R8G8B8_UNORM_BLOCK";
89 case VK_FORMAT_R16_UNORM: return "R16_UNORM";
90 case VK_FORMAT_R16G16_UNORM: return "R16G16_UNORM";
91 case VK_FORMAT_R16G16B16A16_UNORM: return "R16G16B16A16_UNORM";
92 case VK_FORMAT_R16G16_SFLOAT: return "R16G16_SFLOAT";
93
94 default: return "Unknown";
95 }
96}
97
98#endif
Greg Daniel164a9f02016-02-22 09:56:40 -050099#endif