| Index: src/gpu/gl/GrGLGpu.cpp
|
| diff --git a/src/gpu/gl/GrGLGpu.cpp b/src/gpu/gl/GrGLGpu.cpp
|
| index 5388387c3b0104a198ab58bae9b6c5b974fde7ce..cd6bf39adc76c71f3ee6c3172fe24e164eb49f71 100644
|
| --- a/src/gpu/gl/GrGLGpu.cpp
|
| +++ b/src/gpu/gl/GrGLGpu.cpp
|
| @@ -1476,7 +1476,7 @@ bool GrGLGpu::flushGLState(const DrawArgs& args) {
|
| GrGLRenderTarget* glRT = static_cast<GrGLRenderTarget*>(pipeline.getRenderTarget());
|
| this->flushStencil(pipeline.getStencil());
|
| this->flushScissor(pipeline.getScissorState(), glRT->getViewport(), glRT->origin());
|
| - this->flushHWAAState(glRT, pipeline.isHWAntialiasState());
|
| + this->flushHWAAState(glRT, pipeline.isHWAntialiasState(), !pipeline.getStencil().isDisabled());
|
|
|
| // This must come after textures are flushed because a texture may need
|
| // to be msaa-resolved (which will modify bound FBO state).
|
| @@ -1899,6 +1899,22 @@ bool GrGLGpu::onReadPixels(GrSurface* surface,
|
| return true;
|
| }
|
|
|
| +void GrGLGpu::setColocatedSampleLocations(GrRenderTarget* rt, bool useColocatedSampleLocations) {
|
| + GrGLRenderTarget* target = static_cast<GrGLRenderTarget*>(rt->asRenderTarget());
|
| + SkASSERT(0 != target->renderFBOID());
|
| +
|
| + if (!rt->isStencilBufferMultisampled() ||
|
| + useColocatedSampleLocations == target->usesColocatedSampleLocations()) {
|
| + return;
|
| + }
|
| +
|
| + GL_CALL(NamedFramebufferParameteri(target->renderFBOID(),
|
| + GR_GL_FRAMEBUFFER_PROGRAMMABLE_SAMPLE_LOCATIONS,
|
| + useColocatedSampleLocations));
|
| +
|
| + target->flagAsUsingColocatedSampleLocations(useColocatedSampleLocations);
|
| +}
|
| +
|
| void GrGLGpu::flushRenderTarget(GrGLRenderTarget* target, const SkIRect* bound) {
|
|
|
| SkASSERT(target);
|
| @@ -2146,9 +2162,19 @@ void GrGLGpu::flushStencil(const GrStencilSettings& stencilSettings) {
|
| }
|
| }
|
|
|
| -void GrGLGpu::flushHWAAState(GrRenderTarget* rt, bool useHWAA) {
|
| +void GrGLGpu::flushHWAAState(GrRenderTarget* rt, bool useHWAA, bool stencilEnabled) {
|
| SkASSERT(!useHWAA || rt->isStencilBufferMultisampled());
|
|
|
| + if (rt->hasMixedSamples() && stencilEnabled &&
|
| + this->glCaps().glslCaps()->programmableSampleLocationsSupport()) {
|
| + if (useHWAA) {
|
| + this->setColocatedSampleLocations(rt, false);
|
| + } else {
|
| + this->setColocatedSampleLocations(rt, true);
|
| + }
|
| + useHWAA = true;
|
| + }
|
| +
|
| if (this->glCaps().multisampleDisableSupport()) {
|
| if (useHWAA) {
|
| if (kYes_TriState != fMSAAEnabled) {
|
| @@ -2928,7 +2954,7 @@ void GrGLGpu::copySurfaceAsDraw(GrSurface* dst,
|
| this->flushBlend(blendInfo);
|
| this->flushColorWrite(true);
|
| this->flushDrawFace(GrPipelineBuilder::kBoth_DrawFace);
|
| - this->flushHWAAState(dstRT, false);
|
| + this->flushHWAAState(dstRT, false, false);
|
| this->disableScissor();
|
| GrStencilSettings stencil;
|
| stencil.setDisabled();
|
|
|