blob: 46f49357c77d4d6fd09a25a63ff4a03ac606f99f [file] [log] [blame]
bsalomondc47ff72015-05-26 12:16:59 -07001
2/*
3 * Copyright 2015 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
7 */
8
9#include "GrCaps.h"
10#include "GrContextOptions.h"
11
12GrShaderCaps::GrShaderCaps() {
13 fShaderDerivativeSupport = false;
14 fGeometryShaderSupport = false;
15 fPathRenderingSupport = false;
16 fDstReadInShaderSupport = false;
17 fDualSourceBlendingSupport = false;
bsalomondc47ff72015-05-26 12:16:59 -070018 fShaderPrecisionVaries = false;
19}
20
21static const char* shader_type_to_string(GrShaderType type) {
22 switch (type) {
23 case kVertex_GrShaderType:
24 return "vertex";
25 case kGeometry_GrShaderType:
26 return "geometry";
27 case kFragment_GrShaderType:
28 return "fragment";
29 }
30 return "";
31}
32
33static const char* precision_to_string(GrSLPrecision p) {
34 switch (p) {
35 case kLow_GrSLPrecision:
36 return "low";
37 case kMedium_GrSLPrecision:
38 return "medium";
39 case kHigh_GrSLPrecision:
40 return "high";
41 }
42 return "";
43}
44
45SkString GrShaderCaps::dump() const {
46 SkString r;
47 static const char* gNY[] = { "NO", "YES" };
cdalton7e806f32015-11-11 15:16:07 -080048 r.appendf("Shader Derivative Support : %s\n", gNY[fShaderDerivativeSupport]);
49 r.appendf("Geometry Shader Support : %s\n", gNY[fGeometryShaderSupport]);
50 r.appendf("Path Rendering Support : %s\n", gNY[fPathRenderingSupport]);
51 r.appendf("Dst Read In Shader Support : %s\n", gNY[fDstReadInShaderSupport]);
52 r.appendf("Dual Source Blending Support : %s\n", gNY[fDualSourceBlendingSupport]);
bsalomondc47ff72015-05-26 12:16:59 -070053
cdalton7e806f32015-11-11 15:16:07 -080054 r.appendf("Shader Float Precisions (varies: %s):\n", gNY[fShaderPrecisionVaries]);
bsalomondc47ff72015-05-26 12:16:59 -070055
56 for (int s = 0; s < kGrShaderTypeCount; ++s) {
57 GrShaderType shaderType = static_cast<GrShaderType>(s);
58 r.appendf("\t%s:\n", shader_type_to_string(shaderType));
59 for (int p = 0; p < kGrSLPrecisionCount; ++p) {
60 if (fFloatPrecisions[s][p].supported()) {
61 GrSLPrecision precision = static_cast<GrSLPrecision>(p);
62 r.appendf("\t\t%s: log_low: %d log_high: %d bits: %d\n",
63 precision_to_string(precision),
64 fFloatPrecisions[s][p].fLogRangeLow,
65 fFloatPrecisions[s][p].fLogRangeHigh,
66 fFloatPrecisions[s][p].fBits);
67 }
68 }
69 }
70
71 return r;
72}
73
cdalton6fd158e2015-05-27 15:08:33 -070074void GrShaderCaps::applyOptionsOverrides(const GrContextOptions& options) {
75 fDualSourceBlendingSupport = fDualSourceBlendingSupport && !options.fSuppressDualSourceBlending;
egdanielb7e7d572015-11-04 04:23:53 -080076 this->onApplyOptionsOverrides(options);
bsalomon4ee6bd82015-05-27 13:23:23 -070077}
78
bsalomondc47ff72015-05-26 12:16:59 -070079///////////////////////////////////////////////////////////////////////////////
80
81GrCaps::GrCaps(const GrContextOptions& options) {
82 fMipMapSupport = false;
83 fNPOTTextureTileSupport = false;
84 fTwoSidedStencilSupport = false;
85 fStencilWrapOpsSupport = false;
86 fDiscardRenderTargetSupport = false;
87 fReuseScratchTextures = true;
robertphillips1b8e1b52015-06-24 06:54:10 -070088 fReuseScratchBuffers = true;
bsalomondc47ff72015-05-26 12:16:59 -070089 fGpuTracingSupport = false;
90 fCompressedTexSubImageSupport = false;
91 fOversizedStencilSupport = false;
92 fTextureBarrierSupport = false;
egdanieleed519e2016-01-15 11:36:18 -080093 fUsesMixedSamples = false;
joshualitt58001552015-06-26 12:46:36 -070094 fSupportsInstancedDraws = false;
egdaniel51c8d402015-08-06 10:54:13 -070095 fFullClearIsFree = false;
bsalomon7dea7b72015-08-19 08:26:51 -070096 fMustClearUploadedBufferData = false;
bsalomondc47ff72015-05-26 12:16:59 -070097
98 fUseDrawInsteadOfClear = false;
99
100 fBlendEquationSupport = kBasic_BlendEquationSupport;
cdalton1dd05422015-06-12 09:01:18 -0700101 fAdvBlendEqBlacklist = 0;
102
bsalomondc47ff72015-05-26 12:16:59 -0700103 fMapBufferFlags = kNone_MapFlags;
104
egdanielff1d5472015-09-10 08:37:20 -0700105 fMaxRenderTargetSize = 1;
106 fMaxTextureSize = 1;
egdanieleed519e2016-01-15 11:36:18 -0800107 fMaxColorSampleCount = 0;
108 fMaxStencilSampleCount = 0;
cdaltonaf8bc7d2016-02-05 09:35:20 -0800109 fMaxRasterSamples = 0;
bsalomondc47ff72015-05-26 12:16:59 -0700110
robertphillipscaef3452015-11-11 13:18:11 -0800111 fSuppressPrints = options.fSuppressPrints;
112 fImmediateFlush = options.fImmediateMode;
bsalomondc47ff72015-05-26 12:16:59 -0700113 fDrawPathMasksToCompressedTextureSupport = options.fDrawPathToCompressedTexture;
joshualitt7224c862015-05-29 06:46:47 -0700114 fGeometryBufferMapThreshold = options.fGeometryBufferMapThreshold;
joshualitt83bc2292015-06-18 14:18:02 -0700115 fUseDrawInsteadOfPartialRenderTargetWrite = options.fUseDrawInsteadOfPartialRenderTargetWrite;
robertphillips63926682015-08-20 09:39:02 -0700116
117 fPreferVRAMUseOverFlushes = true;
bsalomondc47ff72015-05-26 12:16:59 -0700118}
119
bsalomon4ee6bd82015-05-27 13:23:23 -0700120void GrCaps::applyOptionsOverrides(const GrContextOptions& options) {
121 fMaxTextureSize = SkTMin(fMaxTextureSize, options.fMaxTextureSizeOverride);
bsalomon8c07b7a2015-11-02 11:36:52 -0800122 // If the max tile override is zero, it means we should use the max texture size.
123 if (!options.fMaxTileSizeOverride || options.fMaxTileSizeOverride > fMaxTextureSize) {
124 fMaxTileSize = fMaxTextureSize;
125 } else {
126 fMaxTileSize = options.fMaxTileSizeOverride;
127 }
egdanielb7e7d572015-11-04 04:23:53 -0800128 this->onApplyOptionsOverrides(options);
bsalomon4ee6bd82015-05-27 13:23:23 -0700129}
130
bsalomondc47ff72015-05-26 12:16:59 -0700131static SkString map_flags_to_string(uint32_t flags) {
132 SkString str;
133 if (GrCaps::kNone_MapFlags == flags) {
134 str = "none";
135 } else {
136 SkASSERT(GrCaps::kCanMap_MapFlag & flags);
137 SkDEBUGCODE(flags &= ~GrCaps::kCanMap_MapFlag);
138 str = "can_map";
139
140 if (GrCaps::kSubset_MapFlag & flags) {
141 str.append(" partial");
142 } else {
143 str.append(" full");
144 }
145 SkDEBUGCODE(flags &= ~GrCaps::kSubset_MapFlag);
146 }
147 SkASSERT(0 == flags); // Make sure we handled all the flags.
148 return str;
149}
150
151SkString GrCaps::dump() const {
152 SkString r;
153 static const char* gNY[] = {"NO", "YES"};
154 r.appendf("MIP Map Support : %s\n", gNY[fMipMapSupport]);
155 r.appendf("NPOT Texture Tile Support : %s\n", gNY[fNPOTTextureTileSupport]);
156 r.appendf("Two Sided Stencil Support : %s\n", gNY[fTwoSidedStencilSupport]);
157 r.appendf("Stencil Wrap Ops Support : %s\n", gNY[fStencilWrapOpsSupport]);
158 r.appendf("Discard Render Target Support : %s\n", gNY[fDiscardRenderTargetSupport]);
159 r.appendf("Reuse Scratch Textures : %s\n", gNY[fReuseScratchTextures]);
robertphillips1b8e1b52015-06-24 06:54:10 -0700160 r.appendf("Reuse Scratch Buffers : %s\n", gNY[fReuseScratchBuffers]);
bsalomondc47ff72015-05-26 12:16:59 -0700161 r.appendf("Gpu Tracing Support : %s\n", gNY[fGpuTracingSupport]);
162 r.appendf("Compressed Update Support : %s\n", gNY[fCompressedTexSubImageSupport]);
163 r.appendf("Oversized Stencil Support : %s\n", gNY[fOversizedStencilSupport]);
164 r.appendf("Texture Barrier Support : %s\n", gNY[fTextureBarrierSupport]);
egdanieleed519e2016-01-15 11:36:18 -0800165 r.appendf("Uses Mixed Samples : %s\n", gNY[fUsesMixedSamples]);
joshualitt58001552015-06-26 12:46:36 -0700166 r.appendf("Supports instanced draws : %s\n", gNY[fSupportsInstancedDraws]);
egdaniel51c8d402015-08-06 10:54:13 -0700167 r.appendf("Full screen clear is free : %s\n", gNY[fFullClearIsFree]);
bsalomon7dea7b72015-08-19 08:26:51 -0700168 r.appendf("Must clear buffer memory : %s\n", gNY[fMustClearUploadedBufferData]);
bsalomondc47ff72015-05-26 12:16:59 -0700169 r.appendf("Draw Instead of Clear [workaround] : %s\n", gNY[fUseDrawInsteadOfClear]);
joshualitt83bc2292015-06-18 14:18:02 -0700170 r.appendf("Draw Instead of TexSubImage [workaround] : %s\n",
171 gNY[fUseDrawInsteadOfPartialRenderTargetWrite]);
robertphillips63926682015-08-20 09:39:02 -0700172 r.appendf("Prefer VRAM Use over flushes [workaround] : %s\n", gNY[fPreferVRAMUseOverFlushes]);
173
cdalton1dd05422015-06-12 09:01:18 -0700174 if (this->advancedBlendEquationSupport()) {
175 r.appendf("Advanced Blend Equation Blacklist : 0x%x\n", fAdvBlendEqBlacklist);
176 }
bsalomondc47ff72015-05-26 12:16:59 -0700177
178 r.appendf("Max Texture Size : %d\n", fMaxTextureSize);
bsalomondc47ff72015-05-26 12:16:59 -0700179 r.appendf("Max Render Target Size : %d\n", fMaxRenderTargetSize);
egdanieleed519e2016-01-15 11:36:18 -0800180 r.appendf("Max Color Sample Count : %d\n", fMaxColorSampleCount);
181 r.appendf("Max Stencil Sample Count : %d\n", fMaxStencilSampleCount);
cdaltonaf8bc7d2016-02-05 09:35:20 -0800182 r.appendf("Max Raster Samples : %d\n", fMaxRasterSamples);
bsalomondc47ff72015-05-26 12:16:59 -0700183
184 static const char* kBlendEquationSupportNames[] = {
185 "Basic",
186 "Advanced",
187 "Advanced Coherent",
188 };
189 GR_STATIC_ASSERT(0 == kBasic_BlendEquationSupport);
190 GR_STATIC_ASSERT(1 == kAdvanced_BlendEquationSupport);
191 GR_STATIC_ASSERT(2 == kAdvancedCoherent_BlendEquationSupport);
192 GR_STATIC_ASSERT(SK_ARRAY_COUNT(kBlendEquationSupportNames) == kLast_BlendEquationSupport + 1);
193
194 r.appendf("Blend Equation Support : %s\n",
195 kBlendEquationSupportNames[fBlendEquationSupport]);
196 r.appendf("Map Buffer Support : %s\n",
197 map_flags_to_string(fMapBufferFlags).c_str());
198
199 static const char* kConfigNames[] = {
200 "Unknown", // kUnknown_GrPixelConfig
201 "Alpha8", // kAlpha_8_GrPixelConfig,
202 "Index8", // kIndex_8_GrPixelConfig,
203 "RGB565", // kRGB_565_GrPixelConfig,
204 "RGBA444", // kRGBA_4444_GrPixelConfig,
205 "RGBA8888", // kRGBA_8888_GrPixelConfig,
206 "BGRA8888", // kBGRA_8888_GrPixelConfig,
207 "SRGBA8888",// kSRGBA_8888_GrPixelConfig,
208 "ETC1", // kETC1_GrPixelConfig,
209 "LATC", // kLATC_GrPixelConfig,
210 "R11EAC", // kR11_EAC_GrPixelConfig,
211 "ASTC12x12",// kASTC_12x12_GrPixelConfig,
212 "RGBAFloat",// kRGBA_float_GrPixelConfig
213 "AlphaHalf",// kAlpha_half_GrPixelConfig
214 "RGBAHalf", // kRGBA_half_GrPixelConfig
215 };
216 GR_STATIC_ASSERT(0 == kUnknown_GrPixelConfig);
217 GR_STATIC_ASSERT(1 == kAlpha_8_GrPixelConfig);
218 GR_STATIC_ASSERT(2 == kIndex_8_GrPixelConfig);
219 GR_STATIC_ASSERT(3 == kRGB_565_GrPixelConfig);
220 GR_STATIC_ASSERT(4 == kRGBA_4444_GrPixelConfig);
221 GR_STATIC_ASSERT(5 == kRGBA_8888_GrPixelConfig);
222 GR_STATIC_ASSERT(6 == kBGRA_8888_GrPixelConfig);
223 GR_STATIC_ASSERT(7 == kSRGBA_8888_GrPixelConfig);
224 GR_STATIC_ASSERT(8 == kETC1_GrPixelConfig);
225 GR_STATIC_ASSERT(9 == kLATC_GrPixelConfig);
226 GR_STATIC_ASSERT(10 == kR11_EAC_GrPixelConfig);
227 GR_STATIC_ASSERT(11 == kASTC_12x12_GrPixelConfig);
228 GR_STATIC_ASSERT(12 == kRGBA_float_GrPixelConfig);
229 GR_STATIC_ASSERT(13 == kAlpha_half_GrPixelConfig);
230 GR_STATIC_ASSERT(14 == kRGBA_half_GrPixelConfig);
231 GR_STATIC_ASSERT(SK_ARRAY_COUNT(kConfigNames) == kGrPixelConfigCnt);
232
bsalomon41e4384e2016-01-08 09:12:44 -0800233 SkASSERT(!this->isConfigRenderable(kUnknown_GrPixelConfig, false));
234 SkASSERT(!this->isConfigRenderable(kUnknown_GrPixelConfig, true));
bsalomondc47ff72015-05-26 12:16:59 -0700235
236 for (size_t i = 1; i < SK_ARRAY_COUNT(kConfigNames); ++i) {
bsalomon41e4384e2016-01-08 09:12:44 -0800237 GrPixelConfig config = static_cast<GrPixelConfig>(i);
bsalomondc47ff72015-05-26 12:16:59 -0700238 r.appendf("%s is renderable: %s, with MSAA: %s\n",
239 kConfigNames[i],
bsalomon41e4384e2016-01-08 09:12:44 -0800240 gNY[this->isConfigRenderable(config, false)],
241 gNY[this->isConfigRenderable(config, true)]);
bsalomondc47ff72015-05-26 12:16:59 -0700242 }
243
bsalomon41e4384e2016-01-08 09:12:44 -0800244 SkASSERT(!this->isConfigTexturable(kUnknown_GrPixelConfig));
bsalomondc47ff72015-05-26 12:16:59 -0700245
246 for (size_t i = 1; i < SK_ARRAY_COUNT(kConfigNames); ++i) {
bsalomon41e4384e2016-01-08 09:12:44 -0800247 GrPixelConfig config = static_cast<GrPixelConfig>(i);
bsalomondc47ff72015-05-26 12:16:59 -0700248 r.appendf("%s is uploadable to a texture: %s\n",
249 kConfigNames[i],
bsalomon41e4384e2016-01-08 09:12:44 -0800250 gNY[this->isConfigTexturable(config)]);
bsalomondc47ff72015-05-26 12:16:59 -0700251 }
252
253 return r;
254}