2015-06-24 13:59:57 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2012 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2016-11-29 18:43:05 +00:00
|
|
|
#ifndef GrShaderCaps_DEFINED
|
|
|
|
#define GrShaderCaps_DEFINED
|
2015-06-24 13:59:57 +00:00
|
|
|
|
2016-11-29 18:43:05 +00:00
|
|
|
#include "../private/GrSwizzle.h"
|
|
|
|
#include "../private/GrGLSL.h"
|
2015-06-24 13:59:57 +00:00
|
|
|
|
2016-11-11 20:16:46 +00:00
|
|
|
namespace SkSL {
|
2016-11-29 20:27:52 +00:00
|
|
|
class ShaderCapsFactory;
|
2016-11-11 20:16:46 +00:00
|
|
|
}
|
2016-11-29 18:43:05 +00:00
|
|
|
struct GrContextOptions;
|
2017-08-10 14:23:25 +00:00
|
|
|
class SkJSONWriter;
|
2016-11-11 20:16:46 +00:00
|
|
|
|
2016-11-29 18:43:05 +00:00
|
|
|
class GrShaderCaps : public SkRefCnt {
|
2015-06-24 13:59:57 +00:00
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Indicates how GLSL must interact with advanced blend equations. The KHR extension requires
|
|
|
|
* special layout qualifiers in the fragment shader.
|
|
|
|
*/
|
|
|
|
enum AdvBlendEqInteraction {
|
|
|
|
kNotSupported_AdvBlendEqInteraction, //<! No _blend_equation_advanced extension
|
|
|
|
kAutomatic_AdvBlendEqInteraction, //<! No interaction required
|
|
|
|
kGeneralEnable_AdvBlendEqInteraction, //<! layout(blend_support_all_equations) out
|
|
|
|
kSpecificEnables_AdvBlendEqInteraction, //<! Specific layout qualifiers per equation
|
|
|
|
|
|
|
|
kLast_AdvBlendEqInteraction = kSpecificEnables_AdvBlendEqInteraction
|
|
|
|
};
|
|
|
|
|
2016-11-29 18:43:05 +00:00
|
|
|
GrShaderCaps(const GrContextOptions&);
|
|
|
|
|
2017-08-10 14:23:25 +00:00
|
|
|
void dumpJSON(SkJSONWriter*) const;
|
2016-11-29 18:43:05 +00:00
|
|
|
|
|
|
|
bool shaderDerivativeSupport() const { return fShaderDerivativeSupport; }
|
|
|
|
bool geometryShaderSupport() const { return fGeometryShaderSupport; }
|
2017-10-06 17:57:51 +00:00
|
|
|
bool gsInvocationsSupport() const { return fGSInvocationsSupport; }
|
2016-11-29 18:43:05 +00:00
|
|
|
bool pathRenderingSupport() const { return fPathRenderingSupport; }
|
|
|
|
bool dstReadInShaderSupport() const { return fDstReadInShaderSupport; }
|
|
|
|
bool dualSourceBlendingSupport() const { return fDualSourceBlendingSupport; }
|
|
|
|
bool integerSupport() const { return fIntegerSupport; }
|
|
|
|
bool texelBufferSupport() const { return fTexelBufferSupport; }
|
|
|
|
int imageLoadStoreSupport() const { return fImageLoadStoreSupport; }
|
|
|
|
|
2015-06-24 13:59:57 +00:00
|
|
|
/**
|
|
|
|
* Some helper functions for encapsulating various extensions to read FB Buffer on openglES
|
|
|
|
*
|
|
|
|
* TODO(joshualitt) On desktop opengl 4.2+ we can achieve something similar to this effect
|
|
|
|
*/
|
|
|
|
bool fbFetchSupport() const { return fFBFetchSupport; }
|
|
|
|
|
|
|
|
bool fbFetchNeedsCustomOutput() const { return fFBFetchNeedsCustomOutput; }
|
|
|
|
|
2015-10-22 15:20:00 +00:00
|
|
|
const char* versionDeclString() const { return fVersionDeclString; }
|
|
|
|
|
2015-06-24 13:59:57 +00:00
|
|
|
const char* fbFetchColorName() const { return fFBFetchColorName; }
|
|
|
|
|
|
|
|
const char* fbFetchExtensionString() const { return fFBFetchExtensionString; }
|
|
|
|
|
|
|
|
bool dropsTileOnZeroDivide() const { return fDropsTileOnZeroDivide; }
|
|
|
|
|
2016-02-12 20:14:06 +00:00
|
|
|
bool flatInterpolationSupport() const { return fFlatInterpolationSupport; }
|
|
|
|
|
2017-09-15 16:40:03 +00:00
|
|
|
bool preferFlatInterpolation() const { return fPreferFlatInterpolation; }
|
|
|
|
|
2016-02-12 20:14:06 +00:00
|
|
|
bool noperspectiveInterpolationSupport() const { return fNoPerspectiveInterpolationSupport; }
|
|
|
|
|
2016-03-11 18:07:37 +00:00
|
|
|
bool externalTextureSupport() const { return fExternalTextureSupport; }
|
|
|
|
|
2016-04-11 20:02:05 +00:00
|
|
|
bool texelFetchSupport() const { return fTexelFetchSupport; }
|
2016-03-11 22:07:38 +00:00
|
|
|
|
2017-05-31 18:51:23 +00:00
|
|
|
bool vertexIDSupport() const { return fVertexIDSupport; }
|
|
|
|
|
2017-11-16 01:27:09 +00:00
|
|
|
bool floatIs32Bits() const { return fFloatIs32Bits; }
|
|
|
|
|
|
|
|
bool halfIs32Bits() const { return fHalfIs32Bits; }
|
|
|
|
|
2015-06-24 13:59:57 +00:00
|
|
|
AdvBlendEqInteraction advBlendEqInteraction() const { return fAdvBlendEqInteraction; }
|
|
|
|
|
|
|
|
bool mustEnableAdvBlendEqs() const {
|
|
|
|
return fAdvBlendEqInteraction >= kGeneralEnable_AdvBlendEqInteraction;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool mustEnableSpecificAdvBlendEqs() const {
|
|
|
|
return fAdvBlendEqInteraction == kSpecificEnables_AdvBlendEqInteraction;
|
|
|
|
}
|
2016-03-29 16:03:52 +00:00
|
|
|
|
2015-06-24 13:59:57 +00:00
|
|
|
bool mustDeclareFragmentShaderOutput() const {
|
|
|
|
return fGLSLGeneration > k110_GrGLSLGeneration;
|
|
|
|
}
|
|
|
|
|
2015-10-21 14:14:17 +00:00
|
|
|
bool usesPrecisionModifiers() const { return fUsesPrecisionModifiers; }
|
|
|
|
|
2017-01-20 15:45:49 +00:00
|
|
|
// Returns whether we can use the glsl function any() in our shader code.
|
2015-10-22 15:20:00 +00:00
|
|
|
bool canUseAnyFunctionInShader() const { return fCanUseAnyFunctionInShader; }
|
|
|
|
|
2015-11-11 14:27:20 +00:00
|
|
|
bool canUseMinAndAbsTogether() const { return fCanUseMinAndAbsTogether; }
|
|
|
|
|
2017-08-07 18:38:22 +00:00
|
|
|
bool canUseFractForNegativeValues() const { return fCanUseFractForNegativeValues; }
|
|
|
|
|
2015-11-11 14:27:20 +00:00
|
|
|
bool mustForceNegatedAtanParamToFloat() const { return fMustForceNegatedAtanParamToFloat; }
|
|
|
|
|
2017-01-20 15:45:49 +00:00
|
|
|
// Returns whether a device incorrectly implements atan(y,x) as atan(y/x)
|
|
|
|
bool atan2ImplementedAsAtanYOverX() const { return fAtan2ImplementedAsAtanYOverX; }
|
|
|
|
|
2017-12-01 21:19:43 +00:00
|
|
|
// If this returns true some operation (could be a no op) must be called between floor and abs
|
|
|
|
// to make sure the driver compiler doesn't inline them together which can cause a driver bug in
|
|
|
|
// the shader.
|
|
|
|
bool mustDoOpBetweenFloorAndAbs() const { return fMustDoOpBetweenFloorAndAbs; }
|
|
|
|
|
2018-01-16 13:52:29 +00:00
|
|
|
// If false, SkSL uses a workaround so that sk_FragCoord doesn't actually query gl_FragCoord
|
|
|
|
bool canUseFragCoord() const { return fCanUseFragCoord; }
|
|
|
|
|
2018-01-22 13:43:38 +00:00
|
|
|
// If true interpolated vertex shader outputs are inaccurate.
|
|
|
|
bool interpolantsAreInaccurate() const { return fInterpolantsAreInaccurate; }
|
|
|
|
|
2018-03-07 14:46:10 +00:00
|
|
|
// If true, short ints can't represent every integer in the 16-bit two's complement range as
|
|
|
|
// required by the spec. SKSL will always emit full ints.
|
|
|
|
bool incompleteShortIntPrecision() const { return fIncompleteShortIntPrecision; }
|
|
|
|
|
2016-08-17 17:59:00 +00:00
|
|
|
bool requiresLocalOutputColorForFBFetch() const { return fRequiresLocalOutputColorForFBFetch; }
|
|
|
|
|
2017-05-25 15:34:38 +00:00
|
|
|
bool mustObfuscateUniformColor() const { return fMustObfuscateUniformColor; }
|
|
|
|
|
2017-08-01 18:46:18 +00:00
|
|
|
// The D3D shader compiler, when targeting PS 3.0 (ie within ANGLE) fails to compile certain
|
|
|
|
// constructs. See detailed comments in GrGLCaps.cpp.
|
|
|
|
bool mustGuardDivisionEvenAfterExplicitZeroCheck() const {
|
|
|
|
return fMustGuardDivisionEvenAfterExplicitZeroCheck;
|
|
|
|
}
|
|
|
|
|
2015-11-02 14:22:44 +00:00
|
|
|
// Returns the string of an extension that must be enabled in the shader to support
|
|
|
|
// derivatives. If nullptr is returned then no extension needs to be enabled. Before calling
|
|
|
|
// this function, the caller should check that shaderDerivativeSupport exists.
|
|
|
|
const char* shaderDerivativeExtensionString() const {
|
|
|
|
SkASSERT(this->shaderDerivativeSupport());
|
|
|
|
return fShaderDerivativeExtensionString;
|
|
|
|
}
|
2016-02-22 15:55:44 +00:00
|
|
|
|
2018-01-11 05:46:14 +00:00
|
|
|
// Returns the string of an extension that must be enabled in the shader to support geometry
|
|
|
|
// shaders. If nullptr is returned then no extension needs to be enabled. Before calling this
|
|
|
|
// function, the caller must verify that geometryShaderSupport exists.
|
|
|
|
const char* geometryShaderExtensionString() const {
|
|
|
|
SkASSERT(this->geometryShaderSupport());
|
|
|
|
return fGeometryShaderExtensionString;
|
|
|
|
}
|
|
|
|
|
2017-10-06 17:57:51 +00:00
|
|
|
// Returns the string of an extension that must be enabled in the shader to support
|
|
|
|
// geometry shader invocations. If nullptr is returned then no extension needs to be enabled.
|
|
|
|
// Before calling this function, the caller must verify that gsInvocationsSupport exists.
|
|
|
|
const char* gsInvocationsExtensionString() const {
|
|
|
|
SkASSERT(this->gsInvocationsSupport());
|
|
|
|
return fGSInvocationsExtensionString;
|
|
|
|
}
|
|
|
|
|
2015-11-11 14:27:20 +00:00
|
|
|
// Returns the string of an extension that will do all necessary coord transfomations needed
|
|
|
|
// when reading the fragment position. If such an extension does not exisits, this function
|
|
|
|
// returns a nullptr, and all transforms of the frag position must be done manually in the
|
|
|
|
// shader.
|
|
|
|
const char* fragCoordConventionsExtensionString() const {
|
|
|
|
return fFragCoordConventionsExtensionString;
|
|
|
|
}
|
|
|
|
|
|
|
|
// This returns the name of an extension that must be enabled in the shader, if such a thing is
|
|
|
|
// required in order to use a secondary output in the shader. This returns a nullptr if no such
|
|
|
|
// extension is required. However, the return value of this function does not say whether dual
|
|
|
|
// source blending is supported.
|
|
|
|
const char* secondaryOutputExtensionString() const {
|
|
|
|
return fSecondaryOutputExtensionString;
|
|
|
|
}
|
2015-11-02 14:22:44 +00:00
|
|
|
|
2015-11-22 22:51:00 +00:00
|
|
|
const char* externalTextureExtensionString() const {
|
2016-03-11 18:07:37 +00:00
|
|
|
SkASSERT(this->externalTextureSupport());
|
2015-11-22 22:51:00 +00:00
|
|
|
return fExternalTextureExtensionString;
|
|
|
|
}
|
|
|
|
|
2016-04-11 20:02:05 +00:00
|
|
|
const char* texelBufferExtensionString() const {
|
|
|
|
SkASSERT(this->texelBufferSupport());
|
|
|
|
return fTexelBufferExtensionString;
|
2016-03-11 22:07:38 +00:00
|
|
|
}
|
|
|
|
|
2016-02-12 20:14:06 +00:00
|
|
|
const char* noperspectiveInterpolationExtensionString() const {
|
|
|
|
SkASSERT(this->noperspectiveInterpolationSupport());
|
|
|
|
return fNoPerspectiveInterpolationExtensionString;
|
|
|
|
}
|
|
|
|
|
2016-11-15 19:05:01 +00:00
|
|
|
const char* imageLoadStoreExtensionString() const {
|
|
|
|
SkASSERT(this->imageLoadStoreSupport());
|
|
|
|
return fImageLoadStoreExtensionString;
|
|
|
|
}
|
|
|
|
|
2016-03-11 18:07:37 +00:00
|
|
|
int maxVertexSamplers() const { return fMaxVertexSamplers; }
|
|
|
|
|
|
|
|
int maxGeometrySamplers() const { return fMaxGeometrySamplers; }
|
|
|
|
|
|
|
|
int maxFragmentSamplers() const { return fMaxFragmentSamplers; }
|
|
|
|
|
|
|
|
int maxCombinedSamplers() const { return fMaxCombinedSamplers; }
|
|
|
|
|
2017-12-01 15:25:08 +00:00
|
|
|
/**
|
|
|
|
* In general using multiple texture units for image rendering seems to be a win at smaller
|
|
|
|
* sizes of dst rects and a loss at larger sizes. Dst rects above this pixel area threshold will
|
|
|
|
* not use multitexturing.
|
|
|
|
*/
|
|
|
|
size_t disableImageMultitexturingDstRectAreaThreshold() const {
|
|
|
|
return fDisableImageMultitexturingDstRectAreaThreshold;
|
|
|
|
}
|
2017-10-11 19:34:27 +00:00
|
|
|
|
2015-11-04 12:23:53 +00:00
|
|
|
/**
|
2016-01-08 21:20:12 +00:00
|
|
|
* Given a texture's config, this determines what swizzle must be appended to accesses to the
|
|
|
|
* texture in generated shader code. Swizzling may be implemented in texture parameters or a
|
2016-01-12 21:29:26 +00:00
|
|
|
* sampler rather than in the shader. In this case the returned swizzle will always be "rgba".
|
2015-11-04 12:23:53 +00:00
|
|
|
*/
|
2016-01-08 21:20:12 +00:00
|
|
|
const GrSwizzle& configTextureSwizzle(GrPixelConfig config) const {
|
|
|
|
return fConfigTextureSwizzle[config];
|
|
|
|
}
|
2015-11-04 12:23:53 +00:00
|
|
|
|
2016-01-12 21:29:26 +00:00
|
|
|
/** Swizzle that should occur on the fragment shader outputs for a given config. */
|
|
|
|
const GrSwizzle& configOutputSwizzle(GrPixelConfig config) const {
|
|
|
|
return fConfigOutputSwizzle[config];
|
|
|
|
}
|
|
|
|
|
2015-06-24 13:59:57 +00:00
|
|
|
GrGLSLGeneration generation() const { return fGLSLGeneration; }
|
|
|
|
|
|
|
|
private:
|
2016-11-29 18:43:05 +00:00
|
|
|
void applyOptionsOverrides(const GrContextOptions& options);
|
2015-11-04 12:23:53 +00:00
|
|
|
|
2015-06-24 13:59:57 +00:00
|
|
|
GrGLSLGeneration fGLSLGeneration;
|
2016-03-29 16:03:52 +00:00
|
|
|
|
2016-11-29 18:43:05 +00:00
|
|
|
bool fShaderDerivativeSupport : 1;
|
|
|
|
bool fGeometryShaderSupport : 1;
|
2017-10-06 17:57:51 +00:00
|
|
|
bool fGSInvocationsSupport : 1;
|
2016-11-29 18:43:05 +00:00
|
|
|
bool fPathRenderingSupport : 1;
|
|
|
|
bool fDstReadInShaderSupport : 1;
|
|
|
|
bool fDualSourceBlendingSupport : 1;
|
|
|
|
bool fIntegerSupport : 1;
|
|
|
|
bool fTexelBufferSupport : 1;
|
|
|
|
bool fImageLoadStoreSupport : 1;
|
2015-06-24 13:59:57 +00:00
|
|
|
bool fDropsTileOnZeroDivide : 1;
|
|
|
|
bool fFBFetchSupport : 1;
|
|
|
|
bool fFBFetchNeedsCustomOutput : 1;
|
2015-10-21 14:14:17 +00:00
|
|
|
bool fUsesPrecisionModifiers : 1;
|
2016-02-12 20:14:06 +00:00
|
|
|
bool fFlatInterpolationSupport : 1;
|
2017-09-15 16:40:03 +00:00
|
|
|
bool fPreferFlatInterpolation : 1;
|
2016-02-12 20:14:06 +00:00
|
|
|
bool fNoPerspectiveInterpolationSupport : 1;
|
2016-03-11 18:07:37 +00:00
|
|
|
bool fExternalTextureSupport : 1;
|
2016-04-11 20:02:05 +00:00
|
|
|
bool fTexelFetchSupport : 1;
|
2017-05-31 18:51:23 +00:00
|
|
|
bool fVertexIDSupport : 1;
|
2017-11-16 01:27:09 +00:00
|
|
|
bool fFloatIs32Bits : 1;
|
|
|
|
bool fHalfIs32Bits : 1;
|
2015-10-21 14:14:17 +00:00
|
|
|
|
2015-11-11 14:27:20 +00:00
|
|
|
// Used for specific driver bug work arounds
|
2018-01-23 16:06:41 +00:00
|
|
|
bool fCanUseAnyFunctionInShader : 1;
|
2015-11-11 14:27:20 +00:00
|
|
|
bool fCanUseMinAndAbsTogether : 1;
|
2017-08-07 18:38:22 +00:00
|
|
|
bool fCanUseFractForNegativeValues : 1;
|
2015-11-11 14:27:20 +00:00
|
|
|
bool fMustForceNegatedAtanParamToFloat : 1;
|
2017-01-20 15:45:49 +00:00
|
|
|
bool fAtan2ImplementedAsAtanYOverX : 1;
|
2017-12-01 21:19:43 +00:00
|
|
|
bool fMustDoOpBetweenFloorAndAbs : 1;
|
2016-08-17 17:59:00 +00:00
|
|
|
bool fRequiresLocalOutputColorForFBFetch : 1;
|
2017-05-25 15:34:38 +00:00
|
|
|
bool fMustObfuscateUniformColor : 1;
|
2017-08-01 18:46:18 +00:00
|
|
|
bool fMustGuardDivisionEvenAfterExplicitZeroCheck : 1;
|
2018-01-16 13:52:29 +00:00
|
|
|
bool fCanUseFragCoord : 1;
|
2018-01-22 13:43:38 +00:00
|
|
|
bool fInterpolantsAreInaccurate : 1;
|
2018-03-07 14:46:10 +00:00
|
|
|
bool fIncompleteShortIntPrecision : 1;
|
2015-11-11 14:27:20 +00:00
|
|
|
|
2015-10-22 15:20:00 +00:00
|
|
|
const char* fVersionDeclString;
|
2015-06-24 13:59:57 +00:00
|
|
|
|
2015-11-02 14:22:44 +00:00
|
|
|
const char* fShaderDerivativeExtensionString;
|
2018-01-11 05:46:14 +00:00
|
|
|
const char* fGeometryShaderExtensionString;
|
2017-10-06 17:57:51 +00:00
|
|
|
const char* fGSInvocationsExtensionString;
|
2015-11-11 14:27:20 +00:00
|
|
|
const char* fFragCoordConventionsExtensionString;
|
|
|
|
const char* fSecondaryOutputExtensionString;
|
2015-11-22 22:51:00 +00:00
|
|
|
const char* fExternalTextureExtensionString;
|
2016-04-11 20:02:05 +00:00
|
|
|
const char* fTexelBufferExtensionString;
|
2016-02-12 20:14:06 +00:00
|
|
|
const char* fNoPerspectiveInterpolationExtensionString;
|
2016-11-15 19:05:01 +00:00
|
|
|
const char* fImageLoadStoreExtensionString;
|
2015-11-02 14:22:44 +00:00
|
|
|
|
2015-06-24 13:59:57 +00:00
|
|
|
const char* fFBFetchColorName;
|
|
|
|
const char* fFBFetchExtensionString;
|
|
|
|
|
2016-09-27 10:33:05 +00:00
|
|
|
int fMaxVertexSamplers;
|
|
|
|
int fMaxGeometrySamplers;
|
|
|
|
int fMaxFragmentSamplers;
|
|
|
|
int fMaxCombinedSamplers;
|
2016-03-11 18:07:37 +00:00
|
|
|
|
2017-12-01 15:25:08 +00:00
|
|
|
size_t fDisableImageMultitexturingDstRectAreaThreshold;
|
|
|
|
|
2015-06-24 13:59:57 +00:00
|
|
|
AdvBlendEqInteraction fAdvBlendEqInteraction;
|
|
|
|
|
2016-01-08 21:20:12 +00:00
|
|
|
GrSwizzle fConfigTextureSwizzle[kGrPixelConfigCnt];
|
2016-01-12 21:29:26 +00:00
|
|
|
GrSwizzle fConfigOutputSwizzle[kGrPixelConfigCnt];
|
2015-11-04 12:23:53 +00:00
|
|
|
|
2017-12-18 21:22:34 +00:00
|
|
|
friend class GrCaps; // For initialization.
|
|
|
|
friend class GrGLCaps;
|
2017-11-04 21:22:22 +00:00
|
|
|
friend class GrMockCaps;
|
2017-07-31 14:45:52 +00:00
|
|
|
friend class GrMtlCaps;
|
2016-01-13 20:19:30 +00:00
|
|
|
friend class GrVkCaps;
|
2016-11-29 20:27:52 +00:00
|
|
|
friend class SkSL::ShaderCapsFactory;
|
2015-06-24 13:59:57 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|