| 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 #ifndef PaintController_h | 5 #ifndef PaintController_h |
| 6 #define PaintController_h | 6 #define PaintController_h |
| 7 | 7 |
| 8 #include "platform/PlatformExport.h" | 8 #include "platform/PlatformExport.h" |
| 9 #include "platform/RuntimeEnabledFeatures.h" | 9 #include "platform/RuntimeEnabledFeatures.h" |
| 10 #include "platform/geometry/IntRect.h" | 10 #include "platform/geometry/IntRect.h" |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 72 static_assert(WTF::IsSubclass<DisplayItemClass, DisplayItem>::value, | 72 static_assert(WTF::IsSubclass<DisplayItemClass, DisplayItem>::value, |
| 73 "Can only createAndAppend subclasses of DisplayItem."); | 73 "Can only createAndAppend subclasses of DisplayItem."); |
| 74 static_assert(sizeof(DisplayItemClass) <= kMaximumDisplayItemSize, | 74 static_assert(sizeof(DisplayItemClass) <= kMaximumDisplayItemSize, |
| 75 "DisplayItem subclass is larger than kMaximumDisplayItemSize."); | 75 "DisplayItem subclass is larger than kMaximumDisplayItemSize."); |
| 76 | 76 |
| 77 if (displayItemConstructionIsDisabled()) | 77 if (displayItemConstructionIsDisabled()) |
| 78 return; | 78 return; |
| 79 | 79 |
| 80 ensureNewDisplayItemListInitialCapacity(); | 80 ensureNewDisplayItemListInitialCapacity(); |
| 81 DisplayItemClass& displayItem = m_newDisplayItemList.allocateAndConstruc
t<DisplayItemClass>(std::forward<Args>(args)...); | 81 DisplayItemClass& displayItem = m_newDisplayItemList.allocateAndConstruc
t<DisplayItemClass>(std::forward<Args>(args)...); |
| 82 processNewItem(displayItem, NewPainting); | 82 processNewItem(displayItem); |
| 83 } | 83 } |
| 84 | 84 |
| 85 // Creates and appends an ending display item to pair with a preceding | 85 // Creates and appends an ending display item to pair with a preceding |
| 86 // beginning item iff the display item actually draws content. For no-op | 86 // beginning item iff the display item actually draws content. For no-op |
| 87 // items, rather than creating an ending item, the begin item will | 87 // items, rather than creating an ending item, the begin item will |
| 88 // instead be removed, thereby maintaining brevity of the list. If display | 88 // instead be removed, thereby maintaining brevity of the list. If display |
| 89 // item construction is disabled, no list mutations will be performed. | 89 // item construction is disabled, no list mutations will be performed. |
| 90 template <typename DisplayItemClass, typename... Args> | 90 template <typename DisplayItemClass, typename... Args> |
| 91 void endItem(Args&&... args) | 91 void endItem(Args&&... args) |
| 92 { | 92 { |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 158 | 158 |
| 159 protected: | 159 protected: |
| 160 PaintController() | 160 PaintController() |
| 161 : m_newDisplayItemList(0) | 161 : m_newDisplayItemList(0) |
| 162 , m_constructionDisabled(false) | 162 , m_constructionDisabled(false) |
| 163 , m_subsequenceCachingDisabled(false) | 163 , m_subsequenceCachingDisabled(false) |
| 164 , m_textPainted(false) | 164 , m_textPainted(false) |
| 165 , m_imagePainted(false) | 165 , m_imagePainted(false) |
| 166 , m_skippingCacheCount(0) | 166 , m_skippingCacheCount(0) |
| 167 , m_numCachedNewItems(0) | 167 , m_numCachedNewItems(0) |
| 168 , m_currentChunkIsFromCachedSubsequence(true) | 168 , m_currentCachedSubsequenceBeginIndexInNewList(kNotFound) |
| 169 #ifndef NDEBUG | 169 #ifndef NDEBUG |
| 170 , m_numSequentialMatches(0) | 170 , m_numSequentialMatches(0) |
| 171 , m_numOutOfOrderMatches(0) | 171 , m_numOutOfOrderMatches(0) |
| 172 , m_numIndexedItems(0) | 172 , m_numIndexedItems(0) |
| 173 #endif | 173 #endif |
| 174 { | 174 { |
| 175 resetCurrentListIndices(); | 175 resetCurrentListIndices(); |
| 176 } | 176 } |
| 177 | 177 |
| 178 private: | 178 private: |
| 179 friend class PaintControllerTestBase; | 179 friend class PaintControllerTestBase; |
| 180 friend class PaintControllerPaintTestBase; | 180 friend class PaintControllerPaintTestBase; |
| 181 | 181 |
| 182 void ensureNewDisplayItemListInitialCapacity() | 182 void ensureNewDisplayItemListInitialCapacity() |
| 183 { | 183 { |
| 184 if (m_newDisplayItemList.isEmpty()) { | 184 if (m_newDisplayItemList.isEmpty()) { |
| 185 // TODO(wangxianzhu): Consider revisiting this heuristic. | 185 // TODO(wangxianzhu): Consider revisiting this heuristic. |
| 186 m_newDisplayItemList = DisplayItemList(m_currentPaintArtifact.getDis
playItemList().isEmpty() ? kInitialDisplayItemListCapacityBytes : m_currentPaint
Artifact.getDisplayItemList().usedCapacityInBytes()); | 186 m_newDisplayItemList = DisplayItemList(m_currentPaintArtifact.getDis
playItemList().isEmpty() ? kInitialDisplayItemListCapacityBytes : m_currentPaint
Artifact.getDisplayItemList().usedCapacityInBytes()); |
| 187 } | 187 } |
| 188 } | 188 } |
| 189 | 189 |
| 190 // Set new item state (cache skipping, etc) for a new item. | 190 // Set new item state (cache skipping, etc) for a new item. |
| 191 enum NewItemSource { FromCachedItem, FromCachedSubsequence, NewPainting }; | 191 void processNewItem(DisplayItem&); |
| 192 void processNewItem(DisplayItem&, NewItemSource); | 192 DisplayItem& moveItemFromCurrentListToNewList(size_t); |
| 193 | 193 |
| 194 String displayItemListAsDebugString(const DisplayItemList&) const; | 194 String displayItemListAsDebugString(const DisplayItemList&) const; |
| 195 | 195 |
| 196 // Maps clients to indices of display items or chunks of each client. | 196 // Maps clients to indices of display items or chunks of each client. |
| 197 using IndicesByClientMap = HashMap<const DisplayItemClient*, Vector<size_t>>
; | 197 using IndicesByClientMap = HashMap<const DisplayItemClient*, Vector<size_t>>
; |
| 198 | 198 |
| 199 static size_t findMatchingItemFromIndex(const DisplayItem::Id&, const Indice
sByClientMap&, const DisplayItemList&); | 199 static size_t findMatchingItemFromIndex(const DisplayItem::Id&, const Indice
sByClientMap&, const DisplayItemList&); |
| 200 static void addItemToIndexIfNeeded(const DisplayItem&, size_t index, Indices
ByClientMap&); | 200 static void addItemToIndexIfNeeded(const DisplayItem&, size_t index, Indices
ByClientMap&); |
| 201 | 201 |
| 202 size_t findCachedItem(const DisplayItem::Id&); | 202 size_t findCachedItem(const DisplayItem::Id&); |
| 203 size_t findOutOfOrderCachedItemForward(const DisplayItem::Id&); | 203 size_t findOutOfOrderCachedItemForward(const DisplayItem::Id&); |
| 204 void copyCachedSubsequence(size_t&); | 204 void copyCachedSubsequence(size_t&); |
| 205 | 205 |
| 206 // Resets the indices (e.g. m_nextItemToMatch) of m_currentPaintArtifact.get
DisplayItemList() | 206 // Resets the indices (e.g. m_nextItemToMatch) of m_currentPaintArtifact.get
DisplayItemList() |
| 207 // to their initial values. This should be called when the DisplayItemList i
n m_currentPaintArtifact | 207 // to their initial values. This should be called when the DisplayItemList i
n m_currentPaintArtifact |
| 208 // is newly created, or is changed causing the previous indices to be invali
d. | 208 // is newly created, or is changed causing the previous indices to be invali
d. |
| 209 void resetCurrentListIndices(); | 209 void resetCurrentListIndices(); |
| 210 | 210 |
| 211 void generateChunkRasterInvalidationRects(PaintChunk& newChunk); | 211 void generateChunkRasterInvalidationRects(PaintChunk& newChunk); |
| 212 void generateChunkRasterInvalidationRectsComparingOldChunk(PaintChunk& newCh
unk, const PaintChunk& oldChunk); | 212 void generateChunkRasterInvalidationRectsComparingOldChunk(PaintChunk& newCh
unk, const PaintChunk& oldChunk); |
| 213 void generateChunkRasterInvalidationRectsForReorderedItems(PaintChunk& newCh
unk, const PaintChunk& oldChunk, |
| 214 Vector<size_t>::const_iterator, Vector<size_t>::const_iterator, Vector<s
ize_t>::const_iterator, Vector<size_t>::const_iterator); |
| 213 | 215 |
| 214 // The following two methods are for checking under-invalidations | 216 // The following two methods are for checking under-invalidations |
| 215 // (when RuntimeEnabledFeatures::paintUnderInvalidationCheckingEnabled). | 217 // (when RuntimeEnabledFeatures::paintUnderInvalidationCheckingEnabled). |
| 216 void showUnderInvalidationError(const char* reason, const DisplayItem& newIt
em, const DisplayItem* oldItem) const; | 218 void showUnderInvalidationError(const char* reason, const DisplayItem& newIt
em, const DisplayItem* oldItem) const; |
| 217 void checkUnderInvalidation(); | 219 void checkUnderInvalidation(); |
| 218 bool isCheckingUnderInvalidation() const { return m_underInvalidationCheckin
gEnd - m_underInvalidationCheckingBegin > 0; } | 220 bool isCheckingUnderInvalidation() const { return m_underInvalidationCheckin
gEnd - m_underInvalidationCheckingBegin > 0; } |
| 219 | 221 |
| 220 // The last complete paint artifact. | 222 // The last complete paint artifact. |
| 221 // In SPv2, this includes paint chunks as well as display items. | 223 // In SPv2, this includes paint chunks as well as display items. |
| 222 PaintArtifact m_currentPaintArtifact; | 224 PaintArtifact m_currentPaintArtifact; |
| 223 | 225 |
| 224 // Data being used to build the next paint artifact. | 226 // Data being used to build the next paint artifact. |
| 225 DisplayItemList m_newDisplayItemList; | 227 DisplayItemList m_newDisplayItemList; |
| 226 PaintChunker m_newPaintChunks; | 228 PaintChunker m_newPaintChunks; |
| 227 | 229 |
| 230 // Stores indices into m_newDisplayItemList for display items that have been
moved from |
| 231 // m_currentPaintArtifact.getDisplayItemList(), indexed by the positions of
the display |
| 232 // items before move. The values are undefined for display items that are no
t moved. |
| 233 Vector<size_t> m_itemsMovedIntoNewList; |
| 234 |
| 228 // Allow display item construction to be disabled to isolate the costs of co
nstruction | 235 // Allow display item construction to be disabled to isolate the costs of co
nstruction |
| 229 // in performance metrics. | 236 // in performance metrics. |
| 230 bool m_constructionDisabled; | 237 bool m_constructionDisabled; |
| 231 | 238 |
| 232 // Allow subsequence caching to be disabled to test the cost of display item
caching. | 239 // Allow subsequence caching to be disabled to test the cost of display item
caching. |
| 233 bool m_subsequenceCachingDisabled; | 240 bool m_subsequenceCachingDisabled; |
| 234 | 241 |
| 235 // Indicates this PaintController has ever had text. It is never reset to fa
lse. | 242 // Indicates this PaintController has ever had text. It is never reset to fa
lse. |
| 236 bool m_textPainted; | 243 bool m_textPainted; |
| 237 bool m_imagePainted; | 244 bool m_imagePainted; |
| (...skipping 15 matching lines...) Expand all Loading... |
| 253 size_t m_nextItemToMatch; | 260 size_t m_nextItemToMatch; |
| 254 | 261 |
| 255 // The next item in the current list to be indexed for out-of-order cache re
quests. | 262 // The next item in the current list to be indexed for out-of-order cache re
quests. |
| 256 size_t m_nextItemToIndex; | 263 size_t m_nextItemToIndex; |
| 257 | 264 |
| 258 // Similar to m_outOfOrderItemIndices but | 265 // Similar to m_outOfOrderItemIndices but |
| 259 // - the indices are chunk indices in m_currentPaintArtifacts.paintChunks(); | 266 // - the indices are chunk indices in m_currentPaintArtifacts.paintChunks(); |
| 260 // - chunks are matched not only for requests of cached display items, but a
lso non-cached display items. | 267 // - chunks are matched not only for requests of cached display items, but a
lso non-cached display items. |
| 261 IndicesByClientMap m_outOfOrderChunkIndices; | 268 IndicesByClientMap m_outOfOrderChunkIndices; |
| 262 | 269 |
| 263 bool m_currentChunkIsFromCachedSubsequence; | 270 size_t m_currentCachedSubsequenceBeginIndexInNewList; |
| 264 size_t m_nextChunkToMatch; | 271 size_t m_nextChunkToMatch; |
| 265 | 272 |
| 266 DisplayItemClient::CacheGenerationOrInvalidationReason m_currentCacheGenerat
ion; | 273 DisplayItemClient::CacheGenerationOrInvalidationReason m_currentCacheGenerat
ion; |
| 267 | 274 |
| 268 #ifndef NDEBUG | 275 #ifndef NDEBUG |
| 269 int m_numSequentialMatches; | 276 int m_numSequentialMatches; |
| 270 int m_numOutOfOrderMatches; | 277 int m_numOutOfOrderMatches; |
| 271 int m_numIndexedItems; | 278 int m_numIndexedItems; |
| 272 #endif | 279 #endif |
| 273 | 280 |
| (...skipping 17 matching lines...) Expand all Loading... |
| 291 | 298 |
| 292 #if CHECK_DISPLAY_ITEM_CLIENT_ALIVENESS | 299 #if CHECK_DISPLAY_ITEM_CLIENT_ALIVENESS |
| 293 // A stack recording subsequence clients that are currently painting. | 300 // A stack recording subsequence clients that are currently painting. |
| 294 Vector<const DisplayItemClient*> m_currentSubsequenceClients; | 301 Vector<const DisplayItemClient*> m_currentSubsequenceClients; |
| 295 #endif | 302 #endif |
| 296 }; | 303 }; |
| 297 | 304 |
| 298 } // namespace blink | 305 } // namespace blink |
| 299 | 306 |
| 300 #endif // PaintController_h | 307 #endif // PaintController_h |
| OLD | NEW |