Index: cc/trees/occlusion_tracker.cc |
diff --git a/cc/trees/occlusion_tracker.cc b/cc/trees/occlusion_tracker.cc |
index 8f98c279a421c2fa5654d1cff09f92003744f61b..e44aa4911a7a3df94e92fc8b6f638e00d9427956 100644 |
--- a/cc/trees/occlusion_tracker.cc |
+++ b/cc/trees/occlusion_tracker.cc |
@@ -233,9 +233,9 @@ void OcclusionTrackerBase<LayerType, RenderSurfaceType>::FinishedRenderTarget( |
// If the occlusion within the surface can not be applied to things outside of |
// the surface's subtree, then clear the occlusion here so it won't be used. |
- if (finished_target->mask_layer() || |
- !SurfaceOpacityKnown(surface) || |
+ if (finished_target->mask_layer() || !SurfaceOpacityKnown(surface) || |
surface->draw_opacity() < 1 || |
+ !finished_target->uses_default_blend_mode() || |
target_is_only_for_copy_request || |
finished_target->filters().HasFilterThatAffectsOpacity()) { |
stack_.back().occlusion_from_outside_target.Clear(); |
@@ -414,6 +414,9 @@ void OcclusionTrackerBase<LayerType, RenderSurfaceType>:: |
if (!LayerOpacityKnown(layer) || layer->draw_opacity() < 1) |
return; |
+ if (!layer->uses_default_blend_mode()) |
+ return; |
+ |
if (LayerIsInUnsorted3dRenderingContext(layer)) |
return; |