Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "config.h" | 5 #include "config.h" |
| 6 #include "platform/graphics/paint/PaintController.h" | 6 #include "platform/graphics/paint/PaintController.h" |
| 7 | 7 |
| 8 #include "platform/NotImplemented.h" | 8 #include "platform/NotImplemented.h" |
| 9 #include "platform/TraceEvent.h" | 9 #include "platform/TraceEvent.h" |
| 10 #include "platform/graphics/GraphicsLayer.h" | 10 #include "platform/graphics/GraphicsLayer.h" |
| (...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 117 invalidateClient(client); | 117 invalidateClient(client); |
| 118 | 118 |
| 119 if (visualRect) { | 119 if (visualRect) { |
| 120 // TODO(wkorman): cache visualRect for the client. | 120 // TODO(wkorman): cache visualRect for the client. |
| 121 } | 121 } |
| 122 } | 122 } |
| 123 | 123 |
| 124 void PaintController::invalidateClient(const DisplayItemClientWrapper& client) | 124 void PaintController::invalidateClient(const DisplayItemClientWrapper& client) |
| 125 { | 125 { |
| 126 #if ENABLE(ASSERT) | 126 #if ENABLE(ASSERT) |
| 127 m_invalidations.append(client.debugName()); | 127 // Slimming paint v1 CompositedLayerMapping may invalidate client on extra l ayers. |
|
chrishtr
2015/10/28 21:12:58
v2 or v1?
Xianzhu
2015/10/29 04:22:01
v1. For example, in invalidatePaintIncludingNonCom
chrishtr
2015/10/29 20:22:45
Yikes. How does this situation avoid causing the w
Xianzhu
2015/10/30 00:03:57
Sometimes somehow we also invalidate the object in
Xianzhu
2015/10/30 18:05:51
Also crbug.com/416535.
| |
| 128 if (RuntimeEnabledFeatures::slimmingPaintV2Enabled() || clientCacheIsValid(c lient.displayItemClient())) | |
| 129 m_invalidations.append(client.debugName()); | |
| 128 #endif | 130 #endif |
| 129 | 131 |
| 130 invalidateUntracked(client.displayItemClient()); | 132 invalidateUntracked(client.displayItemClient()); |
| 131 if (RuntimeEnabledFeatures::slimmingPaintV2Enabled() && m_trackedPaintInvali dationObjects) | 133 if (RuntimeEnabledFeatures::slimmingPaintV2Enabled() && m_trackedPaintInvali dationObjects) |
| 132 m_trackedPaintInvalidationObjects->append(client.debugName()); | 134 m_trackedPaintInvalidationObjects->append(client.debugName()); |
| 133 } | 135 } |
| 134 | 136 |
| 135 void PaintController::invalidateUntracked(DisplayItemClient client) | 137 void PaintController::invalidateUntracked(DisplayItemClient client) |
| 136 { | 138 { |
| 137 // This can be called during painting, but we can't invalidate already paint ed clients. | 139 // This can be called during painting, but we can't invalidate already paint ed clients. |
| (...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 271 { | 273 { |
| 272 TRACE_EVENT2("blink,benchmark", "PaintController::commitNewDisplayItems", | 274 TRACE_EVENT2("blink,benchmark", "PaintController::commitNewDisplayItems", |
| 273 "current_display_list_size", (int)m_currentPaintArtifact.displayItemList ().size(), | 275 "current_display_list_size", (int)m_currentPaintArtifact.displayItemList ().size(), |
| 274 "num_non_cached_new_items", (int)m_newDisplayItemList.size() - m_numCach edItems); | 276 "num_non_cached_new_items", (int)m_newDisplayItemList.size() - m_numCach edItems); |
| 275 | 277 |
| 276 if (RuntimeEnabledFeatures::slimmingPaintSynchronizedPaintingEnabled() | 278 if (RuntimeEnabledFeatures::slimmingPaintSynchronizedPaintingEnabled() |
| 277 && !m_newDisplayItemList.isEmpty() | 279 && !m_newDisplayItemList.isEmpty() |
| 278 && m_newDisplayItemList.last().type() == DisplayItem::CachedDisplayItemL ist) { | 280 && m_newDisplayItemList.last().type() == DisplayItem::CachedDisplayItemL ist) { |
| 279 // The whole display item list is cached. | 281 // The whole display item list is cached. |
| 280 ASSERT(m_newDisplayItemList.size() == 1 | 282 ASSERT(m_newDisplayItemList.size() == 1 |
| 281 || (m_newDisplayItemList.size() == 2 && m_newDisplayItemList[0].type () == DisplayItem::DebugRedFill)); | 283 || (m_newDisplayItemList.size() == 2 && DisplayItem::nonCachedType(m _newDisplayItemList[0].type()) == DisplayItem::DebugRedFill)); |
|
pdr.
2015/10/29 04:06:10
Why does synchronous painting cause us to hit this
Xianzhu
2015/10/29 04:22:01
This assert is only for CachedDisplayItemList whic
| |
| 282 ASSERT(m_invalidations.isEmpty()); | 284 ASSERT(m_invalidations.isEmpty()); |
| 283 ASSERT(m_clientsCheckedPaintInvalidation.isEmpty()); | 285 ASSERT(m_clientsCheckedPaintInvalidation.isEmpty()); |
| 284 m_newDisplayItemList.clear(); | 286 m_newDisplayItemList.clear(); |
| 285 m_newPaintChunks.clear(); | 287 m_newPaintChunks.clear(); |
| 286 return; | 288 return; |
| 287 } | 289 } |
| 288 if (RuntimeEnabledFeatures::slimmingPaintV2Enabled()) | 290 if (RuntimeEnabledFeatures::slimmingPaintV2Enabled()) |
| 289 m_clientsCheckedPaintInvalidation.clear(); | 291 m_clientsCheckedPaintInvalidation.clear(); |
| 290 | 292 |
| 291 // These data structures are used during painting only. | 293 // These data structures are used during painting only. |
| (...skipping 270 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 562 | 564 |
| 563 void PaintController::showDebugData() const | 565 void PaintController::showDebugData() const |
| 564 { | 566 { |
| 565 WTFLogAlways("current display item list: [%s]\n", displayItemListAsDebugStri ng(m_currentPaintArtifact.displayItemList()).utf8().data()); | 567 WTFLogAlways("current display item list: [%s]\n", displayItemListAsDebugStri ng(m_currentPaintArtifact.displayItemList()).utf8().data()); |
| 566 WTFLogAlways("new display item list: [%s]\n", displayItemListAsDebugString(m _newDisplayItemList).utf8().data()); | 568 WTFLogAlways("new display item list: [%s]\n", displayItemListAsDebugString(m _newDisplayItemList).utf8().data()); |
| 567 } | 569 } |
| 568 | 570 |
| 569 #endif // ifndef NDEBUG | 571 #endif // ifndef NDEBUG |
| 570 | 572 |
| 571 } // namespace blink | 573 } // namespace blink |
| OLD | NEW |