OLD | NEW |
1 | 1 |
2 /* | 2 /* |
3 * Copyright 2015 Google Inc. | 3 * Copyright 2015 Google Inc. |
4 * | 4 * |
5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
7 */ | 7 */ |
8 | 8 |
9 #include "GrCaps.h" | 9 #include "GrCaps.h" |
10 #include "GrContextOptions.h" | 10 #include "GrContextOptions.h" |
11 | 11 |
12 GrShaderCaps::GrShaderCaps() { | 12 GrShaderCaps::GrShaderCaps() { |
13 fShaderDerivativeSupport = false; | 13 fShaderDerivativeSupport = false; |
14 fGeometryShaderSupport = false; | 14 fGeometryShaderSupport = false; |
15 fPathRenderingSupport = false; | 15 fPathRenderingSupport = false; |
16 fDstReadInShaderSupport = false; | 16 fDstReadInShaderSupport = false; |
17 fDualSourceBlendingSupport = false; | 17 fDualSourceBlendingSupport = false; |
18 fMixedSamplesSupport = false; | |
19 fProgrammableSampleLocationsSupport = false; | 18 fProgrammableSampleLocationsSupport = false; |
20 fShaderPrecisionVaries = false; | 19 fShaderPrecisionVaries = false; |
21 } | 20 } |
22 | 21 |
23 static const char* shader_type_to_string(GrShaderType type) { | 22 static const char* shader_type_to_string(GrShaderType type) { |
24 switch (type) { | 23 switch (type) { |
25 case kVertex_GrShaderType: | 24 case kVertex_GrShaderType: |
26 return "vertex"; | 25 return "vertex"; |
27 case kGeometry_GrShaderType: | 26 case kGeometry_GrShaderType: |
28 return "geometry"; | 27 return "geometry"; |
(...skipping 16 matching lines...) Expand all Loading... |
45 } | 44 } |
46 | 45 |
47 SkString GrShaderCaps::dump() const { | 46 SkString GrShaderCaps::dump() const { |
48 SkString r; | 47 SkString r; |
49 static const char* gNY[] = { "NO", "YES" }; | 48 static const char* gNY[] = { "NO", "YES" }; |
50 r.appendf("Shader Derivative Support : %s\n", gNY[fShaderDerivat
iveSupport]); | 49 r.appendf("Shader Derivative Support : %s\n", gNY[fShaderDerivat
iveSupport]); |
51 r.appendf("Geometry Shader Support : %s\n", gNY[fGeometryShade
rSupport]); | 50 r.appendf("Geometry Shader Support : %s\n", gNY[fGeometryShade
rSupport]); |
52 r.appendf("Path Rendering Support : %s\n", gNY[fPathRendering
Support]); | 51 r.appendf("Path Rendering Support : %s\n", gNY[fPathRendering
Support]); |
53 r.appendf("Dst Read In Shader Support : %s\n", gNY[fDstReadInShad
erSupport]); | 52 r.appendf("Dst Read In Shader Support : %s\n", gNY[fDstReadInShad
erSupport]); |
54 r.appendf("Dual Source Blending Support : %s\n", gNY[fDualSourceBle
ndingSupport]); | 53 r.appendf("Dual Source Blending Support : %s\n", gNY[fDualSourceBle
ndingSupport]); |
55 r.appendf("Mixed Samples Support : %s\n", gNY[fMixedSamplesS
upport]); | |
56 r.appendf("Programmable Sample Locations Support : %s\n", gNY[fProgrammableS
ampleLocationsSupport]); | 54 r.appendf("Programmable Sample Locations Support : %s\n", gNY[fProgrammableS
ampleLocationsSupport]); |
57 | 55 |
58 r.appendf("Shader Float Precisions (varies: %s) :\n", gNY[fShaderPrecisionV
aries]); | 56 r.appendf("Shader Float Precisions (varies: %s) :\n", gNY[fShaderPrecisionV
aries]); |
59 | 57 |
60 for (int s = 0; s < kGrShaderTypeCount; ++s) { | 58 for (int s = 0; s < kGrShaderTypeCount; ++s) { |
61 GrShaderType shaderType = static_cast<GrShaderType>(s); | 59 GrShaderType shaderType = static_cast<GrShaderType>(s); |
62 r.appendf("\t%s:\n", shader_type_to_string(shaderType)); | 60 r.appendf("\t%s:\n", shader_type_to_string(shaderType)); |
63 for (int p = 0; p < kGrSLPrecisionCount; ++p) { | 61 for (int p = 0; p < kGrSLPrecisionCount; ++p) { |
64 if (fFloatPrecisions[s][p].supported()) { | 62 if (fFloatPrecisions[s][p].supported()) { |
65 GrSLPrecision precision = static_cast<GrSLPrecision>(p); | 63 GrSLPrecision precision = static_cast<GrSLPrecision>(p); |
(...skipping 21 matching lines...) Expand all Loading... |
87 fNPOTTextureTileSupport = false; | 85 fNPOTTextureTileSupport = false; |
88 fTwoSidedStencilSupport = false; | 86 fTwoSidedStencilSupport = false; |
89 fStencilWrapOpsSupport = false; | 87 fStencilWrapOpsSupport = false; |
90 fDiscardRenderTargetSupport = false; | 88 fDiscardRenderTargetSupport = false; |
91 fReuseScratchTextures = true; | 89 fReuseScratchTextures = true; |
92 fReuseScratchBuffers = true; | 90 fReuseScratchBuffers = true; |
93 fGpuTracingSupport = false; | 91 fGpuTracingSupport = false; |
94 fCompressedTexSubImageSupport = false; | 92 fCompressedTexSubImageSupport = false; |
95 fOversizedStencilSupport = false; | 93 fOversizedStencilSupport = false; |
96 fTextureBarrierSupport = false; | 94 fTextureBarrierSupport = false; |
| 95 fMixedSamplesSupport = false; |
97 fSupportsInstancedDraws = false; | 96 fSupportsInstancedDraws = false; |
98 fFullClearIsFree = false; | 97 fFullClearIsFree = false; |
99 fMustClearUploadedBufferData = false; | 98 fMustClearUploadedBufferData = false; |
100 | 99 |
101 fUseDrawInsteadOfClear = false; | 100 fUseDrawInsteadOfClear = false; |
102 | 101 |
103 fBlendEquationSupport = kBasic_BlendEquationSupport; | 102 fBlendEquationSupport = kBasic_BlendEquationSupport; |
104 fAdvBlendEqBlacklist = 0; | 103 fAdvBlendEqBlacklist = 0; |
105 | 104 |
106 fMapBufferFlags = kNone_MapFlags; | 105 fMapBufferFlags = kNone_MapFlags; |
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
158 r.appendf("NPOT Texture Tile Support : %s\n", gNY[fNPOTTextureTileS
upport]); | 157 r.appendf("NPOT Texture Tile Support : %s\n", gNY[fNPOTTextureTileS
upport]); |
159 r.appendf("Two Sided Stencil Support : %s\n", gNY[fTwoSidedStencilS
upport]); | 158 r.appendf("Two Sided Stencil Support : %s\n", gNY[fTwoSidedStencilS
upport]); |
160 r.appendf("Stencil Wrap Ops Support : %s\n", gNY[fStencilWrapOpsSu
pport]); | 159 r.appendf("Stencil Wrap Ops Support : %s\n", gNY[fStencilWrapOpsSu
pport]); |
161 r.appendf("Discard Render Target Support : %s\n", gNY[fDiscardRenderTar
getSupport]); | 160 r.appendf("Discard Render Target Support : %s\n", gNY[fDiscardRenderTar
getSupport]); |
162 r.appendf("Reuse Scratch Textures : %s\n", gNY[fReuseScratchText
ures]); | 161 r.appendf("Reuse Scratch Textures : %s\n", gNY[fReuseScratchText
ures]); |
163 r.appendf("Reuse Scratch Buffers : %s\n", gNY[fReuseScratchBuff
ers]); | 162 r.appendf("Reuse Scratch Buffers : %s\n", gNY[fReuseScratchBuff
ers]); |
164 r.appendf("Gpu Tracing Support : %s\n", gNY[fGpuTracingSuppor
t]); | 163 r.appendf("Gpu Tracing Support : %s\n", gNY[fGpuTracingSuppor
t]); |
165 r.appendf("Compressed Update Support : %s\n", gNY[fCompressedTexSub
ImageSupport]); | 164 r.appendf("Compressed Update Support : %s\n", gNY[fCompressedTexSub
ImageSupport]); |
166 r.appendf("Oversized Stencil Support : %s\n", gNY[fOversizedStencil
Support]); | 165 r.appendf("Oversized Stencil Support : %s\n", gNY[fOversizedStencil
Support]); |
167 r.appendf("Texture Barrier Support : %s\n", gNY[fTextureBarrierSu
pport]); | 166 r.appendf("Texture Barrier Support : %s\n", gNY[fTextureBarrierSu
pport]); |
| 167 r.appendf("Mixed Samples Support : %s\n", gNY[fMixedSamplesSupp
ort]); |
168 r.appendf("Supports instanced draws : %s\n", gNY[fSupportsInstance
dDraws]); | 168 r.appendf("Supports instanced draws : %s\n", gNY[fSupportsInstance
dDraws]); |
169 r.appendf("Full screen clear is free : %s\n", gNY[fFullClearIsFree]
); | 169 r.appendf("Full screen clear is free : %s\n", gNY[fFullClearIsFree]
); |
170 r.appendf("Must clear buffer memory : %s\n", gNY[fMustClearUploade
dBufferData]); | 170 r.appendf("Must clear buffer memory : %s\n", gNY[fMustClearUploade
dBufferData]); |
171 r.appendf("Draw Instead of Clear [workaround] : %s\n", gNY[fUseDrawInsteadOf
Clear]); | 171 r.appendf("Draw Instead of Clear [workaround] : %s\n", gNY[fUseDrawInsteadOf
Clear]); |
172 r.appendf("Draw Instead of TexSubImage [workaround] : %s\n", | 172 r.appendf("Draw Instead of TexSubImage [workaround] : %s\n", |
173 gNY[fUseDrawInsteadOfPartialRenderTargetWrite]); | 173 gNY[fUseDrawInsteadOfPartialRenderTargetWrite]); |
174 r.appendf("Prefer VRAM Use over flushes [workaround] : %s\n", gNY[fPreferVRA
MUseOverFlushes]); | 174 r.appendf("Prefer VRAM Use over flushes [workaround] : %s\n", gNY[fPreferVRA
MUseOverFlushes]); |
175 | 175 |
176 if (this->advancedBlendEquationSupport()) { | 176 if (this->advancedBlendEquationSupport()) { |
177 r.appendf("Advanced Blend Equation Blacklist : 0x%x\n", fAdvBlendEqBlac
klist); | 177 r.appendf("Advanced Blend Equation Blacklist : 0x%x\n", fAdvBlendEqBlac
klist); |
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
243 SkASSERT(!fConfigTextureSupport[kUnknown_GrPixelConfig]); | 243 SkASSERT(!fConfigTextureSupport[kUnknown_GrPixelConfig]); |
244 | 244 |
245 for (size_t i = 1; i < SK_ARRAY_COUNT(kConfigNames); ++i) { | 245 for (size_t i = 1; i < SK_ARRAY_COUNT(kConfigNames); ++i) { |
246 r.appendf("%s is uploadable to a texture: %s\n", | 246 r.appendf("%s is uploadable to a texture: %s\n", |
247 kConfigNames[i], | 247 kConfigNames[i], |
248 gNY[fConfigTextureSupport[i]]); | 248 gNY[fConfigTextureSupport[i]]); |
249 } | 249 } |
250 | 250 |
251 return r; | 251 return r; |
252 } | 252 } |
OLD | NEW |