Revert "Don't keep a non-msaa FBO with EXT_multisampled_render_to_texture"
This reverts commit 6694a36a7f
.
Reason for revert: Issues with Adreno GMs.
Original change's description:
> Don't keep a non-msaa FBO with EXT_multisampled_render_to_texture
>
> This seems to cause bugs on various platforms. Instead, do the same
> thing we do for dmsaa: reconfigure a single FBO as msaa or not,
> based on need.
>
> Bug: chromium:1222095
> Change-Id: I4ca4aff32772ee2a9607c92c586ae9494f955229
> Reviewed-on: https://skia-review.googlesource.com/c/skia/+/442565
> Commit-Queue: Jim Van Verth <jvanverth@google.com>
> Reviewed-by: Brian Salomon <bsalomon@google.com>
Bug: chromium:1222095
Change-Id: I060988c63edbfeb628d5a6c34cda3e159066114a
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/449918
Bot-Commit: Rubber Stamper <rubber-stamper@appspot.gserviceaccount.com>
Commit-Queue: Jim Van Verth <jvanverth@google.com>
This commit is contained in:
parent
3299eb7feb
commit
dcfa824c38
@ -1217,20 +1217,19 @@ bool GrGLGpu::createRenderTargetObjects(const GrGLTexture::Desc& desc,
|
|||||||
// rendered from.
|
// rendered from.
|
||||||
if (sampleCount <= 1) {
|
if (sampleCount <= 1) {
|
||||||
rtIDs->fMultisampleFBOID = GrGLRenderTarget::kUnresolvableFBOID;
|
rtIDs->fMultisampleFBOID = GrGLRenderTarget::kUnresolvableFBOID;
|
||||||
} else if (this->glCaps().usesImplicitMSAAResolve()) {
|
|
||||||
// GrGLRenderTarget target will configure the FBO as multisample or not base on need.
|
|
||||||
rtIDs->fMultisampleFBOID = rtIDs->fSingleSampleFBOID;
|
|
||||||
} else {
|
} else {
|
||||||
GL_CALL(GenFramebuffers(1, &rtIDs->fMultisampleFBOID));
|
GL_CALL(GenFramebuffers(1, &rtIDs->fMultisampleFBOID));
|
||||||
if (!rtIDs->fMultisampleFBOID) {
|
if (!rtIDs->fMultisampleFBOID) {
|
||||||
goto FAILED;
|
goto FAILED;
|
||||||
}
|
}
|
||||||
|
if (!this->glCaps().usesImplicitMSAAResolve()) {
|
||||||
GL_CALL(GenRenderbuffers(1, &rtIDs->fMSColorRenderbufferID));
|
GL_CALL(GenRenderbuffers(1, &rtIDs->fMSColorRenderbufferID));
|
||||||
if (!rtIDs->fMSColorRenderbufferID) {
|
if (!rtIDs->fMSColorRenderbufferID) {
|
||||||
goto FAILED;
|
goto FAILED;
|
||||||
}
|
}
|
||||||
colorRenderbufferFormat = this->glCaps().getRenderbufferInternalFormat(desc.fFormat);
|
colorRenderbufferFormat = this->glCaps().getRenderbufferInternalFormat(desc.fFormat);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// below here we may bind the FBO
|
// below here we may bind the FBO
|
||||||
fHWBoundRenderTargetUniqueID.makeInvalid();
|
fHWBoundRenderTargetUniqueID.makeInvalid();
|
||||||
@ -1247,6 +1246,16 @@ bool GrGLGpu::createRenderTargetObjects(const GrGLTexture::Desc& desc,
|
|||||||
GR_GL_RENDERBUFFER,
|
GR_GL_RENDERBUFFER,
|
||||||
rtIDs->fMSColorRenderbufferID));
|
rtIDs->fMSColorRenderbufferID));
|
||||||
rtIDs->fTotalMemorySamplesPerPixel += sampleCount;
|
rtIDs->fTotalMemorySamplesPerPixel += sampleCount;
|
||||||
|
} else if (sampleCount > 1) {
|
||||||
|
// multisampled_render_to_texture
|
||||||
|
SkASSERT(this->glCaps().usesImplicitMSAAResolve()); // Otherwise fMSColorRenderbufferID!=0.
|
||||||
|
this->bindFramebuffer(GR_GL_FRAMEBUFFER, rtIDs->fMultisampleFBOID);
|
||||||
|
GL_CALL(FramebufferTexture2DMultisample(GR_GL_FRAMEBUFFER,
|
||||||
|
GR_GL_COLOR_ATTACHMENT0,
|
||||||
|
desc.fTarget,
|
||||||
|
desc.fID,
|
||||||
|
0,
|
||||||
|
sampleCount));
|
||||||
}
|
}
|
||||||
|
|
||||||
this->bindFramebuffer(GR_GL_FRAMEBUFFER, rtIDs->fSingleSampleFBOID);
|
this->bindFramebuffer(GR_GL_FRAMEBUFFER, rtIDs->fSingleSampleFBOID);
|
||||||
|
Loading…
Reference in New Issue
Block a user