| Index: src/gpu/gl/GrGLXferProcessor.cpp | 
| diff --git a/src/gpu/gl/GrGLXferProcessor.cpp b/src/gpu/gl/GrGLXferProcessor.cpp | 
| index 3d3ab49dadc89ba64e0c84c40ca21284286af26a..e62497193fbcc38a39c42b2138ee0fe3ca50e26c 100644 | 
| --- a/src/gpu/gl/GrGLXferProcessor.cpp | 
| +++ b/src/gpu/gl/GrGLXferProcessor.cpp | 
| @@ -63,7 +63,14 @@ void GrGLXferProcessor::emitCode(const EmitArgs& args) { | 
| args.fXP); | 
|  | 
| // Apply coverage. | 
| -    if (args.fXP.readsCoverage()) { | 
| +    if (args.fXP.dstReadUsesMixedSamples()) { | 
| +        if (args.fXP.readsCoverage()) { | 
| +            fsBuilder->codeAppendf("%s *= %s;", args.fOutputPrimary, args.fInputCoverage); | 
| +            fsBuilder->codeAppendf("%s = %s;", args.fOutputSecondary, args.fInputCoverage); | 
| +        } else { | 
| +            fsBuilder->codeAppendf("%s = vec4(1.0);", args.fOutputSecondary); | 
| +        } | 
| +    } else if (args.fXP.readsCoverage()) { | 
| fsBuilder->codeAppendf("%s = %s * %s + (vec4(1.0) - %s) * %s;", | 
| args.fOutputPrimary, args.fInputCoverage, | 
| args.fOutputPrimary, args.fInputCoverage, dstColor); | 
|  |