aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/gpu/GrPipeline.cpp
diff options
context:
space:
mode:
authorGravatar bsalomon <bsalomon@google.com>2015-08-10 12:01:15 -0700
committerGravatar Commit bot <commit-bot@chromium.org>2015-08-10 12:01:15 -0700
commitc699873ac7c6b21bbca96053cdb9720c80f69916 (patch)
tree72d4c4b83832851d7cf37fcf51ad3fc70a57d14d /src/gpu/GrPipeline.cpp
parentb7ee1bf01709887388cea564989289d1572710e7 (diff)
Remove GrPipelineOptimizations member from GrPipeline
Diffstat (limited to 'src/gpu/GrPipeline.cpp')
-rw-r--r--src/gpu/GrPipeline.cpp96
1 files changed, 48 insertions, 48 deletions
diff --git a/src/gpu/GrPipeline.cpp b/src/gpu/GrPipeline.cpp
index ce0c5fcabb..0781c6fb27 100644
--- a/src/gpu/GrPipeline.cpp
+++ b/src/gpu/GrPipeline.cpp
@@ -15,16 +15,20 @@
#include "batches/GrBatch.h"
-GrPipeline::GrPipeline(const GrPipelineBuilder& pipelineBuilder,
- const GrProcOptInfo& colorPOI,
- const GrProcOptInfo& coveragePOI,
- const GrCaps& caps,
- const GrScissorState& scissorState,
- const GrXferProcessor::DstTexture* dstTexture) {
+GrPipeline* GrPipeline::CreateAt(void* memory,
+ const GrPipelineBuilder& builder,
+ const GrProcOptInfo& colorPOI,
+ const GrProcOptInfo& coveragePOI,
+ const GrCaps& caps,
+ const GrScissorState& scissor,
+ const GrXferProcessor::DstTexture* dst,
+ GrPipelineOptimizations* opts) {
+ GrPipeline* pipeline = SkNEW_PLACEMENT(memory, GrPipeline);
+
// Create XferProcessor from DS's XPFactory
SkAutoTUnref<GrXferProcessor> xferProcessor(
- pipelineBuilder.getXPFactory()->createXferProcessor(
- colorPOI, coveragePOI, pipelineBuilder.hasMixedSamples(), dstTexture, caps));
+ builder.getXPFactory()->createXferProcessor(
+ colorPOI, coveragePOI, builder.hasMixedSamples(), dst, caps));
GrColor overrideColor = GrColor_ILLEGAL;
if (colorPOI.firstEffectiveStageIndex() != 0) {
@@ -33,11 +37,11 @@ GrPipeline::GrPipeline(const GrPipelineBuilder& pipelineBuilder,
GrXferProcessor::OptFlags optFlags = GrXferProcessor::kNone_OptFlags;
if (xferProcessor) {
- fXferProcessor.reset(xferProcessor.get());
+ pipeline->fXferProcessor.reset(xferProcessor.get());
optFlags = xferProcessor->getOptimizations(colorPOI,
coveragePOI,
- pipelineBuilder.getStencil().doesWrite(),
+ builder.getStencil().doesWrite(),
&overrideColor,
caps);
}
@@ -53,26 +57,26 @@ GrPipeline::GrPipeline(const GrPipelineBuilder& pipelineBuilder,
if (!xferProcessor || (GrXferProcessor::kSkipDraw_OptFlag & optFlags)) {
// Set the fields that don't default init and return. The lack of a render target will
// indicate that this can be skipped.
- fFlags = 0;
- fDrawFace = GrPipelineBuilder::kInvalid_DrawFace;
- return;
+ pipeline->fFlags = 0;
+ pipeline->fDrawFace = GrPipelineBuilder::kInvalid_DrawFace;
+ return pipeline;
}
- fRenderTarget.reset(pipelineBuilder.fRenderTarget.get());
- SkASSERT(fRenderTarget);
- fScissorState = scissorState;
- fStencilSettings = pipelineBuilder.getStencil();
- fDrawFace = pipelineBuilder.getDrawFace();
+ pipeline->fRenderTarget.reset(builder.fRenderTarget.get());
+ SkASSERT(pipeline->fRenderTarget);
+ pipeline->fScissorState = scissor;
+ pipeline->fStencilSettings = builder.getStencil();
+ pipeline->fDrawFace = builder.getDrawFace();
- fFlags = 0;
- if (pipelineBuilder.isHWAntialias()) {
- fFlags |= kHWAA_Flag;
+ pipeline->fFlags = 0;
+ if (builder.isHWAntialias()) {
+ pipeline->fFlags |= kHWAA_Flag;
}
- if (pipelineBuilder.isDither()) {
- fFlags |= kDither_Flag;
+ if (builder.isDither()) {
+ pipeline->fFlags |= kDither_Flag;
}
- if (pipelineBuilder.snapVerticesToPixelCenters()) {
- fFlags |= kSnapVertices_Flag;
+ if (builder.snapVerticesToPixelCenters()) {
+ pipeline->fFlags |= kSnapVertices_Flag;
}
int firstColorStageIdx = colorPOI.firstEffectiveStageIndex();
@@ -81,52 +85,48 @@ GrPipeline::GrPipeline(const GrPipelineBuilder& pipelineBuilder,
// GrPipelineBuilder's coverageProcInfo (like color above) to set this initial information.
int firstCoverageStageIdx = 0;
- this->adjustProgramFromOptimizations(pipelineBuilder, optFlags, colorPOI, coveragePOI,
- &firstColorStageIdx, &firstCoverageStageIdx);
+ pipeline->adjustProgramFromOptimizations(builder, optFlags, colorPOI, coveragePOI,
+ &firstColorStageIdx, &firstCoverageStageIdx);
bool usesLocalCoords = false;
// Copy Stages from PipelineBuilder to Pipeline
- for (int i = firstColorStageIdx; i < pipelineBuilder.numColorFragmentStages(); ++i) {
- const GrFragmentStage& fps = pipelineBuilder.fColorStages[i];
+ for (int i = firstColorStageIdx; i < builder.numColorFragmentStages(); ++i) {
+ const GrFragmentStage& fps = builder.fColorStages[i];
const GrFragmentProcessor* fp = fps.processor();
- SkNEW_APPEND_TO_TARRAY(&fFragmentStages, GrPendingFragmentStage, (fps));
+ SkNEW_APPEND_TO_TARRAY(&pipeline->fFragmentStages, GrPendingFragmentStage, (fps));
usesLocalCoords = usesLocalCoords || fp->usesLocalCoords();
- fp->gatherCoordTransforms(&fCoordTransforms);
+ fp->gatherCoordTransforms(&pipeline->fCoordTransforms);
}
- fNumColorStages = fFragmentStages.count();
- for (int i = firstCoverageStageIdx; i < pipelineBuilder.numCoverageFragmentStages(); ++i) {
- const GrFragmentStage& fps = pipelineBuilder.fCoverageStages[i];
+ pipeline->fNumColorStages = pipeline->fFragmentStages.count();
+ for (int i = firstCoverageStageIdx; i < builder.numCoverageFragmentStages(); ++i) {
+ const GrFragmentStage& fps = builder.fCoverageStages[i];
const GrFragmentProcessor* fp = fps.processor();
- SkNEW_APPEND_TO_TARRAY(&fFragmentStages, GrPendingFragmentStage, (fps));
+ SkNEW_APPEND_TO_TARRAY(&pipeline->fFragmentStages, GrPendingFragmentStage, (fps));
usesLocalCoords = usesLocalCoords || fp->usesLocalCoords();
- fp->gatherCoordTransforms(&fCoordTransforms);
+ fp->gatherCoordTransforms(&pipeline->fCoordTransforms);
}
// Setup info we need to pass to GrPrimitiveProcessors that are used with this GrPipeline.
- fInfoForPrimitiveProcessor.fFlags = 0;
+ opts->fFlags = 0;
if (!SkToBool(optFlags & GrXferProcessor::kIgnoreColor_OptFlag)) {
- fInfoForPrimitiveProcessor.fFlags |=
- GrPipelineOptimizations::kReadsColor_GrPipelineOptimizationsFlag;
+ opts->fFlags |= GrPipelineOptimizations::kReadsColor_Flag;
}
if (GrColor_ILLEGAL != overrideColor) {
- fInfoForPrimitiveProcessor.fFlags |=
- GrPipelineOptimizations::kUseOverrideColor_GrPipelineOptimizationsFlag;
- fInfoForPrimitiveProcessor.fOverrideColor = overrideColor;
+ opts->fFlags |= GrPipelineOptimizations::kUseOverrideColor_Flag;
+ opts->fOverrideColor = overrideColor;
}
if (!SkToBool(optFlags & GrXferProcessor::kIgnoreCoverage_OptFlag)) {
- fInfoForPrimitiveProcessor.fFlags |=
- GrPipelineOptimizations::kReadsCoverage_GrPipelineOptimizationsFlag;
+ opts->fFlags |= GrPipelineOptimizations::kReadsCoverage_Flag;
}
if (usesLocalCoords) {
- fInfoForPrimitiveProcessor.fFlags |=
- GrPipelineOptimizations::kReadsLocalCoords_GrPipelineOptimizationsFlag;
+ opts->fFlags |= GrPipelineOptimizations::kReadsLocalCoords_Flag;
}
if (SkToBool(optFlags & GrXferProcessor::kCanTweakAlphaForCoverage_OptFlag)) {
- fInfoForPrimitiveProcessor.fFlags |=
- GrPipelineOptimizations::kCanTweakAlphaForCoverage_GrPipelineOptimizationsFlag;
+ opts->fFlags |= GrPipelineOptimizations::kCanTweakAlphaForCoverage_Flag;
}
+ return pipeline;
}
void GrPipeline::adjustProgramFromOptimizations(const GrPipelineBuilder& pipelineBuilder,