Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(301)

Side by Side Diff: cc/resources/managed_tile_state.cc

Issue 22831041: cc: Removed low priority bin from tile management. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 7 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "cc/resources/managed_tile_state.h" 5 #include "cc/resources/managed_tile_state.h"
6 6
7 #include <limits> 7 #include <limits>
8 8
9 #include "cc/base/math_util.h" 9 #include "cc/base/math_util.h"
10 10
11 namespace cc { 11 namespace cc {
12 12
13 scoped_ptr<base::Value> ManagedTileBinAsValue(ManagedTileBin bin) { 13 scoped_ptr<base::Value> ManagedTileBinAsValue(ManagedTileBin bin) {
14 switch (bin) { 14 switch (bin) {
15 case NOW_AND_READY_TO_DRAW_BIN: 15 case NOW_AND_READY_TO_DRAW_BIN:
16 return scoped_ptr<base::Value>(base::Value::CreateStringValue( 16 return scoped_ptr<base::Value>(
17 "NOW_AND_READY_TO_DRAW_BIN")); 17 base::Value::CreateStringValue("NOW_AND_READY_TO_DRAW_BIN"));
18 case NOW_BIN: 18 case NOW_BIN:
19 return scoped_ptr<base::Value>(base::Value::CreateStringValue( 19 return scoped_ptr<base::Value>(
20 "NOW_BIN")); 20 base::Value::CreateStringValue("NOW_BIN"));
21 case SOON_BIN: 21 case SOON_BIN:
22 return scoped_ptr<base::Value>(base::Value::CreateStringValue( 22 return scoped_ptr<base::Value>(
23 "SOON_BIN")); 23 base::Value::CreateStringValue("SOON_BIN"));
24 case EVENTUALLY_AND_ACTIVE_BIN: 24 case EVENTUALLY_AND_ACTIVE_BIN:
25 return scoped_ptr<base::Value>(base::Value::CreateStringValue( 25 return scoped_ptr<base::Value>(
26 "EVENTUALLY_AND_ACTIVE_BIN")); 26 base::Value::CreateStringValue("EVENTUALLY_AND_ACTIVE_BIN"));
27 case EVENTUALLY_BIN: 27 case EVENTUALLY_BIN:
28 return scoped_ptr<base::Value>(base::Value::CreateStringValue( 28 return scoped_ptr<base::Value>(
29 "EVENTUALLY_BIN")); 29 base::Value::CreateStringValue("EVENTUALLY_BIN"));
30 case NEVER_AND_ACTIVE_BIN: 30 case AT_LAST_AND_ACTIVE_BIN:
31 return scoped_ptr<base::Value>(base::Value::CreateStringValue( 31 return scoped_ptr<base::Value>(
32 "NEVER_AND_ACTIVE_BIN")); 32 base::Value::CreateStringValue("AT_LAST_AND_ACTIVE_BIN"));
33 case NEVER_BIN: 33 case AT_LAST_BIN:
34 return scoped_ptr<base::Value>(base::Value::CreateStringValue( 34 return scoped_ptr<base::Value>(
35 "NEVER_BIN")); 35 base::Value::CreateStringValue("AT_LAST_BIN"));
36 default: 36 case NEVER_BIN:
37 DCHECK(false) << "Unrecognized ManagedTileBin value " << bin; 37 return scoped_ptr<base::Value>(
38 return scoped_ptr<base::Value>(base::Value::CreateStringValue( 38 base::Value::CreateStringValue("NEVER_BIN"));
39 "<unknown ManagedTileBin value>")); 39 case NUM_BINS:
40 NOTREACHED();
41 return scoped_ptr<base::Value>(
42 base::Value::CreateStringValue("Invalid Bin (NUM_BINS)"));
40 } 43 }
41 } 44 return scoped_ptr<base::Value>(
42 45 base::Value::CreateStringValue("Invalid Bin (UNKNOWN)"));
43 scoped_ptr<base::Value> ManagedTileBinPriorityAsValue(
44 ManagedTileBinPriority bin_priority) {
45 switch (bin_priority) {
46 case HIGH_PRIORITY_BIN:
47 return scoped_ptr<base::Value>(base::Value::CreateStringValue(
48 "HIGH_PRIORITY_BIN"));
49 case LOW_PRIORITY_BIN:
50 return scoped_ptr<base::Value>(base::Value::CreateStringValue(
51 "LOW_PRIORITY_BIN"));
52 default:
53 DCHECK(false) << "Unrecognized ManagedTileBinPriority value";
54 return scoped_ptr<base::Value>(base::Value::CreateStringValue(
55 "<unknown ManagedTileBinPriority value>"));
56 }
57 } 46 }
58 47
59 ManagedTileState::ManagedTileState() 48 ManagedTileState::ManagedTileState()
60 : raster_mode(LOW_QUALITY_RASTER_MODE), 49 : raster_mode(LOW_QUALITY_RASTER_MODE),
50 bin(NEVER_BIN),
61 gpu_memmgr_stats_bin(NEVER_BIN), 51 gpu_memmgr_stats_bin(NEVER_BIN),
62 resolution(NON_IDEAL_RESOLUTION), 52 resolution(NON_IDEAL_RESOLUTION),
63 required_for_activation(false), 53 required_for_activation(false),
64 time_to_needed_in_seconds(std::numeric_limits<float>::infinity()), 54 time_to_needed_in_seconds(std::numeric_limits<float>::infinity()),
65 distance_to_visible_in_pixels(std::numeric_limits<float>::infinity()), 55 distance_to_visible_in_pixels(std::numeric_limits<float>::infinity()),
66 visible_and_ready_to_draw(false), 56 visible_and_ready_to_draw(false),
67 scheduled_priority(0) { 57 scheduled_priority(0) {
68 for (int i = 0; i < NUM_TREES; ++i) { 58 for (int i = 0; i < NUM_TREES; ++i)
69 tree_bin[i] = NEVER_BIN; 59 tree_bin[i] = NEVER_BIN;
70 bin[i] = NEVER_BIN;
71 }
72 } 60 }
73 61
74 ManagedTileState::TileVersion::TileVersion() 62 ManagedTileState::TileVersion::TileVersion()
75 : mode_(RESOURCE_MODE), 63 : mode_(RESOURCE_MODE),
76 has_text_(false) { 64 has_text_(false) {
77 } 65 }
78 66
79 ManagedTileState::TileVersion::~TileVersion() { 67 ManagedTileState::TileVersion::~TileVersion() {
80 DCHECK(!resource_); 68 DCHECK(!resource_);
81 } 69 }
(...skipping 17 matching lines...) Expand all
99 return resource_->bytes(); 87 return resource_->bytes();
100 } 88 }
101 89
102 ManagedTileState::~ManagedTileState() { 90 ManagedTileState::~ManagedTileState() {
103 } 91 }
104 92
105 scoped_ptr<base::Value> ManagedTileState::AsValue() const { 93 scoped_ptr<base::Value> ManagedTileState::AsValue() const {
106 scoped_ptr<base::DictionaryValue> state(new base::DictionaryValue()); 94 scoped_ptr<base::DictionaryValue> state(new base::DictionaryValue());
107 state->SetBoolean("has_resource", 95 state->SetBoolean("has_resource",
108 tile_versions[raster_mode].resource_.get() != 0); 96 tile_versions[raster_mode].resource_.get() != 0);
109 state->Set("bin.0", ManagedTileBinAsValue(bin[ACTIVE_TREE]).release()); 97 state->Set("tree_bin.0",
110 state->Set("bin.1", ManagedTileBinAsValue(bin[PENDING_TREE]).release()); 98 ManagedTileBinAsValue(tree_bin[ACTIVE_TREE]).release());
99 state->Set("tree_bin.1",
100 ManagedTileBinAsValue(tree_bin[PENDING_TREE]).release());
111 state->Set("gpu_memmgr_stats_bin", 101 state->Set("gpu_memmgr_stats_bin",
112 ManagedTileBinAsValue(bin[ACTIVE_TREE]).release()); 102 ManagedTileBinAsValue(gpu_memmgr_stats_bin).release());
113 state->Set("resolution", TileResolutionAsValue(resolution).release()); 103 state->Set("resolution", TileResolutionAsValue(resolution).release());
114 state->Set("time_to_needed_in_seconds", 104 state->Set("time_to_needed_in_seconds",
115 MathUtil::AsValueSafely(time_to_needed_in_seconds).release()); 105 MathUtil::AsValueSafely(time_to_needed_in_seconds).release());
116 state->Set("distance_to_visible_in_pixels", 106 state->Set("distance_to_visible_in_pixels",
117 MathUtil::AsValueSafely(distance_to_visible_in_pixels).release()); 107 MathUtil::AsValueSafely(distance_to_visible_in_pixels).release());
118 state->SetBoolean("required_for_activation", required_for_activation); 108 state->SetBoolean("required_for_activation", required_for_activation);
119 state->SetBoolean( 109 state->SetBoolean(
120 "is_solid_color", 110 "is_solid_color",
121 tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE); 111 tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE);
122 state->SetBoolean( 112 state->SetBoolean(
123 "is_transparent", 113 "is_transparent",
124 tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE && 114 tile_versions[raster_mode].mode_ == TileVersion::SOLID_COLOR_MODE &&
125 !SkColorGetA(tile_versions[raster_mode].solid_color_)); 115 !SkColorGetA(tile_versions[raster_mode].solid_color_));
126 state->SetInteger("scheduled_priority", scheduled_priority); 116 state->SetInteger("scheduled_priority", scheduled_priority);
127 return state.PassAs<base::Value>(); 117 return state.PassAs<base::Value>();
128 } 118 }
129 119
130 } // namespace cc 120 } // namespace cc
131 121
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698