blob: fe0edc9619ebc35765312395209242b881e631a2 [file] [log] [blame]
egdaniel066df7c2016-06-08 14:02:27 -07001/*
2* Copyright 2016 Google Inc.
3*
4* Use of this source code is governed by a BSD-style license that can be
5* found in the LICENSE file.
6*/
7
8#ifndef GrGpuCommandBuffer_DEFINED
9#define GrGpuCommandBuffer_DEFINED
10
11#include "GrColor.h"
Chris Dalton46983b72017-06-06 12:27:16 -060012#include "GrPipeline.h"
Brian Salomon89527432016-12-16 09:52:16 -050013#include "ops/GrDrawOp.h"
egdaniel066df7c2016-06-08 14:02:27 -070014
Brian Salomon742e31d2016-12-07 17:06:19 -050015class GrOpFlushState;
csmartdalton29df7602016-08-31 11:55:52 -070016class GrFixedClip;
egdaniel9cb63402016-06-23 08:37:05 -070017class GrGpu;
Chris Daltonbca46e22017-05-15 11:03:26 -060018class GrMesh;
egdaniel9cb63402016-06-23 08:37:05 -070019class GrPipeline;
20class GrPrimitiveProcessor;
egdaniel066df7c2016-06-08 14:02:27 -070021class GrRenderTarget;
egdaniel9cb63402016-06-23 08:37:05 -070022struct SkIRect;
Greg Daniel36a77ee2016-10-18 10:33:25 -040023struct SkRect;
egdaniel066df7c2016-06-08 14:02:27 -070024
Greg Daniel500d58b2017-08-24 15:59:33 -040025class GrGpuRTCommandBuffer;
26
27class GrGpuCommandBuffer {
28public:
29 virtual ~GrGpuCommandBuffer() {}
30
31 // Copy src into current surface owned by either a GrGpuTextureCommandBuffer or
32 // GrGpuRenderTargetCommandBuffer.
Robert Phillipsb0e93a22017-08-29 08:26:54 -040033 virtual void copy(GrSurface* src, GrSurfaceOrigin srcOrigin,
34 const SkIRect& srcRect, const SkIPoint& dstPoint) = 0;
Greg Daniel500d58b2017-08-24 15:59:33 -040035
36 virtual void insertEventMarker(const char*) = 0;
37
38 virtual GrGpuRTCommandBuffer* asRTCommandBuffer() { return nullptr; }
39
40 // Sends the command buffer off to the GPU object to execute the commands built up in the
41 // buffer. The gpu object is allowed to defer execution of the commands until it is flushed.
42 virtual void submit() = 0;
43
44protected:
45 GrGpuCommandBuffer(GrSurfaceOrigin origin) : fOrigin(origin) {}
46
47 GrSurfaceOrigin fOrigin;
48};
49
50class GrGpuTextureCommandBuffer : public GrGpuCommandBuffer{
51public:
52 virtual ~GrGpuTextureCommandBuffer() {}
53
54 virtual void submit() = 0;
55
56protected:
57 GrGpuTextureCommandBuffer(GrTexture* texture, GrSurfaceOrigin origin)
58 : INHERITED(origin)
59 , fTexture(texture) {}
60
61 GrTexture* fTexture;
62
63private:
64 typedef GrGpuCommandBuffer INHERITED;
65};
66
egdaniel9cb63402016-06-23 08:37:05 -070067/**
Greg Daniel500d58b2017-08-24 15:59:33 -040068 * The GrGpuRenderTargetCommandBuffer is a series of commands (draws, clears, and discards), which
69 * all target the same render target. It is possible that these commands execute immediately (GL),
70 * or get buffered up for later execution (Vulkan). GrOps will execute their draw commands into a
egdaniel9cb63402016-06-23 08:37:05 -070071 * GrGpuCommandBuffer.
72 */
Greg Daniel500d58b2017-08-24 15:59:33 -040073class GrGpuRTCommandBuffer : public GrGpuCommandBuffer {
egdaniel066df7c2016-06-08 14:02:27 -070074public:
egdaniel9cb63402016-06-23 08:37:05 -070075 struct LoadAndStoreInfo {
Robert Phillips6b47c7d2017-08-29 07:24:09 -040076 GrLoadOp fLoadOp;
77 GrStoreOp fStoreOp;
78 GrColor fClearColor;
egdaniel066df7c2016-06-08 14:02:27 -070079 };
80
Robert Phillips95214472017-08-08 18:00:03 -040081 // Load-time clears of the stencil buffer are always to 0 so we don't store
82 // an 'fStencilClearValue'
83 struct StencilLoadAndStoreInfo {
Robert Phillips6b47c7d2017-08-29 07:24:09 -040084 GrLoadOp fLoadOp;
85 GrStoreOp fStoreOp;
Robert Phillips95214472017-08-08 18:00:03 -040086 };
87
Greg Daniel500d58b2017-08-24 15:59:33 -040088 virtual ~GrGpuRTCommandBuffer() {}
89
90 GrGpuRTCommandBuffer* asRTCommandBuffer() { return this; }
egdaniel066df7c2016-06-08 14:02:27 -070091
Robert Phillips95214472017-08-08 18:00:03 -040092 virtual void begin() = 0;
egdaniel066df7c2016-06-08 14:02:27 -070093 // Signals the end of recording to the command buffer and that it can now be submitted.
94 virtual void end() = 0;
95
egdaniel9cb63402016-06-23 08:37:05 -070096 // We pass in an array of meshCount GrMesh to the draw. The backend should loop over each
97 // GrMesh object and emit a draw for it. Each draw will use the same GrPipeline and
98 // GrPrimitiveProcessor. This may fail if the draw would exceed any resource limits (e.g.
99 // number of vertex attributes is too large).
Brian Salomonff168d92018-06-23 15:17:27 -0400100 bool draw(const GrPrimitiveProcessor&,
101 const GrPipeline&,
Brian Salomon49348902018-06-26 09:12:38 -0400102 const GrPipeline::FixedDynamicState*,
103 const GrPipeline::DynamicStateArrays*,
Chris Daltonbca46e22017-05-15 11:03:26 -0600104 const GrMesh[],
Greg Daniel36a77ee2016-10-18 10:33:25 -0400105 int meshCount,
106 const SkRect& bounds);
egdaniel9cb63402016-06-23 08:37:05 -0700107
Greg Daniel77b53f62016-10-18 11:48:51 -0400108 // Performs an upload of vertex data in the middle of a set of a set of draws
Brian Salomon943ed792017-10-30 09:37:55 -0400109 virtual void inlineUpload(GrOpFlushState*, GrDeferredTextureUploadFn&) = 0;
Greg Daniel77b53f62016-10-18 11:48:51 -0400110
egdaniel9cb63402016-06-23 08:37:05 -0700111 /**
Jim Van Verth6a40abc2017-11-02 16:56:09 +0000112 * Clear the owned render target. Ignores the draw state and clip.
Greg Daniel77b53f62016-10-18 11:48:51 -0400113 */
Robert Phillips19e51dc2017-08-09 09:30:51 -0400114 void clear(const GrFixedClip&, GrColor);
egdaniel9cb63402016-06-23 08:37:05 -0700115
Robert Phillips19e51dc2017-08-09 09:30:51 -0400116 void clearStencilClip(const GrFixedClip&, bool insideStencilMask);
Greg Daniel36a77ee2016-10-18 10:33:25 -0400117
egdaniel9cb63402016-06-23 08:37:05 -0700118 /**
Robert Phillips19e51dc2017-08-09 09:30:51 -0400119 * Discards the contents render target.
Greg Daniel77b53f62016-10-18 11:48:51 -0400120 */
egdaniel9cb63402016-06-23 08:37:05 -0700121 // TODO: This should be removed in the future to favor using the load and store ops for discard
Robert Phillips19e51dc2017-08-09 09:30:51 -0400122 virtual void discard() = 0;
egdaniel9cb63402016-06-23 08:37:05 -0700123
Robert Phillips19e51dc2017-08-09 09:30:51 -0400124protected:
Greg Daniel500d58b2017-08-24 15:59:33 -0400125 GrGpuRTCommandBuffer(GrRenderTarget* rt, GrSurfaceOrigin origin)
126 : INHERITED(origin)
127 , fRenderTarget(rt) {
128 }
129
Robert Phillips19e51dc2017-08-09 09:30:51 -0400130 GrRenderTarget* fRenderTarget;
Robert Phillips65a88fa2017-08-08 08:36:22 -0400131
egdaniel9cb63402016-06-23 08:37:05 -0700132private:
133 virtual GrGpu* gpu() = 0;
Greg Daniel65a09272016-10-12 09:47:22 -0400134
egdaniel9cb63402016-06-23 08:37:05 -0700135 // overridden by backend-specific derived class to perform the draw call.
Brian Salomonff168d92018-06-23 15:17:27 -0400136 virtual void onDraw(const GrPrimitiveProcessor&,
137 const GrPipeline&,
Brian Salomon49348902018-06-26 09:12:38 -0400138 const GrPipeline::FixedDynamicState*,
139 const GrPipeline::DynamicStateArrays*,
Chris Dalton46983b72017-06-06 12:27:16 -0600140 const GrMesh[],
Greg Daniel36a77ee2016-10-18 10:33:25 -0400141 int meshCount,
142 const SkRect& bounds) = 0;
egdaniel9cb63402016-06-23 08:37:05 -0700143
144 // overridden by backend-specific derived class to perform the clear.
Robert Phillips19e51dc2017-08-09 09:30:51 -0400145 virtual void onClear(const GrFixedClip&, GrColor) = 0;
egdaniel9cb63402016-06-23 08:37:05 -0700146
Robert Phillips19e51dc2017-08-09 09:30:51 -0400147 virtual void onClearStencilClip(const GrFixedClip&, bool insideStencilMask) = 0;
Greg Daniel500d58b2017-08-24 15:59:33 -0400148
149 typedef GrGpuCommandBuffer INHERITED;
egdaniel066df7c2016-06-08 14:02:27 -0700150};
151
152#endif