blob: 625bd90e8f5adc45b88c0d59cad0d3d1648f1c09 [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;
18 fMixedSamplesSupport = false;
19 fShaderPrecisionVaries = false;
20}
21
22static const char* shader_type_to_string(GrShaderType type) {
23 switch (type) {
24 case kVertex_GrShaderType:
25 return "vertex";
26 case kGeometry_GrShaderType:
27 return "geometry";
28 case kFragment_GrShaderType:
29 return "fragment";
30 }
31 return "";
32}
33
34static const char* precision_to_string(GrSLPrecision p) {
35 switch (p) {
36 case kLow_GrSLPrecision:
37 return "low";
38 case kMedium_GrSLPrecision:
39 return "medium";
40 case kHigh_GrSLPrecision:
41 return "high";
42 }
43 return "";
44}
45
46SkString GrShaderCaps::dump() const {
47 SkString r;
48 static const char* gNY[] = { "NO", "YES" };
49 r.appendf("Shader Derivative Support : %s\n", gNY[fShaderDerivativeSupport]);
50 r.appendf("Geometry Shader Support : %s\n", gNY[fGeometryShaderSupport]);
51 r.appendf("Path Rendering Support : %s\n", gNY[fPathRenderingSupport]);
52 r.appendf("Dst Read In Shader Support : %s\n", gNY[fDstReadInShaderSupport]);
53 r.appendf("Dual Source Blending Support : %s\n", gNY[fDualSourceBlendingSupport]);
54 r.appendf("Mixed Samples Support : %s\n", gNY[fMixedSamplesSupport]);
55
56 r.appendf("Shader Float Precisions (varies: %s):\n", gNY[fShaderPrecisionVaries]);
57
58 for (int s = 0; s < kGrShaderTypeCount; ++s) {
59 GrShaderType shaderType = static_cast<GrShaderType>(s);
60 r.appendf("\t%s:\n", shader_type_to_string(shaderType));
61 for (int p = 0; p < kGrSLPrecisionCount; ++p) {
62 if (fFloatPrecisions[s][p].supported()) {
63 GrSLPrecision precision = static_cast<GrSLPrecision>(p);
64 r.appendf("\t\t%s: log_low: %d log_high: %d bits: %d\n",
65 precision_to_string(precision),
66 fFloatPrecisions[s][p].fLogRangeLow,
67 fFloatPrecisions[s][p].fLogRangeHigh,
68 fFloatPrecisions[s][p].fBits);
69 }
70 }
71 }
72
73 return r;
74}
75
bsalomon4ee6bd82015-05-27 13:23:23 -070076void GrShaderCaps::applyOptionsOverrides(const GrContextOptions&) {
77 // Currently no overrides apply to shader caps.
78}
79
bsalomondc47ff72015-05-26 12:16:59 -070080///////////////////////////////////////////////////////////////////////////////
81
82GrCaps::GrCaps(const GrContextOptions& options) {
83 fMipMapSupport = false;
84 fNPOTTextureTileSupport = false;
85 fTwoSidedStencilSupport = false;
86 fStencilWrapOpsSupport = false;
87 fDiscardRenderTargetSupport = false;
88 fReuseScratchTextures = true;
89 fGpuTracingSupport = false;
90 fCompressedTexSubImageSupport = false;
91 fOversizedStencilSupport = false;
92 fTextureBarrierSupport = false;
93
94 fUseDrawInsteadOfClear = false;
95
96 fBlendEquationSupport = kBasic_BlendEquationSupport;
97 fMapBufferFlags = kNone_MapFlags;
98
99 fMaxRenderTargetSize = 0;
100 fMaxTextureSize = 0;
101 fMaxSampleCount = 0;
102
103 memset(fConfigRenderSupport, 0, sizeof(fConfigRenderSupport));
104 memset(fConfigTextureSupport, 0, sizeof(fConfigTextureSupport));
105
106 fSupressPrints = options.fSuppressPrints;
107 fDrawPathMasksToCompressedTextureSupport = options.fDrawPathToCompressedTexture;
108}
109
bsalomon4ee6bd82015-05-27 13:23:23 -0700110void GrCaps::applyOptionsOverrides(const GrContextOptions& options) {
111 fMaxTextureSize = SkTMin(fMaxTextureSize, options.fMaxTextureSizeOverride);
112}
113
bsalomondc47ff72015-05-26 12:16:59 -0700114static SkString map_flags_to_string(uint32_t flags) {
115 SkString str;
116 if (GrCaps::kNone_MapFlags == flags) {
117 str = "none";
118 } else {
119 SkASSERT(GrCaps::kCanMap_MapFlag & flags);
120 SkDEBUGCODE(flags &= ~GrCaps::kCanMap_MapFlag);
121 str = "can_map";
122
123 if (GrCaps::kSubset_MapFlag & flags) {
124 str.append(" partial");
125 } else {
126 str.append(" full");
127 }
128 SkDEBUGCODE(flags &= ~GrCaps::kSubset_MapFlag);
129 }
130 SkASSERT(0 == flags); // Make sure we handled all the flags.
131 return str;
132}
133
134SkString GrCaps::dump() const {
135 SkString r;
136 static const char* gNY[] = {"NO", "YES"};
137 r.appendf("MIP Map Support : %s\n", gNY[fMipMapSupport]);
138 r.appendf("NPOT Texture Tile Support : %s\n", gNY[fNPOTTextureTileSupport]);
139 r.appendf("Two Sided Stencil Support : %s\n", gNY[fTwoSidedStencilSupport]);
140 r.appendf("Stencil Wrap Ops Support : %s\n", gNY[fStencilWrapOpsSupport]);
141 r.appendf("Discard Render Target Support : %s\n", gNY[fDiscardRenderTargetSupport]);
142 r.appendf("Reuse Scratch Textures : %s\n", gNY[fReuseScratchTextures]);
143 r.appendf("Gpu Tracing Support : %s\n", gNY[fGpuTracingSupport]);
144 r.appendf("Compressed Update Support : %s\n", gNY[fCompressedTexSubImageSupport]);
145 r.appendf("Oversized Stencil Support : %s\n", gNY[fOversizedStencilSupport]);
146 r.appendf("Texture Barrier Support : %s\n", gNY[fTextureBarrierSupport]);
147 r.appendf("Draw Instead of Clear [workaround] : %s\n", gNY[fUseDrawInsteadOfClear]);
148
149 r.appendf("Max Texture Size : %d\n", fMaxTextureSize);
150 r.appendf("Max Render Target Size : %d\n", fMaxRenderTargetSize);
151 r.appendf("Max Sample Count : %d\n", fMaxSampleCount);
152
153 static const char* kBlendEquationSupportNames[] = {
154 "Basic",
155 "Advanced",
156 "Advanced Coherent",
157 };
158 GR_STATIC_ASSERT(0 == kBasic_BlendEquationSupport);
159 GR_STATIC_ASSERT(1 == kAdvanced_BlendEquationSupport);
160 GR_STATIC_ASSERT(2 == kAdvancedCoherent_BlendEquationSupport);
161 GR_STATIC_ASSERT(SK_ARRAY_COUNT(kBlendEquationSupportNames) == kLast_BlendEquationSupport + 1);
162
163 r.appendf("Blend Equation Support : %s\n",
164 kBlendEquationSupportNames[fBlendEquationSupport]);
165 r.appendf("Map Buffer Support : %s\n",
166 map_flags_to_string(fMapBufferFlags).c_str());
167
168 static const char* kConfigNames[] = {
169 "Unknown", // kUnknown_GrPixelConfig
170 "Alpha8", // kAlpha_8_GrPixelConfig,
171 "Index8", // kIndex_8_GrPixelConfig,
172 "RGB565", // kRGB_565_GrPixelConfig,
173 "RGBA444", // kRGBA_4444_GrPixelConfig,
174 "RGBA8888", // kRGBA_8888_GrPixelConfig,
175 "BGRA8888", // kBGRA_8888_GrPixelConfig,
176 "SRGBA8888",// kSRGBA_8888_GrPixelConfig,
177 "ETC1", // kETC1_GrPixelConfig,
178 "LATC", // kLATC_GrPixelConfig,
179 "R11EAC", // kR11_EAC_GrPixelConfig,
180 "ASTC12x12",// kASTC_12x12_GrPixelConfig,
181 "RGBAFloat",// kRGBA_float_GrPixelConfig
182 "AlphaHalf",// kAlpha_half_GrPixelConfig
183 "RGBAHalf", // kRGBA_half_GrPixelConfig
184 };
185 GR_STATIC_ASSERT(0 == kUnknown_GrPixelConfig);
186 GR_STATIC_ASSERT(1 == kAlpha_8_GrPixelConfig);
187 GR_STATIC_ASSERT(2 == kIndex_8_GrPixelConfig);
188 GR_STATIC_ASSERT(3 == kRGB_565_GrPixelConfig);
189 GR_STATIC_ASSERT(4 == kRGBA_4444_GrPixelConfig);
190 GR_STATIC_ASSERT(5 == kRGBA_8888_GrPixelConfig);
191 GR_STATIC_ASSERT(6 == kBGRA_8888_GrPixelConfig);
192 GR_STATIC_ASSERT(7 == kSRGBA_8888_GrPixelConfig);
193 GR_STATIC_ASSERT(8 == kETC1_GrPixelConfig);
194 GR_STATIC_ASSERT(9 == kLATC_GrPixelConfig);
195 GR_STATIC_ASSERT(10 == kR11_EAC_GrPixelConfig);
196 GR_STATIC_ASSERT(11 == kASTC_12x12_GrPixelConfig);
197 GR_STATIC_ASSERT(12 == kRGBA_float_GrPixelConfig);
198 GR_STATIC_ASSERT(13 == kAlpha_half_GrPixelConfig);
199 GR_STATIC_ASSERT(14 == kRGBA_half_GrPixelConfig);
200 GR_STATIC_ASSERT(SK_ARRAY_COUNT(kConfigNames) == kGrPixelConfigCnt);
201
202 SkASSERT(!fConfigRenderSupport[kUnknown_GrPixelConfig][0]);
203 SkASSERT(!fConfigRenderSupport[kUnknown_GrPixelConfig][1]);
204
205 for (size_t i = 1; i < SK_ARRAY_COUNT(kConfigNames); ++i) {
206 r.appendf("%s is renderable: %s, with MSAA: %s\n",
207 kConfigNames[i],
208 gNY[fConfigRenderSupport[i][0]],
209 gNY[fConfigRenderSupport[i][1]]);
210 }
211
212 SkASSERT(!fConfigTextureSupport[kUnknown_GrPixelConfig]);
213
214 for (size_t i = 1; i < SK_ARRAY_COUNT(kConfigNames); ++i) {
215 r.appendf("%s is uploadable to a texture: %s\n",
216 kConfigNames[i],
217 gNY[fConfigTextureSupport[i]]);
218 }
219
220 return r;
221}