blob: cbc4f68de37791ee632878ae854fc87474911bc3 [file] [log] [blame]
robertphillips76948d42016-05-04 12:47:41 -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 GrRenderTargetProxy_DEFINED
9#define GrRenderTargetProxy_DEFINED
10
Mike Kleinc0bd9f92019-04-23 12:05:21 -050011#include "include/private/GrTypesPriv.h"
Greg Danielf91aeb22019-06-18 09:58:02 -040012#include "src/gpu/GrSurfaceProxy.h"
Greg Daniel2c19e7f2019-06-18 13:29:21 -040013#include "src/gpu/GrSwizzle.h"
robertphillips76948d42016-05-04 12:47:41 -070014
Brian Osman32342f02017-03-04 08:12:46 -050015class GrResourceProvider;
Greg Daniela070ed72018-04-26 16:31:38 -040016class GrRenderTargetProxyPriv;
robertphillips76948d42016-05-04 12:47:41 -070017
18// This class delays the acquisition of RenderTargets until they are actually
19// required
20// Beware: the uniqueID of the RenderTargetProxy will usually be different than
21// the uniqueID of the RenderTarget it represents!
Robert Phillips84a81202016-11-04 11:59:10 -040022class GrRenderTargetProxy : virtual public GrSurfaceProxy {
robertphillips76948d42016-05-04 12:47:41 -070023public:
robertphillips76948d42016-05-04 12:47:41 -070024 GrRenderTargetProxy* asRenderTargetProxy() override { return this; }
25 const GrRenderTargetProxy* asRenderTargetProxy() const override { return this; }
26
27 // Actually instantiate the backing rendertarget, if necessary.
Robert Phillips10d17212019-04-24 14:09:10 -040028 bool instantiate(GrResourceProvider*) override;
robertphillips76948d42016-05-04 12:47:41 -070029
Brian Salomon7c8460e2017-05-12 11:36:10 -040030 GrFSAAType fsaaType() const {
Brian Salomonbdecacf2018-02-02 20:32:49 -050031 if (fSampleCnt <= 1) {
Robert Phillipsfe0253f2018-03-16 16:47:25 -040032 SkASSERT(!this->hasMixedSamples());
Brian Salomon7c8460e2017-05-12 11:36:10 -040033 return GrFSAAType::kNone;
34 }
Robert Phillipsfe0253f2018-03-16 16:47:25 -040035 return this->hasMixedSamples() ? GrFSAAType::kMixedSamples : GrFSAAType::kUnifiedMSAA;
Brian Salomon7c8460e2017-05-12 11:36:10 -040036 }
Brian Salomonbb5711a2017-05-17 13:49:59 -040037
Robert Phillips65048132017-08-10 08:44:49 -040038 /*
39 * When instantiated does this proxy require a stencil buffer?
40 */
41 void setNeedsStencil() { fNeedsStencil = true; }
42 bool needsStencil() const { return fNeedsStencil; }
43
Brian Salomonbb5711a2017-05-17 13:49:59 -040044 /**
Brian Salomonbdecacf2018-02-02 20:32:49 -050045 * Returns the number of samples/pixel in the stencil buffer (One if non-MSAA).
Brian Salomonbb5711a2017-05-17 13:49:59 -040046 */
47 int numStencilSamples() const { return fSampleCnt; }
48
robertphillips76948d42016-05-04 12:47:41 -070049 /**
Brian Salomonbdecacf2018-02-02 20:32:49 -050050 * Returns the number of samples/pixel in the color buffer (One if non-MSAA or mixed sampled).
robertphillips76948d42016-05-04 12:47:41 -070051 */
Brian Salomon7c8460e2017-05-12 11:36:10 -040052 int numColorSamples() const {
Brian Salomonbdecacf2018-02-02 20:32:49 -050053 return GrFSAAType::kMixedSamples == this->fsaaType() ? 1 : fSampleCnt;
Brian Salomon7c8460e2017-05-12 11:36:10 -040054 }
robertphillips76948d42016-05-04 12:47:41 -070055
Robert Phillipsec2249f2016-11-09 08:54:35 -050056 int maxWindowRectangles(const GrCaps& caps) const;
57
Greg Daniel2c19e7f2019-06-18 13:29:21 -040058 const GrSwizzle& outputSwizzle() const { return fOutputSwizzle; }
59
Greg Danielb46add82019-01-02 14:51:29 -050060 bool wrapsVkSecondaryCB() const { return fWrapsVkSecondaryCB == WrapsVkSecondaryCB::kYes; }
61
Robert Phillipse2f7d182016-12-15 09:23:05 -050062 // TODO: move this to a priv class!
63 bool refsWrappedObjects() const;
64
Greg Daniela070ed72018-04-26 16:31:38 -040065 // Provides access to special purpose functions.
66 GrRenderTargetProxyPriv rtPriv();
67 const GrRenderTargetProxyPriv rtPriv() const;
68
Robert Phillips84a81202016-11-04 11:59:10 -040069protected:
Robert Phillips0bd24dc2018-01-16 08:06:32 -050070 friend class GrProxyProvider; // for ctors
Greg Daniela070ed72018-04-26 16:31:38 -040071 friend class GrRenderTargetProxyPriv;
Robert Phillips37430132016-11-09 06:50:43 -050072
csmartdaltonf9635992016-08-10 11:09:07 -070073 // Deferred version
Greg Daniel4065d452018-11-16 15:43:41 -050074 GrRenderTargetProxy(const GrCaps&, const GrBackendFormat&, const GrSurfaceDesc&,
Greg Daniel2c19e7f2019-06-18 13:29:21 -040075 GrSurfaceOrigin, const GrSwizzle& textureSwizzle,
76 const GrSwizzle& outputSwizzle, SkBackingFit, SkBudgeted,
77 GrInternalSurfaceFlags);
robertphillips76948d42016-05-04 12:47:41 -070078
Greg Danielb085fa92019-03-05 16:55:12 -050079 enum class WrapsVkSecondaryCB : bool { kNo = false, kYes = true };
80
Chris Dalton706a6ff2017-11-29 22:01:06 -070081 // Lazy-callback version
Greg Daniel65fa8ca2018-01-10 17:06:31 -050082 // There are two main use cases for lazily-instantiated proxies:
83 // basic knowledge - width, height, config, samples, origin are known
84 // minimal knowledge - only config is known.
85 //
86 // The basic knowledge version is used for DDL where we know the type of proxy we are going to
87 // use, but we don't have access to the GPU yet to instantiate it.
88 //
89 // The minimal knowledge version is used for CCPR where we are generating an atlas but we do not
90 // know the final size until flush time.
Greg Daniel457469c2018-02-08 15:05:44 -050091 GrRenderTargetProxy(LazyInstantiateCallback&&, LazyInstantiationType lazyType,
Greg Daniel4065d452018-11-16 15:43:41 -050092 const GrBackendFormat&, const GrSurfaceDesc&, GrSurfaceOrigin,
Greg Daniel2c19e7f2019-06-18 13:29:21 -040093 const GrSwizzle& textureSwizzle, const GrSwizzle& outputSwizzle,
Greg Danielb085fa92019-03-05 16:55:12 -050094 SkBackingFit, SkBudgeted, GrInternalSurfaceFlags,
95 WrapsVkSecondaryCB wrapsVkSecondaryCB);
Chris Dalton706a6ff2017-11-29 22:01:06 -070096
robertphillips76948d42016-05-04 12:47:41 -070097 // Wrapped version
Greg Daniel2c19e7f2019-06-18 13:29:21 -040098 GrRenderTargetProxy(sk_sp<GrSurface>, GrSurfaceOrigin, const GrSwizzle& textureSwizzle,
99 const GrSwizzle& outputSwizzle,
Greg Danielb46add82019-01-02 14:51:29 -0500100 WrapsVkSecondaryCB wrapsVkSecondaryCB = WrapsVkSecondaryCB::kNo);
robertphillips76948d42016-05-04 12:47:41 -0700101
Robert Phillips5af44de2017-07-18 14:49:38 -0400102 sk_sp<GrSurface> createSurface(GrResourceProvider*) const override;
103
Robert Phillips84a81202016-11-04 11:59:10 -0400104private:
Greg Daniela070ed72018-04-26 16:31:38 -0400105 void setHasMixedSamples() {
106 fSurfaceFlags |= GrInternalSurfaceFlags::kMixedSampled;
107 }
108 bool hasMixedSamples() const { return fSurfaceFlags & GrInternalSurfaceFlags::kMixedSampled; }
109
Greg Daniela070ed72018-04-26 16:31:38 -0400110 void setGLRTFBOIDIs0() {
111 fSurfaceFlags |= GrInternalSurfaceFlags::kGLRTFBOIDIs0;
112 }
113 bool glRTFBOIDIs0() const {
114 return fSurfaceFlags & GrInternalSurfaceFlags::kGLRTFBOIDIs0;
115 }
116
117
Brian Salomonbb5711a2017-05-17 13:49:59 -0400118 size_t onUninstantiatedGpuMemorySize() const override;
Greg Daniel849dce12018-04-24 14:32:53 -0400119 SkDEBUGCODE(void onValidateSurface(const GrSurface*) override;)
Robert Phillips8bc06d02016-11-01 17:28:40 -0400120
Brian Osman086679b2018-09-10 16:26:51 -0400121 // WARNING: Be careful when adding or removing fields here. ASAN is likely to trigger warnings
122 // when instantiating GrTextureRenderTargetProxy. The std::function in GrSurfaceProxy makes
123 // each class in the diamond require 16 byte alignment. Clang appears to layout the fields for
124 // each class to achieve the necessary alignment. However, ASAN checks the alignment of 'this'
125 // in the constructors, and always looks for the full 16 byte alignment, even if the fields in
126 // that particular class don't require it. Changing the size of this object can move the start
127 // address of other types, leading to this problem.
Greg Danielb46add82019-01-02 14:51:29 -0500128 int fSampleCnt;
Greg Daniel2c19e7f2019-06-18 13:29:21 -0400129 GrSwizzle fOutputSwizzle;
Greg Danielb46add82019-01-02 14:51:29 -0500130 bool fNeedsStencil;
131 WrapsVkSecondaryCB fWrapsVkSecondaryCB;
Greg Daniel2c19e7f2019-06-18 13:29:21 -0400132 // This is to fix issue in large comment above. Without the padding we end 6 bytes into a 16
133 // byte range, so the GrTextureProxy ends up starting 8 byte aligned by not 16. We add the
134 // padding here to get us right up to the 16 byte alignment (technically any padding of 3-10
135 // bytes would work since it always goes up to 8 byte alignment, but we use 10 to more explicit
136 // about what we're doing).
137 char fDummyPadding[10];
Robert Phillips65048132017-08-10 08:44:49 -0400138
Robert Phillipsc7635fa2016-10-28 13:25:24 -0400139 // For wrapped render targets the actual GrRenderTarget is stored in the GrIORefProxy class.
140 // For deferred proxies that pointer is filled in when we need to instantiate the
141 // deferred resource.
robertphillips76948d42016-05-04 12:47:41 -0700142
robertphillips76948d42016-05-04 12:47:41 -0700143 typedef GrSurfaceProxy INHERITED;
144};
145
146#endif