| Index: src/gpu/GrProcOptInfo.h
|
| diff --git a/src/gpu/GrProcOptInfo.h b/src/gpu/GrProcOptInfo.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..5252e8535475b0e042eabeeab32c02783a280ae1
|
| --- /dev/null
|
| +++ b/src/gpu/GrProcOptInfo.h
|
| @@ -0,0 +1,85 @@
|
| +/*
|
| + * Copyright 2014 Google Inc.
|
| + *
|
| + * Use of this source code is governed by a BSD-style license that can be
|
| + * found in the LICENSE file.
|
| + */
|
| +
|
| +#ifndef GrProcOptInfo_DEFINED
|
| +#define GrProcOptInfo_DEFINED
|
| +
|
| +#include "GrColor.h"
|
| +#include "GrInvariantOutput.h"
|
| +
|
| +class GrFragmentStage;
|
| +class GrGeometryProcessor;
|
| +
|
| +/**
|
| + * GrProcOptInfo gathers invariant data from a set of processor stages.It is used to recognize
|
| + * optimizations related to eliminating stages and vertex attributes that aren't necessary for a
|
| + * draw.
|
| + */
|
| +class GrProcOptInfo {
|
| +public:
|
| + GrProcOptInfo()
|
| + : fInOut(0, static_cast<GrColorComponentFlags>(0), false)
|
| + , fFirstEffectStageIndex(0)
|
| + , fInputColorIsUsed(true)
|
| + , fInputColor(0)
|
| + , fRemoveVertexAttrib(false)
|
| + , fReadsDst(false) {}
|
| +
|
| + void calcWithInitialValues(const GrFragmentStage*, int stageCount, GrColor startColor,
|
| + GrColorComponentFlags flags, bool areCoverageStages,
|
| + const GrGeometryProcessor* gp = NULL);
|
| +
|
| + bool isSolidWhite() const { return fInOut.isSolidWhite(); }
|
| + bool isOpaque() const { return fInOut.isOpaque(); }
|
| +
|
| + GrColor color() const { return fInOut.color(); }
|
| + uint8_t validFlags() const { return fInOut.validFlags(); }
|
| +
|
| + /**
|
| + * Returns the index of the first effective color stage. If an intermediate stage doesn't read
|
| + * its input or has a known output, then we can ignore all earlier stages since they will not
|
| + * affect the final output. Thus the first effective stage index is the index to the first stage
|
| + * that will have an effect on the final output.
|
| + *
|
| + * If stages before the firstEffectiveStageIndex are removed, corresponding values from
|
| + * inputColorIsUsed(), inputColorToEffectiveStage(), removeVertexAttribs(), and readsDst() must
|
| + * be used when setting up the draw to ensure correct drawing.
|
| + */
|
| + int firstEffectiveStageIndex() const { return fFirstEffectStageIndex; }
|
| +
|
| + /**
|
| + * True if the first effective stage reads its input, false otherwise.
|
| + */
|
| + bool inputColorIsUsed() const { return fInputColorIsUsed; }
|
| +
|
| + /**
|
| + * If input color is used and per-vertex colors are not used, this is the input color to the
|
| + * first effective stage.
|
| + */
|
| + GrColor inputColorToEffectiveStage() const { return fInputColor; }
|
| +
|
| + /**
|
| + * Given the set of optimizations determined by GrProcOptInfo, should the caller remove the
|
| + * color/coverage vertex attribute that was input to the first stage.
|
| + */
|
| + bool removeVertexAttrib() const { return fRemoveVertexAttrib; }
|
| +
|
| + /**
|
| + * Returns true if any of the stages preserved by GrProcOptInfo read the dst color.
|
| + */
|
| + bool readsDst() const { return fReadsDst; }
|
| +
|
| +private:
|
| + GrInvariantOutput fInOut;
|
| + int fFirstEffectStageIndex;
|
| + bool fInputColorIsUsed;
|
| + GrColor fInputColor;
|
| + bool fRemoveVertexAttrib;
|
| + bool fReadsDst;
|
| +};
|
| +
|
| +#endif
|
|
|