Rename instanceAttribSupport -> drawInstancedSupport
Change-Id: I7d8ff8597849f2b910928867842857e25a12b4b1 Reviewed-on: https://skia-review.googlesource.com/c/skia/+/281582 Commit-Queue: Chris Dalton <csmartdalton@google.com> Reviewed-by: Brian Salomon <bsalomon@google.com>
This commit is contained in:
parent
4b239b1d50
commit
17f05c737e
@ -109,7 +109,7 @@ struct GrMockOptions {
|
||||
|
||||
// GrCaps options.
|
||||
bool fMipMapSupport = false;
|
||||
bool fInstanceAttribSupport = false;
|
||||
bool fDrawInstancedSupport = false;
|
||||
bool fHalfFloatVertexAttributeSupport = false;
|
||||
uint32_t fMapBufferFlags = 0;
|
||||
int fMaxTextureSize = 2048;
|
||||
|
@ -24,7 +24,7 @@ GrCaps::GrCaps(const GrContextOptions& options) {
|
||||
fTextureBarrierSupport = false;
|
||||
fSampleLocationsSupport = false;
|
||||
fMultisampleDisableSupport = false;
|
||||
fInstanceAttribSupport = false;
|
||||
fDrawInstancedSupport = false;
|
||||
fMixedSamplesSupport = false;
|
||||
fConservativeRasterSupport = false;
|
||||
fWireframeSupport = false;
|
||||
@ -192,7 +192,7 @@ void GrCaps::dumpJSON(SkJSONWriter* writer) const {
|
||||
writer->appendBool("Texture Barrier Support", fTextureBarrierSupport);
|
||||
writer->appendBool("Sample Locations Support", fSampleLocationsSupport);
|
||||
writer->appendBool("Multisample disable support", fMultisampleDisableSupport);
|
||||
writer->appendBool("Instance Attrib Support", fInstanceAttribSupport);
|
||||
writer->appendBool("Draw Instanced Support", fDrawInstancedSupport);
|
||||
writer->appendBool("Mixed Samples Support", fMixedSamplesSupport);
|
||||
writer->appendBool("Conservative Raster Support", fConservativeRasterSupport);
|
||||
writer->appendBool("Wireframe Support", fWireframeSupport);
|
||||
|
@ -51,7 +51,7 @@ public:
|
||||
bool textureBarrierSupport() const { return fTextureBarrierSupport; }
|
||||
bool sampleLocationsSupport() const { return fSampleLocationsSupport; }
|
||||
bool multisampleDisableSupport() const { return fMultisampleDisableSupport; }
|
||||
bool instanceAttribSupport() const { return fInstanceAttribSupport; }
|
||||
bool drawInstancedSupport() const { return fDrawInstancedSupport; }
|
||||
bool mixedSamplesSupport() const { return fMixedSamplesSupport; }
|
||||
bool conservativeRasterSupport() const { return fConservativeRasterSupport; }
|
||||
bool wireframeSupport() const { return fWireframeSupport; }
|
||||
@ -464,7 +464,7 @@ protected:
|
||||
bool fTextureBarrierSupport : 1;
|
||||
bool fSampleLocationsSupport : 1;
|
||||
bool fMultisampleDisableSupport : 1;
|
||||
bool fInstanceAttribSupport : 1;
|
||||
bool fDrawInstancedSupport : 1;
|
||||
bool fMixedSamplesSupport : 1;
|
||||
bool fConservativeRasterSupport : 1;
|
||||
bool fWireframeSupport : 1;
|
||||
|
@ -65,7 +65,7 @@ void GrOpsRenderPass::bindPipeline(const GrProgramInfo& programInfo, const SkRec
|
||||
// place (i.e., the target renderTargetProxy) they had best agree.
|
||||
SkASSERT(programInfo.origin() == fOrigin);
|
||||
if (programInfo.primProc().hasInstanceAttributes()) {
|
||||
SkASSERT(this->gpu()->caps()->instanceAttribSupport());
|
||||
SkASSERT(this->gpu()->caps()->drawInstancedSupport());
|
||||
}
|
||||
if (programInfo.pipeline().usesConservativeRaster()) {
|
||||
SkASSERT(this->gpu()->caps()->conservativeRasterSupport());
|
||||
@ -243,7 +243,7 @@ void GrOpsRenderPass::drawIndexed(int indexCount, int baseIndex, uint16_t minInd
|
||||
|
||||
void GrOpsRenderPass::drawInstanced(int instanceCount, int baseInstance, int vertexCount,
|
||||
int baseVertex) {
|
||||
SkASSERT(this->gpu()->caps()->instanceAttribSupport());
|
||||
SkASSERT(this->gpu()->caps()->drawInstancedSupport());
|
||||
if (!this->prepareToDraw()) {
|
||||
return;
|
||||
}
|
||||
@ -255,7 +255,7 @@ void GrOpsRenderPass::drawInstanced(int instanceCount, int baseInstance, int ver
|
||||
|
||||
void GrOpsRenderPass::drawIndexedInstanced(int indexCount, int baseIndex, int instanceCount,
|
||||
int baseInstance, int baseVertex) {
|
||||
SkASSERT(this->gpu()->caps()->instanceAttribSupport());
|
||||
SkASSERT(this->gpu()->caps()->drawInstancedSupport());
|
||||
if (!this->prepareToDraw()) {
|
||||
return;
|
||||
}
|
||||
|
@ -22,7 +22,7 @@ bool GrCoverageCountingPathRenderer::IsSupported(const GrCaps& caps, CoverageTyp
|
||||
GrBackendFormat defaultA8Format = caps.getDefaultBackendFormat(GrColorType::kAlpha_8,
|
||||
GrRenderable::kYes);
|
||||
if (caps.driverBlacklistCCPR() || !shaderCaps.integerSupport() ||
|
||||
!caps.instanceAttribSupport() || !shaderCaps.floatIs32Bits() ||
|
||||
!caps.drawInstancedSupport() || !shaderCaps.floatIs32Bits() ||
|
||||
!defaultA8Format.isValid() || // This checks both texturable and renderable
|
||||
!caps.halfFloatVertexAttributeSupport()) {
|
||||
return false;
|
||||
|
@ -27,7 +27,7 @@ GrD3DCaps::GrD3DCaps(const GrContextOptions& contextOptions, IDXGIAdapter1* adap
|
||||
fReuseScratchTextures = true; //TODO: figure this out
|
||||
fGpuTracingSupport = false; //TODO: figure this out
|
||||
fOversizedStencilSupport = false; //TODO: figure this out
|
||||
fInstanceAttribSupport = true;
|
||||
fDrawInstancedSupport = true;
|
||||
|
||||
// TODO: implement these
|
||||
fSemaphoreSupport = false;
|
||||
|
@ -33,7 +33,6 @@ GrGLCaps::GrGLCaps(const GrContextOptions& contextOptions,
|
||||
fVertexArrayObjectSupport = false;
|
||||
fDebugSupport = false;
|
||||
fES2CompatibilitySupport = false;
|
||||
fDrawInstancedSupport = false;
|
||||
fDrawIndirectSupport = false;
|
||||
fDrawRangeElementsSupport = false;
|
||||
fMultiDrawIndirectSupport = false;
|
||||
@ -205,18 +204,18 @@ void GrGLCaps::init(const GrContextOptions& contextOptions,
|
||||
if (GR_IS_GR_GL(standard)) {
|
||||
// 3.1 has draw_instanced but not instanced_arrays, for the time being we only care about
|
||||
// instanced arrays, but we could make this more granular if we wanted
|
||||
fInstanceAttribSupport =
|
||||
fDrawInstancedSupport =
|
||||
version >= GR_GL_VER(3, 2) ||
|
||||
(ctxInfo.hasExtension("GL_ARB_draw_instanced") &&
|
||||
ctxInfo.hasExtension("GL_ARB_instanced_arrays"));
|
||||
} else if (GR_IS_GR_GL_ES(standard)) {
|
||||
fInstanceAttribSupport =
|
||||
fDrawInstancedSupport =
|
||||
version >= GR_GL_VER(3, 0) ||
|
||||
(ctxInfo.hasExtension("GL_EXT_draw_instanced") &&
|
||||
ctxInfo.hasExtension("GL_EXT_instanced_arrays"));
|
||||
} else if (GR_IS_GR_WEBGL(standard)) {
|
||||
// WebGL 2.0 has DrawArraysInstanced and drawElementsInstanced
|
||||
fInstanceAttribSupport = version >= GR_GL_VER(2, 0);
|
||||
fDrawInstancedSupport = version >= GR_GL_VER(2, 0);
|
||||
}
|
||||
|
||||
if (GR_IS_GR_GL(standard)) {
|
||||
@ -3547,7 +3546,7 @@ void GrGLCaps::applyDriverCorrectnessWorkarounds(const GrGLContextInfo& ctxInfo,
|
||||
}
|
||||
|
||||
// http://anglebug.com/4538
|
||||
if (fBaseVertexBaseInstanceSupport && !fInstanceAttribSupport) {
|
||||
if (fBaseVertexBaseInstanceSupport && !fDrawInstancedSupport) {
|
||||
fBaseVertexBaseInstanceSupport = false;
|
||||
}
|
||||
|
||||
|
@ -310,9 +310,6 @@ public:
|
||||
/// Is there support for ES2 compatability?
|
||||
bool ES2CompatibilitySupport() const { return fES2CompatibilitySupport; }
|
||||
|
||||
/// Is there support for glDraw*Instanced?
|
||||
bool drawInstancedSupport() const { return fDrawInstancedSupport; }
|
||||
|
||||
/// Is there support for glDraw*Indirect? Note that the baseInstance fields of indirect draw
|
||||
/// commands cannot be used unless we have base instance support.
|
||||
bool drawIndirectSupport() const { return fDrawIndirectSupport; }
|
||||
@ -525,7 +522,6 @@ private:
|
||||
bool fVertexArrayObjectSupport : 1;
|
||||
bool fDebugSupport : 1;
|
||||
bool fES2CompatibilitySupport : 1;
|
||||
bool fDrawInstancedSupport : 1;
|
||||
bool fDrawIndirectSupport : 1;
|
||||
bool fDrawRangeElementsSupport : 1;
|
||||
bool fMultiDrawIndirectSupport : 1;
|
||||
|
@ -143,7 +143,7 @@ void GrGLOpsRenderPass::onDrawIndexed(int indexCount, int baseIndex, uint16_t mi
|
||||
uint16_t maxIndexValue, int baseVertex) {
|
||||
GrGLenum glPrimType = fGpu->prepareToDraw(fPrimitiveType);
|
||||
if (fGpu->glCaps().baseVertexBaseInstanceSupport()) {
|
||||
SkASSERT(fGpu->glCaps().instanceAttribSupport());
|
||||
SkASSERT(fGpu->glCaps().drawInstancedSupport());
|
||||
SkASSERT(!fActiveVertexBuffer);
|
||||
if (baseVertex != 0) {
|
||||
GL_CALL(DrawElementsInstancedBaseVertexBaseInstance(
|
||||
|
@ -85,7 +85,7 @@ void GrGLAttribArrayState::set(GrGLGpu* gpu,
|
||||
size_t offsetInBytes,
|
||||
int divisor) {
|
||||
SkASSERT(index >= 0 && index < fAttribArrayStates.count());
|
||||
SkASSERT(0 == divisor || gpu->caps()->instanceAttribSupport());
|
||||
SkASSERT(0 == divisor || gpu->caps()->drawInstancedSupport());
|
||||
AttribArrayState* array = &fAttribArrayStates[index];
|
||||
const char* offsetAsPtr;
|
||||
bool bufferChanged = false;
|
||||
@ -134,7 +134,7 @@ void GrGLAttribArrayState::set(GrGLGpu* gpu,
|
||||
array->fStride = stride;
|
||||
array->fOffset = offsetAsPtr;
|
||||
}
|
||||
if (gpu->caps()->instanceAttribSupport() && array->fDivisor != divisor) {
|
||||
if (gpu->caps()->drawInstancedSupport() && array->fDivisor != divisor) {
|
||||
SkASSERT(0 == divisor || 1 == divisor); // not necessarily a requirement but what we expect.
|
||||
GR_GL_CALL(gpu->glInterface(), VertexAttribDivisor(index, divisor));
|
||||
array->fDivisor = divisor;
|
||||
|
@ -17,7 +17,7 @@ public:
|
||||
GrMockCaps(const GrContextOptions& contextOptions, const GrMockOptions& options)
|
||||
: INHERITED(contextOptions), fOptions(options) {
|
||||
fMipMapSupport = options.fMipMapSupport;
|
||||
fInstanceAttribSupport = options.fInstanceAttribSupport;
|
||||
fDrawInstancedSupport = options.fDrawInstancedSupport;
|
||||
fHalfFloatVertexAttributeSupport = options.fHalfFloatVertexAttributeSupport;
|
||||
fMapBufferFlags = options.fMapBufferFlags;
|
||||
fBufferMapThreshold = SK_MaxS32; // Overridable in GrContextOptions.
|
||||
|
@ -279,7 +279,7 @@ void GrMtlCaps::initGrCaps(const id<MTLDevice> device) {
|
||||
|
||||
if (@available(macOS 10.11, iOS 9.0, *)) {
|
||||
if (this->isMac() || 3 == fFamilyGroup) {
|
||||
fInstanceAttribSupport = true;
|
||||
fDrawInstancedSupport = true;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -145,7 +145,7 @@ std::unique_ptr<GrDrawOp> FillRRectOp::Make(GrRecordingContext* ctx,
|
||||
|
||||
const GrCaps* caps = ctx->priv().caps();
|
||||
|
||||
if (!caps->instanceAttribSupport()) {
|
||||
if (!caps->drawInstancedSupport()) {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
|
@ -41,7 +41,7 @@ GrVkCaps::GrVkCaps(const GrContextOptions& contextOptions, const GrVkInterface*
|
||||
fReuseScratchTextures = true; //TODO: figure this out
|
||||
fGpuTracingSupport = false; //TODO: figure this out
|
||||
fOversizedStencilSupport = false; //TODO: figure this out
|
||||
fInstanceAttribSupport = true;
|
||||
fDrawInstancedSupport = true;
|
||||
|
||||
fSemaphoreSupport = true; // always available in Vulkan
|
||||
fFenceSyncSupport = true; // always available in Vulkan
|
||||
@ -477,7 +477,7 @@ void GrVkCaps::applyDriverCorrectnessWorkarounds(const VkPhysicalDevicePropertie
|
||||
#endif
|
||||
|
||||
if (kARM_VkVendor == properties.vendorID) {
|
||||
fInstanceAttribSupport = false;
|
||||
fDrawInstancedSupport = false;
|
||||
fAvoidWritePixelsFastPath = true; // bugs.skia.org/8064
|
||||
}
|
||||
|
||||
|
@ -141,7 +141,7 @@ class CCPRTest {
|
||||
public:
|
||||
void run(skiatest::Reporter* reporter, DoCoverageCount doCoverageCount, DoStroke doStroke) {
|
||||
GrMockOptions mockOptions;
|
||||
mockOptions.fInstanceAttribSupport = true;
|
||||
mockOptions.fDrawInstancedSupport = true;
|
||||
mockOptions.fHalfFloatVertexAttributeSupport = true;
|
||||
mockOptions.fMapBufferFlags = GrCaps::kCanMap_MapFlag;
|
||||
mockOptions.fConfigOptions[(int)GrColorType::kAlpha_F16].fRenderability =
|
||||
|
@ -231,7 +231,7 @@ DEF_GPUTEST_FOR_RENDERING_CONTEXTS(GrMeshTest, reporter, ctxInfo) {
|
||||
});
|
||||
|
||||
for (bool indexed : {false, true}) {
|
||||
if (!context->priv().caps()->instanceAttribSupport()) {
|
||||
if (!context->priv().caps()->drawInstancedSupport()) {
|
||||
break;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user