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

Unified Diff: cc/resources/raster_worker_pool.cc

Issue 17625002: cc: Eliminate tile.h's dependency on tile_manager.h (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: reveman's review Created 7 years, 6 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « cc/resources/raster_worker_pool.h ('k') | cc/resources/raster_worker_pool_perftest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/resources/raster_worker_pool.cc
diff --git a/cc/resources/raster_worker_pool.cc b/cc/resources/raster_worker_pool.cc
index b1ab2108ea6ac9881ef3e86397d3854c7d3f049a..3b8a9377d02127d4f53c036b85ae8727d6d77689 100644
--- a/cc/resources/raster_worker_pool.cc
+++ b/cc/resources/raster_worker_pool.cc
@@ -21,25 +21,6 @@ namespace {
// a tile is of solid color.
const bool kUseColorEstimator = true;
-scoped_ptr<base::Value> RasterModeAsValue(RasterMode raster_mode) {
- switch (raster_mode) {
- case HIGH_QUALITY_NO_LCD_RASTER_MODE:
- return scoped_ptr<base::Value>(
- base::Value::CreateStringValue("HIGH_QUALITY_NO_LCD_RASTER_MODE"));
- case HIGH_QUALITY_RASTER_MODE:
- return scoped_ptr<base::Value>(
- base::Value::CreateStringValue("HIGH_QUALITY_RASTER_MODE"));
- case LOW_QUALITY_RASTER_MODE:
- return scoped_ptr<base::Value>(
- base::Value::CreateStringValue("LOW_QUALITY_RASTER_MODE"));
- case NUM_RASTER_MODES:
- default:
- NOTREACHED() << "Unrecognized RasterMode value " << raster_mode;
- return scoped_ptr<base::Value>(
- base::Value::CreateStringValue("<unknown RasterMode value>"));
- }
-}
-
class DisableLCDTextFilter : public SkDrawFilter {
public:
// SkDrawFilter interface.
@@ -52,6 +33,22 @@ class DisableLCDTextFilter : public SkDrawFilter {
}
};
+scoped_ptr<base::Value> RasterTracingDataAsValue(
+ bool is_tile_in_pending_tree_now_bin_,
+ TileResolution tile_resolution_,
+ int layer_id_,
+ const void* tile_id_,
+ int source_frame_number_) {
reveman 2013/07/03 16:56:12 no "_" suffixes please. however, I think this woul
vmpstr 2013/07/03 17:33:33 Oops, sorry about the trailing underscores, it was
+ scoped_ptr<base::DictionaryValue> res(new base::DictionaryValue());
+ res->Set("tile_id", TracedValue::CreateIDRef(tile_id_).release());
+ res->SetBoolean("is_tile_in_pending_tree_now_bin",
+ is_tile_in_pending_tree_now_bin_);
+ res->Set("resolution", TileResolutionAsValue(tile_resolution_).release());
+ res->SetInteger("source_frame_number", source_frame_number_);
+ res->SetInteger("layer_id", layer_id_);
+ return res.PassAs<base::Value>();
+}
+
class RasterWorkerPoolTaskImpl : public internal::RasterWorkerPoolTask {
public:
RasterWorkerPoolTaskImpl(const Resource* resource,
@@ -59,7 +56,11 @@ class RasterWorkerPoolTaskImpl : public internal::RasterWorkerPoolTask {
gfx::Rect content_rect,
float contents_scale,
RasterMode raster_mode,
- const RasterTaskMetadata& metadata,
+ bool is_tile_in_pending_tree_now_bin,
+ TileResolution tile_resolution,
+ int layer_id,
+ const void* tile_id,
+ int source_frame_number,
RenderingStatsInstrumentation* rendering_stats,
const RasterWorkerPool::RasterTask::Reply& reply,
TaskVector* dependencies)
@@ -68,7 +69,11 @@ class RasterWorkerPoolTaskImpl : public internal::RasterWorkerPoolTask {
content_rect_(content_rect),
contents_scale_(contents_scale),
raster_mode_(raster_mode),
- metadata_(metadata),
+ is_tile_in_pending_tree_now_bin_(is_tile_in_pending_tree_now_bin),
+ tile_resolution_(tile_resolution),
+ layer_id_(layer_id),
+ tile_id_(tile_id),
+ source_frame_number_(source_frame_number),
rendering_stats_(rendering_stats),
reply_(reply) {}
@@ -76,7 +81,12 @@ class RasterWorkerPoolTaskImpl : public internal::RasterWorkerPoolTask {
TRACE_EVENT1("cc",
"RasterWorkerPoolTaskImpl::RunAnalysisOnThread",
"metadata",
reveman 2013/07/03 16:56:12 lets remove all references to metadata. "data" her
vmpstr 2013/07/03 17:33:33 Done.
- TracedValue::FromValue(metadata_.AsValue().release()));
+ TracedValue::FromValue(
+ RasterTracingDataAsValue(is_tile_in_pending_tree_now_bin_,
+ tile_resolution_,
+ layer_id_,
+ tile_id_,
+ source_frame_number_).release()));
DCHECK(picture_pile_.get());
DCHECK(rendering_stats_);
@@ -105,12 +115,17 @@ class RasterWorkerPoolTaskImpl : public internal::RasterWorkerPoolTask {
"cc",
"RasterWorkerPoolTaskImpl::RunRasterOnThread",
"metadata",
- TracedValue::FromValue(metadata_.AsValue().release()),
+ TracedValue::FromValue(
+ RasterTracingDataAsValue(is_tile_in_pending_tree_now_bin_,
+ tile_resolution_,
+ layer_id_,
+ tile_id_,
+ source_frame_number_).release()),
"raster_mode",
TracedValue::FromValue(RasterModeAsValue(raster_mode_).release()));
devtools_instrumentation::ScopedLayerTask raster_task(
- devtools_instrumentation::kRasterTask, metadata_.layer_id);
+ devtools_instrumentation::kRasterTask, layer_id_);
DCHECK(picture_pile_.get());
DCHECK(device);
@@ -148,7 +163,7 @@ class RasterWorkerPoolTaskImpl : public internal::RasterWorkerPoolTask {
raster_stats.total_rasterize_time,
raster_stats.best_rasterize_time,
raster_stats.total_pixels_rasterized,
- metadata_.is_tile_in_pending_tree_now_bin);
+ is_tile_in_pending_tree_now_bin_);
HISTOGRAM_CUSTOM_COUNTS(
"Renderer4.PictureRasterTimeUS",
@@ -182,7 +197,11 @@ class RasterWorkerPoolTaskImpl : public internal::RasterWorkerPoolTask {
gfx::Rect content_rect_;
float contents_scale_;
RasterMode raster_mode_;
- RasterTaskMetadata metadata_;
+ bool is_tile_in_pending_tree_now_bin_;
+ TileResolution tile_resolution_;
+ int layer_id_;
+ const void* tile_id_;
+ int source_frame_number_;
RenderingStatsInstrumentation* rendering_stats_;
const RasterWorkerPool::RasterTask::Reply reply_;
@@ -299,16 +318,6 @@ bool RasterWorkerPoolTask::HasCompleted() const {
} // namespace internal
-scoped_ptr<base::Value> RasterTaskMetadata::AsValue() const {
- scoped_ptr<base::DictionaryValue> res(new base::DictionaryValue());
- res->Set("tile_id", TracedValue::CreateIDRef(tile_id).release());
- res->SetBoolean("is_tile_in_pending_tree_now_bin",
- is_tile_in_pending_tree_now_bin);
- res->Set("resolution", TileResolutionAsValue(tile_resolution).release());
- res->SetInteger("source_frame_number", source_frame_number);
- return res.PassAs<base::Value>();
-}
-
RasterWorkerPool::Task::Set::Set() {
}
@@ -420,19 +429,28 @@ RasterWorkerPool::RasterTask RasterWorkerPool::CreateRasterTask(
gfx::Rect content_rect,
float contents_scale,
RasterMode raster_mode,
- const RasterTaskMetadata& metadata,
+ bool is_tile_in_pending_tree_now_bin,
+ TileResolution tile_resolution,
+ int layer_id,
+ const void* tile_id,
+ int source_frame_number,
RenderingStatsInstrumentation* rendering_stats,
const RasterTask::Reply& reply,
Task::Set* dependencies) {
- return RasterTask(new RasterWorkerPoolTaskImpl(resource,
- picture_pile,
- content_rect,
- contents_scale,
- raster_mode,
- metadata,
- rendering_stats,
- reply,
- &dependencies->tasks_));
+ return RasterTask(
+ new RasterWorkerPoolTaskImpl(resource,
+ picture_pile,
+ content_rect,
+ contents_scale,
+ raster_mode,
+ is_tile_in_pending_tree_now_bin,
+ tile_resolution,
+ layer_id,
+ tile_id,
+ source_frame_number,
+ rendering_stats,
+ reply,
+ &dependencies->tasks_));
}
// static
« no previous file with comments | « cc/resources/raster_worker_pool.h ('k') | cc/resources/raster_worker_pool_perftest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698