blob: fcb0b3575c6b8c361b3712af99d833de21ef6a49 [file] [log] [blame]
bsalomon@google.comaa5b6732011-07-29 15:13:20 +00001/*
2 * Copyright 2011 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
Mike Kleinc0bd9f92019-04-23 12:05:21 -05009#include "include/gpu/GrRenderTarget.h"
bsalomon@google.comaa5b6732011-07-29 15:13:20 +000010
Mike Kleinc0bd9f92019-04-23 12:05:21 -050011#include "include/gpu/GrContext.h"
12#include "src/core/SkRectPriv.h"
13#include "src/gpu/GrContextPriv.h"
14#include "src/gpu/GrGpu.h"
15#include "src/gpu/GrRenderTargetContext.h"
16#include "src/gpu/GrRenderTargetOpList.h"
17#include "src/gpu/GrRenderTargetPriv.h"
18#include "src/gpu/GrSamplePatternDictionary.h"
19#include "src/gpu/GrStencilAttachment.h"
20#include "src/gpu/GrStencilSettings.h"
bsalomon@google.comaa5b6732011-07-29 15:13:20 +000021
Brian Salomone8a766b2019-07-19 14:24:36 -040022GrRenderTarget::GrRenderTarget(GrGpu* gpu, const GrSurfaceDesc& desc, GrProtected isProtected,
csmartdaltonf9635992016-08-10 11:09:07 -070023 GrStencilAttachment* stencil)
Brian Salomone8a766b2019-07-19 14:24:36 -040024 : INHERITED(gpu, desc, isProtected)
Brian Salomond34edf32017-05-19 15:45:48 -040025 , fSampleCnt(desc.fSampleCnt)
Chris Daltond7291ba2019-03-07 14:17:03 -070026 , fSamplePatternKey(GrSamplePatternDictionary::kInvalidSamplePatternKey)
Robert Phillipsfe0253f2018-03-16 16:47:25 -040027 , fStencilAttachment(stencil) {
Mike Reed274218e2018-01-08 15:05:02 -050028 fResolveRect = SkRectPriv::MakeILargestInverted();
csmartdaltonf9635992016-08-10 11:09:07 -070029}
30
Ben Wagner9ec70c62018-07-12 13:30:47 -040031GrRenderTarget::~GrRenderTarget() = default;
32
commit-bot@chromium.orgfd03d4a2013-07-17 21:39:42 +000033void GrRenderTarget::flagAsNeedingResolve(const SkIRect* rect) {
bsalomon@google.comaa5b6732011-07-29 15:13:20 +000034 if (kCanResolve_ResolveType == getResolveType()) {
bsalomon49f085d2014-09-05 13:34:00 -070035 if (rect) {
bsalomon@google.comaa5b6732011-07-29 15:13:20 +000036 fResolveRect.join(*rect);
37 if (!fResolveRect.intersect(0, 0, this->width(), this->height())) {
38 fResolveRect.setEmpty();
39 }
40 } else {
41 fResolveRect.setLTRB(0, 0, this->width(), this->height());
42 }
43 }
44}
45
commit-bot@chromium.orgfd03d4a2013-07-17 21:39:42 +000046void GrRenderTarget::overrideResolveRect(const SkIRect rect) {
bsalomon@google.comaa5b6732011-07-29 15:13:20 +000047 fResolveRect = rect;
48 if (fResolveRect.isEmpty()) {
Mike Reed274218e2018-01-08 15:05:02 -050049 fResolveRect = SkRectPriv::MakeILargestInverted();
bsalomon@google.comaa5b6732011-07-29 15:13:20 +000050 } else {
51 if (!fResolveRect.intersect(0, 0, this->width(), this->height())) {
Mike Reed274218e2018-01-08 15:05:02 -050052 fResolveRect = SkRectPriv::MakeILargestInverted();
bsalomon@google.comaa5b6732011-07-29 15:13:20 +000053 }
54 }
bsalomon@google.com81c3f8d2011-08-03 15:18:33 +000055}
56
Mike Reed274218e2018-01-08 15:05:02 -050057void GrRenderTarget::flagAsResolved() {
58 fResolveRect = SkRectPriv::MakeILargestInverted();
59}
60
robertphillips@google.comd6bbbf82012-09-05 15:46:34 +000061void GrRenderTarget::onRelease() {
Ben Wagner9ec70c62018-07-12 13:30:47 -040062 fStencilAttachment = nullptr;
robertphillips@google.comd3645542012-09-05 18:37:39 +000063
64 INHERITED::onRelease();
robertphillips@google.comd6bbbf82012-09-05 15:46:34 +000065}
66
67void GrRenderTarget::onAbandon() {
Ben Wagner9ec70c62018-07-12 13:30:47 -040068 fStencilAttachment = nullptr;
robertphillips498d7ac2015-10-30 10:11:30 -070069
robertphillips@google.comd3645542012-09-05 18:37:39 +000070 INHERITED::onAbandon();
robertphillips@google.comd6bbbf82012-09-05 15:46:34 +000071}
bsalomon6bc1b5f2015-02-23 09:06:38 -080072
73///////////////////////////////////////////////////////////////////////////////
74
Greg Danielcfa39352018-10-05 12:01:59 -040075void GrRenderTargetPriv::attachStencilAttachment(sk_sp<GrStencilAttachment> stencil) {
Chris Daltoneffee202019-07-01 22:28:03 -060076#ifdef SK_DEBUG
77 if (1 == fRenderTarget->fSampleCnt) {
78 // TODO: We don't expect a mixed sampled render target to ever change its stencil buffer
79 // right now. But if it does swap in a stencil buffer with a different number of samples,
80 // and if we have a valid fSamplePatternKey, we will need to invalidate fSamplePatternKey
81 // here and add tests to make sure we it properly.
82 SkASSERT(GrSamplePatternDictionary::kInvalidSamplePatternKey ==
83 fRenderTarget->fSamplePatternKey);
84 } else {
85 // Render targets with >1 color sample should never use mixed samples. (This would lead to
86 // different sample patterns, depending on stencil state.)
87 SkASSERT(!stencil || stencil->numSamples() == fRenderTarget->fSampleCnt);
88 }
89#endif
90
egdaniel79bd2ae2015-09-15 08:46:13 -070091 if (!stencil && !fRenderTarget->fStencilAttachment) {
92 // No need to do any work since we currently don't have a stencil attachment and
Robert Phillips29e52f12016-11-03 10:19:14 -040093 // we're not actually adding one.
Greg Danielcfa39352018-10-05 12:01:59 -040094 return;
egdaniel79bd2ae2015-09-15 08:46:13 -070095 }
Chris Daltoneffee202019-07-01 22:28:03 -060096
Ben Wagner9ec70c62018-07-12 13:30:47 -040097 fRenderTarget->fStencilAttachment = std::move(stencil);
egdanielec00d942015-09-14 12:56:10 -070098 if (!fRenderTarget->completeStencilAttachment()) {
Ben Wagner9ec70c62018-07-12 13:30:47 -040099 fRenderTarget->fStencilAttachment = nullptr;
halcanary9d524f22016-03-29 09:03:52 -0700100 }
bsalomon6bc1b5f2015-02-23 09:06:38 -0800101}
cdalton28f45b92016-03-07 13:58:26 -0800102
cdalton193d9cf2016-05-12 11:52:02 -0700103int GrRenderTargetPriv::numStencilBits() const {
csmartdaltonc633abb2016-11-01 08:55:55 -0700104 SkASSERT(this->getStencilAttachment());
105 return this->getStencilAttachment()->bits();
cdalton193d9cf2016-05-12 11:52:02 -0700106}
Chris Daltond7291ba2019-03-07 14:17:03 -0700107
Chris Dalton8c4cafd2019-04-15 19:14:36 -0600108int GrRenderTargetPriv::getSamplePatternKey() const {
Chris Daltoneffee202019-07-01 22:28:03 -0600109#ifdef SK_DEBUG
110 GrStencilAttachment* stencil = fRenderTarget->fStencilAttachment.get();
111 if (fRenderTarget->fSampleCnt <= 1) {
112 // If the color buffer is not multisampled, the sample pattern better come from the stencil
113 // buffer (mixed samples).
114 SkASSERT(stencil && stencil->numSamples() > 1);
115 } else {
116 // The color sample count and stencil count cannot both be unequal and both greater than
117 // one. If this were the case, there would be more than one sample pattern associated with
118 // the render target.
119 SkASSERT(!stencil || stencil->numSamples() == fRenderTarget->fSampleCnt);
120 }
121#endif
Chris Daltond7291ba2019-03-07 14:17:03 -0700122 if (GrSamplePatternDictionary::kInvalidSamplePatternKey == fRenderTarget->fSamplePatternKey) {
123 fRenderTarget->fSamplePatternKey =
Chris Dalton8c4cafd2019-04-15 19:14:36 -0600124 fRenderTarget->getGpu()->findOrAssignSamplePatternKey(fRenderTarget);
Chris Daltond7291ba2019-03-07 14:17:03 -0700125 }
126 SkASSERT(GrSamplePatternDictionary::kInvalidSamplePatternKey
127 != fRenderTarget->fSamplePatternKey);
Chris Daltond7291ba2019-03-07 14:17:03 -0700128 return fRenderTarget->fSamplePatternKey;
129}