Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(211)

Unified Diff: src/gpu/GrBatch.h

Issue 1277233002: Make folder for batches (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: rebase Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/gpu/GrAtlasTextContext.cpp ('k') | src/gpu/GrBatch.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/gpu/GrBatch.h
diff --git a/src/gpu/GrBatch.h b/src/gpu/GrBatch.h
deleted file mode 100644
index 1a35db5591d56053417d31c70e9507766924fdb6..0000000000000000000000000000000000000000
--- a/src/gpu/GrBatch.h
+++ /dev/null
@@ -1,200 +0,0 @@
-/*
- * Copyright 2015 Google Inc.
- *
- * Use of this source code is governed by a BSD-style license that can be
- * found in the LICENSE file.
- */
-
-#ifndef GrBatch_DEFINED
-#define GrBatch_DEFINED
-
-#include <new>
-#include "GrBatchTarget.h"
-#include "GrGeometryProcessor.h"
-#include "GrNonAtomicRef.h"
-#include "GrVertices.h"
-#include "SkAtomics.h"
-#include "SkTypes.h"
-
-class GrGpu;
-class GrPipeline;
-
-struct GrInitInvariantOutput;
-
-/*
- * GrBatch is the base class for all Ganesh deferred geometry generators. To facilitate
- * reorderable batching, Ganesh does not generate geometry inline with draw calls. Instead, it
- * captures the arguments to the draw and then generates the geometry on demand. This gives GrBatch
- * subclasses complete freedom to decide how / what they can batch.
- *
- * Batches are created when GrContext processes a draw call. Batches of the same subclass may be
- * merged using combineIfPossible. When two batches merge, one takes on the union of the data
- * and the other is left empty. The merged batch becomes responsible for drawing the data from both
- * the original batches.
- *
- * If there are any possible optimizations which might require knowing more about the full state of
- * the draw, ie whether or not the GrBatch is allowed to tweak alpha for coverage, then this
- * information will be communicated to the GrBatch prior to geometry generation.
- */
-#define GR_BATCH_SPEW 0
-#if GR_BATCH_SPEW
- #define GrBATCH_INFO(...) SkDebugf(__VA_ARGS__)
- #define GrBATCH_SPEW(code) code
-#else
- #define GrBATCH_SPEW(code)
- #define GrBATCH_INFO(...)
-#endif
-
-class GrBatch : public GrNonAtomicRef {
-public:
- GrBatch()
- : fClassID(kIllegalBatchID)
- , fNumberOfDraws(0)
-#if GR_BATCH_SPEW
- , fUniqueID(GenID(&gCurrBatchUniqueID))
-#endif
- { SkDEBUGCODE(fUsed = false;) }
- virtual ~GrBatch() {}
-
- virtual const char* name() const = 0;
- virtual void getInvariantOutputColor(GrInitInvariantOutput* out) const = 0;
- virtual void getInvariantOutputCoverage(GrInitInvariantOutput* out) const = 0;
-
- /*
- * initBatchTracker is a hook for the some additional overrides / optimization possibilities
- * from the GrXferProcessor.
- */
- virtual void initBatchTracker(const GrPipelineInfo& init) = 0;
-
- bool combineIfPossible(GrBatch* that) {
- if (this->classID() != that->classID()) {
- return false;
- }
-
- return this->onCombineIfPossible(that);
- }
-
- virtual bool onCombineIfPossible(GrBatch*) = 0;
-
- virtual void generateGeometry(GrBatchTarget*) = 0;
-
- const SkRect& bounds() const { return fBounds; }
-
- // TODO this goes away when batches are everywhere
- void setNumberOfDraws(int numberOfDraws) { fNumberOfDraws = numberOfDraws; }
- int numberOfDraws() const { return fNumberOfDraws; }
-
- void* operator new(size_t size);
- void operator delete(void* target);
-
- void* operator new(size_t size, void* placement) {
- return ::operator new(size, placement);
- }
- void operator delete(void* target, void* placement) {
- ::operator delete(target, placement);
- }
-
- /**
- * Helper for down-casting to a GrBatch subclass
- */
- template <typename T> const T& cast() const { return *static_cast<const T*>(this); }
- template <typename T> T* cast() { return static_cast<T*>(this); }
-
- uint32_t classID() const { SkASSERT(kIllegalBatchID != fClassID); return fClassID; }
-
- // TODO no GrPrimitiveProcessors yet read fragment position
- bool willReadFragmentPosition() const { return false; }
-
- SkDEBUGCODE(bool isUsed() const { return fUsed; })
-
- const GrPipeline* pipeline() const { return fPipeline; }
- void setPipeline(const GrPipeline* pipeline) { fPipeline.reset(SkRef(pipeline)); }
-
-#if GR_BATCH_SPEW
- uint32_t uniqueID() const { return fUniqueID; }
-#endif
-
-protected:
- template <typename PROC_SUBCLASS> void initClassID() {
- static uint32_t kClassID = GenID(&gCurrBatchClassID);
- fClassID = kClassID;
- }
-
- // NOTE, compute some bounds, even if extremely conservative. Do *NOT* setLargest on the bounds
- // rect because we outset it for dst copy textures
- void setBounds(const SkRect& newBounds) { fBounds = newBounds; }
-
- void joinBounds(const SkRect& otherBounds) {
- return fBounds.joinPossiblyEmptyRect(otherBounds);
- }
-
- /** Helper for rendering instances using an instanced index index buffer. This class creates the
- space for the vertices and flushes the draws to the batch target.*/
- class InstancedHelper {
- public:
- InstancedHelper() {}
- /** Returns the allocated storage for the vertices. The caller should populate the before
- vertices before calling issueDraws(). */
- void* init(GrBatchTarget* batchTarget, GrPrimitiveType, size_t vertexStride,
- const GrIndexBuffer*, int verticesPerInstance, int indicesPerInstance,
- int instancesToDraw);
-
- /** Call after init() to issue draws to the batch target.*/
- void issueDraw(GrBatchTarget* batchTarget) {
- SkASSERT(fVertices.instanceCount());
- batchTarget->draw(fVertices);
- }
- private:
- GrVertices fVertices;
- };
-
- static const int kVerticesPerQuad = 4;
- static const int kIndicesPerQuad = 6;
-
- /** A specialization of InstanceHelper for quad rendering. */
- class QuadHelper : private InstancedHelper {
- public:
- QuadHelper() : INHERITED() {}
- /** Finds the cached quad index buffer and reserves vertex space. Returns NULL on failure
- and on sucess a pointer to the vertex data that the caller should populate before
- calling issueDraws(). */
- void* init(GrBatchTarget* batchTarget, size_t vertexStride, int quadsToDraw);
-
- using InstancedHelper::issueDraw;
-
- private:
- typedef InstancedHelper INHERITED;
- };
-
- uint32_t fClassID;
- SkRect fBounds;
-
-private:
- static uint32_t GenID(int32_t* idCounter) {
- // fCurrProcessorClassID has been initialized to kIllegalProcessorClassID. The
- // atomic inc returns the old value not the incremented value. So we add
- // 1 to the returned value.
- uint32_t id = static_cast<uint32_t>(sk_atomic_inc(idCounter)) + 1;
- if (!id) {
- SkFAIL("This should never wrap as it should only be called once for each GrBatch "
- "subclass.");
- }
- return id;
- }
-
- enum {
- kIllegalBatchID = 0,
- };
- SkAutoTUnref<const GrPipeline> fPipeline;
- static int32_t gCurrBatchClassID;
- int fNumberOfDraws;
- SkDEBUGCODE(bool fUsed;)
-#if GR_BATCH_SPEW
- static int32_t gCurrBatchUniqueID;
- uint32_t fUniqueID;
-#endif
-
- typedef SkRefCnt INHERITED;
-};
-
-#endif
« no previous file with comments | « src/gpu/GrAtlasTextContext.cpp ('k') | src/gpu/GrBatch.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698