summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorepenner@chromium.org <epenner@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-11-20 05:34:17 +0000
committerepenner@chromium.org <epenner@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-11-20 05:34:17 +0000
commited3307fb8dcf971d28daa5a1d008b20d4508990c (patch)
tree0e8c2b2f5afad1c80e1b42b6d008b430f15a95b0
parent6ec70cc7ef252a95464f34ede4fcd86ff34f1bfd (diff)
downloadchromium_src-ed3307fb8dcf971d28daa5a1d008b20d4508990c.zip
chromium_src-ed3307fb8dcf971d28daa5a1d008b20d4508990c.tar.gz
chromium_src-ed3307fb8dcf971d28daa5a1d008b20d4508990c.tar.bz2
CC: Cache non-ideal tiles, but don't paint them.
This patch never paints _new_ non-ideal tiles. The old ones exist only because they are still being used (the ideal resolution hasn't covered all non-ideal tiles yet). BUG=307206 Review URL: https://codereview.chromium.org/71753003 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@236163 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--cc/resources/tile_manager.cc24
-rw-r--r--cc/test/test_tile_priorities.cc2
2 files changed, 19 insertions, 7 deletions
diff --git a/cc/resources/tile_manager.cc b/cc/resources/tile_manager.cc
index 85c7fa1..84842fe 100644
--- a/cc/resources/tile_manager.cc
+++ b/cc/resources/tile_manager.cc
@@ -372,24 +372,36 @@ void TileManager::GetTilesWithAssignedBins(PrioritizedTileSet* tiles) {
TilePriority pending_priority = tile->priority(PENDING_TREE);
ManagedTileBin pending_bin = BinFromTilePriority(pending_priority);
+ bool pending_is_low_res =
+ pending_priority.resolution == LOW_RESOLUTION;
+ bool pending_is_non_ideal =
+ pending_priority.resolution == NON_IDEAL_RESOLUTION;
+ bool active_is_non_ideal =
+ active_priority.resolution == NON_IDEAL_RESOLUTION;
+
// Adjust pending bin state for low res tiles. This prevents
// pending tree low-res tiles from being initialized before
// high-res tiles.
- if (pending_priority.resolution == LOW_RESOLUTION)
+ if (pending_is_low_res)
pending_bin = std::max(pending_bin, EVENTUALLY_BIN);
- // Compute combined bin.
- ManagedTileBin combined_bin = std::min(active_bin, pending_bin);
-
// Adjust bin state based on if ready to draw.
active_bin = kBinReadyToDrawMap[tile_is_ready_to_draw][active_bin];
pending_bin = kBinReadyToDrawMap[tile_is_ready_to_draw][pending_bin];
- combined_bin = kBinReadyToDrawMap[tile_is_ready_to_draw][combined_bin];
// Adjust bin state based on if active.
active_bin = kBinIsActiveMap[tile_is_active][active_bin];
pending_bin = kBinIsActiveMap[tile_is_active][pending_bin];
- combined_bin = kBinIsActiveMap[tile_is_active][combined_bin];
+
+ // We never want to paint new non-ideal tiles, as we always have
+ // a high-res tile covering that content (paint that instead).
+ if (!tile_is_ready_to_draw && active_is_non_ideal)
+ active_bin = NEVER_BIN;
+ if (!tile_is_ready_to_draw && pending_is_non_ideal)
+ pending_bin = NEVER_BIN;
+
+ // Compute combined bin.
+ ManagedTileBin combined_bin = std::min(active_bin, pending_bin);
ManagedTileBin tree_bin[NUM_TREES];
tree_bin[ACTIVE_TREE] = kBinPolicyMap[memory_policy][active_bin];
diff --git a/cc/test/test_tile_priorities.cc b/cc/test/test_tile_priorities.cc
index f83f9b9..9d3aae2 100644
--- a/cc/test/test_tile_priorities.cc
+++ b/cc/test/test_tile_priorities.cc
@@ -10,7 +10,7 @@ TilePriorityForSoonBin::TilePriorityForSoonBin()
: TilePriority(HIGH_RESOLUTION, 0.5, 300.0) {}
TilePriorityForEventualBin::TilePriorityForEventualBin()
- : TilePriority(NON_IDEAL_RESOLUTION, 1.0, 315.0) {}
+ : TilePriority(HIGH_RESOLUTION, 2.0, 315.0) {}
TilePriorityForNowBin::TilePriorityForNowBin()
: TilePriority(HIGH_RESOLUTION, 0, 0) {}