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

Unified Diff: cc/resources/raster_worker_pool_perftest.cc

Issue 228173002: cc: Separate RasterWorkerPool interface from implementation details. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: address review feedback Created 6 years, 8 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_delegate.cc ('k') | cc/resources/raster_worker_pool_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/resources/raster_worker_pool_perftest.cc
diff --git a/cc/resources/raster_worker_pool_perftest.cc b/cc/resources/raster_worker_pool_perftest.cc
index de4cac49874d310c5e9fcaca83db6f84c9508d8c..749985a3485efe0be6bab997be5ee0003d84a0fd 100644
--- a/cc/resources/raster_worker_pool_perftest.cc
+++ b/cc/resources/raster_worker_pool_perftest.cc
@@ -9,6 +9,7 @@
#include "cc/resources/direct_raster_worker_pool.h"
#include "cc/resources/image_raster_worker_pool.h"
#include "cc/resources/pixel_buffer_raster_worker_pool.h"
+#include "cc/resources/rasterizer.h"
#include "cc/resources/resource_provider.h"
#include "cc/resources/scoped_resource.h"
#include "cc/test/fake_output_surface.h"
@@ -80,18 +81,18 @@ static const int kTimeLimitMillis = 2000;
static const int kWarmupRuns = 5;
static const int kTimeCheckInterval = 10;
-class PerfWorkerPoolTaskImpl : public internal::WorkerPoolTask {
+class PerfImageDecodeTaskImpl : public internal::ImageDecodeTask {
public:
- PerfWorkerPoolTaskImpl() {}
+ PerfImageDecodeTaskImpl() {}
// Overridden from internal::Task:
virtual void RunOnWorkerThread() OVERRIDE {}
- // Overridden from internal::WorkerPoolTask:
- virtual void ScheduleOnOriginThread(internal::WorkerPoolTaskClient* client)
+ // Overridden from internal::RasterizerTask:
+ virtual void ScheduleOnOriginThread(internal::RasterizerTaskClient* client)
OVERRIDE {}
virtual void RunOnOriginThread() OVERRIDE {}
- virtual void CompleteOnOriginThread(internal::WorkerPoolTaskClient* client)
+ virtual void CompleteOnOriginThread(internal::RasterizerTaskClient* client)
OVERRIDE {}
virtual void RunReplyOnOriginThread() OVERRIDE { Reset(); }
@@ -101,31 +102,31 @@ class PerfWorkerPoolTaskImpl : public internal::WorkerPoolTask {
}
protected:
- virtual ~PerfWorkerPoolTaskImpl() {}
+ virtual ~PerfImageDecodeTaskImpl() {}
private:
- DISALLOW_COPY_AND_ASSIGN(PerfWorkerPoolTaskImpl);
+ DISALLOW_COPY_AND_ASSIGN(PerfImageDecodeTaskImpl);
};
-class PerfRasterWorkerPoolTaskImpl : public internal::RasterWorkerPoolTask {
+class PerfRasterTaskImpl : public internal::RasterTask {
public:
- PerfRasterWorkerPoolTaskImpl(scoped_ptr<ScopedResource> resource,
- internal::WorkerPoolTask::Vector* dependencies)
- : internal::RasterWorkerPoolTask(resource.get(), dependencies),
+ PerfRasterTaskImpl(scoped_ptr<ScopedResource> resource,
+ internal::ImageDecodeTask::Vector* dependencies)
+ : internal::RasterTask(resource.get(), dependencies),
resource_(resource.Pass()) {}
// Overridden from internal::Task:
virtual void RunOnWorkerThread() OVERRIDE {}
- // Overridden from internal::WorkerPoolTask:
- virtual void ScheduleOnOriginThread(internal::WorkerPoolTaskClient* client)
+ // Overridden from internal::RasterizerTask:
+ virtual void ScheduleOnOriginThread(internal::RasterizerTaskClient* client)
OVERRIDE {
- client->AcquireCanvasForRaster(this, resource());
+ client->AcquireCanvasForRaster(this);
}
virtual void RunOnOriginThread() OVERRIDE {}
- virtual void CompleteOnOriginThread(internal::WorkerPoolTaskClient* client)
+ virtual void CompleteOnOriginThread(internal::RasterizerTaskClient* client)
OVERRIDE {
- client->ReleaseCanvasForRaster(this, resource());
+ client->ReleaseCanvasForRaster(this);
}
virtual void RunReplyOnOriginThread() OVERRIDE { Reset(); }
@@ -135,48 +136,17 @@ class PerfRasterWorkerPoolTaskImpl : public internal::RasterWorkerPoolTask {
}
protected:
- virtual ~PerfRasterWorkerPoolTaskImpl() {}
+ virtual ~PerfRasterTaskImpl() {}
private:
scoped_ptr<ScopedResource> resource_;
- DISALLOW_COPY_AND_ASSIGN(PerfRasterWorkerPoolTaskImpl);
-};
-
-class PerfPixelBufferRasterWorkerPoolImpl : public PixelBufferRasterWorkerPool {
- public:
- PerfPixelBufferRasterWorkerPoolImpl(
- internal::TaskGraphRunner* task_graph_runner,
- ResourceProvider* resource_provider)
- : PixelBufferRasterWorkerPool(base::MessageLoopProxy::current().get(),
- task_graph_runner,
- resource_provider,
- std::numeric_limits<size_t>::max()) {}
-};
-
-class PerfImageRasterWorkerPoolImpl : public ImageRasterWorkerPool {
- public:
- PerfImageRasterWorkerPoolImpl(internal::TaskGraphRunner* task_graph_runner,
- ResourceProvider* resource_provider)
- : ImageRasterWorkerPool(base::MessageLoopProxy::current().get(),
- task_graph_runner,
- resource_provider,
- GL_TEXTURE_2D) {}
-};
-
-class PerfDirectRasterWorkerPoolImpl : public DirectRasterWorkerPool {
- public:
- PerfDirectRasterWorkerPoolImpl(ResourceProvider* resource_provider,
- ContextProvider* context_provider)
- : DirectRasterWorkerPool(base::MessageLoopProxy::current().get(),
- resource_provider,
- context_provider) {}
+ DISALLOW_COPY_AND_ASSIGN(PerfRasterTaskImpl);
};
class RasterWorkerPoolPerfTestBase {
public:
- typedef std::vector<scoped_refptr<internal::RasterWorkerPoolTask> >
- RasterTaskVector;
+ typedef std::vector<scoped_refptr<internal::RasterTask> > RasterTaskVector;
RasterWorkerPoolPerfTestBase()
: context_provider_(make_scoped_refptr(new PerfContextProvider)),
@@ -192,25 +162,18 @@ class RasterWorkerPoolPerfTestBase {
ResourceProvider::Create(
output_surface_.get(), shared_bitmap_manager_.get(), 0, false, 1)
.Pass();
- pixel_buffer_raster_worker_pool_.reset(
- new PerfPixelBufferRasterWorkerPoolImpl(task_graph_runner_.get(),
- resource_provider_.get()));
- image_raster_worker_pool_.reset(new PerfImageRasterWorkerPoolImpl(
- task_graph_runner_.get(), resource_provider_.get()));
- direct_raster_worker_pool_.reset(new PerfDirectRasterWorkerPoolImpl(
- resource_provider_.get(), context_provider_));
}
void CreateImageDecodeTasks(
unsigned num_image_decode_tasks,
- internal::WorkerPoolTask::Vector* image_decode_tasks) {
+ internal::ImageDecodeTask::Vector* image_decode_tasks) {
for (unsigned i = 0; i < num_image_decode_tasks; ++i)
- image_decode_tasks->push_back(new PerfWorkerPoolTaskImpl);
+ image_decode_tasks->push_back(new PerfImageDecodeTaskImpl);
}
void CreateRasterTasks(
unsigned num_raster_tasks,
- const internal::WorkerPoolTask::Vector& image_decode_tasks,
+ const internal::ImageDecodeTask::Vector& image_decode_tasks,
RasterTaskVector* raster_tasks) {
const gfx::Size size(1, 1);
@@ -219,9 +182,9 @@ class RasterWorkerPoolPerfTestBase {
ScopedResource::Create(resource_provider_.get()));
resource->Allocate(size, ResourceProvider::TextureUsageAny, RGBA_8888);
- internal::WorkerPoolTask::Vector dependencies = image_decode_tasks;
+ internal::ImageDecodeTask::Vector dependencies = image_decode_tasks;
raster_tasks->push_back(
- new PerfRasterWorkerPoolTaskImpl(resource.Pass(), &dependencies));
+ new PerfRasterTaskImpl(resource.Pass(), &dependencies));
}
}
@@ -242,47 +205,55 @@ class RasterWorkerPoolPerfTestBase {
scoped_ptr<SharedBitmapManager> shared_bitmap_manager_;
scoped_ptr<ResourceProvider> resource_provider_;
scoped_ptr<internal::TaskGraphRunner> task_graph_runner_;
- scoped_ptr<PixelBufferRasterWorkerPool> pixel_buffer_raster_worker_pool_;
- scoped_ptr<ImageRasterWorkerPool> image_raster_worker_pool_;
- scoped_ptr<DirectRasterWorkerPool> direct_raster_worker_pool_;
LapTimer timer_;
};
class RasterWorkerPoolPerfTest
: public RasterWorkerPoolPerfTestBase,
public testing::TestWithParam<RasterWorkerPoolType>,
- public RasterWorkerPoolClient {
+ public RasterizerClient {
public:
- RasterWorkerPoolPerfTest() : raster_worker_pool_(NULL) {
+ RasterWorkerPoolPerfTest() {
switch (GetParam()) {
case RASTER_WORKER_POOL_TYPE_PIXEL_BUFFER:
- raster_worker_pool_ = pixel_buffer_raster_worker_pool_.get();
+ raster_worker_pool_ = PixelBufferRasterWorkerPool::Create(
+ base::MessageLoopProxy::current().get(),
+ task_graph_runner_.get(),
+ resource_provider_.get(),
+ std::numeric_limits<size_t>::max());
break;
case RASTER_WORKER_POOL_TYPE_IMAGE:
- raster_worker_pool_ = image_raster_worker_pool_.get();
+ raster_worker_pool_ = ImageRasterWorkerPool::Create(
+ base::MessageLoopProxy::current().get(),
+ task_graph_runner_.get(),
+ resource_provider_.get(),
+ GL_TEXTURE_2D);
break;
case RASTER_WORKER_POOL_TYPE_DIRECT:
- raster_worker_pool_ = direct_raster_worker_pool_.get();
+ raster_worker_pool_ = DirectRasterWorkerPool::Create(
+ base::MessageLoopProxy::current().get(),
+ resource_provider_.get(),
+ context_provider_.get());
break;
}
DCHECK(raster_worker_pool_);
- raster_worker_pool_->SetClient(this);
+ raster_worker_pool_->AsRasterizer()->SetClient(this);
}
// Overridden from testing::Test:
virtual void TearDown() OVERRIDE {
- raster_worker_pool_->Shutdown();
- raster_worker_pool_->CheckForCompletedTasks();
+ raster_worker_pool_->AsRasterizer()->Shutdown();
+ raster_worker_pool_->AsRasterizer()->CheckForCompletedTasks();
}
- // Overriden from RasterWorkerPoolClient:
- virtual bool ShouldForceTasksRequiredForActivationToComplete()
- const OVERRIDE {
+ // Overriden from RasterizerClient:
+ virtual bool ShouldForceTasksRequiredForActivationToComplete() const
+ OVERRIDE {
return false;
}
virtual void DidFinishRunningTasks() OVERRIDE {
- raster_worker_pool_->CheckForCompletedTasks();
+ raster_worker_pool_->AsRasterizer()->CheckForCompletedTasks();
base::MessageLoop::current()->Quit();
}
virtual void DidFinishRunningTasksRequiredForActivation() OVERRIDE {}
@@ -295,7 +266,7 @@ class RasterWorkerPoolPerfTest
void RunScheduleTasksTest(const std::string& test_name,
unsigned num_raster_tasks,
unsigned num_image_decode_tasks) {
- internal::WorkerPoolTask::Vector image_decode_tasks;
+ internal::ImageDecodeTask::Vector image_decode_tasks;
RasterTaskVector raster_tasks;
CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks);
CreateRasterTasks(num_raster_tasks, image_decode_tasks, &raster_tasks);
@@ -307,13 +278,13 @@ class RasterWorkerPoolPerfTest
do {
queue.Reset();
BuildRasterTaskQueue(&queue, raster_tasks);
- raster_worker_pool_->ScheduleTasks(&queue);
- raster_worker_pool_->CheckForCompletedTasks();
+ raster_worker_pool_->AsRasterizer()->ScheduleTasks(&queue);
+ raster_worker_pool_->AsRasterizer()->CheckForCompletedTasks();
timer_.NextLap();
} while (!timer_.HasTimeLimitExpired());
RasterTaskQueue empty;
- raster_worker_pool_->ScheduleTasks(&empty);
+ raster_worker_pool_->AsRasterizer()->ScheduleTasks(&empty);
RunMessageLoopUntilAllTasksHaveCompleted();
perf_test::PrintResult("schedule_tasks",
@@ -328,7 +299,7 @@ class RasterWorkerPoolPerfTest
unsigned num_raster_tasks,
unsigned num_image_decode_tasks) {
const size_t kNumVersions = 2;
- internal::WorkerPoolTask::Vector image_decode_tasks[kNumVersions];
+ internal::ImageDecodeTask::Vector image_decode_tasks[kNumVersions];
RasterTaskVector raster_tasks[kNumVersions];
for (size_t i = 0; i < kNumVersions; ++i) {
CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks[i]);
@@ -344,14 +315,14 @@ class RasterWorkerPoolPerfTest
do {
queue.Reset();
BuildRasterTaskQueue(&queue, raster_tasks[count % kNumVersions]);
- raster_worker_pool_->ScheduleTasks(&queue);
- raster_worker_pool_->CheckForCompletedTasks();
+ raster_worker_pool_->AsRasterizer()->ScheduleTasks(&queue);
+ raster_worker_pool_->AsRasterizer()->CheckForCompletedTasks();
++count;
timer_.NextLap();
} while (!timer_.HasTimeLimitExpired());
RasterTaskQueue empty;
- raster_worker_pool_->ScheduleTasks(&empty);
+ raster_worker_pool_->AsRasterizer()->ScheduleTasks(&empty);
RunMessageLoopUntilAllTasksHaveCompleted();
perf_test::PrintResult("schedule_alternate_tasks",
@@ -365,7 +336,7 @@ class RasterWorkerPoolPerfTest
void RunScheduleAndExecuteTasksTest(const std::string& test_name,
unsigned num_raster_tasks,
unsigned num_image_decode_tasks) {
- internal::WorkerPoolTask::Vector image_decode_tasks;
+ internal::ImageDecodeTask::Vector image_decode_tasks;
RasterTaskVector raster_tasks;
CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks);
CreateRasterTasks(num_raster_tasks, image_decode_tasks, &raster_tasks);
@@ -377,13 +348,13 @@ class RasterWorkerPoolPerfTest
do {
queue.Reset();
BuildRasterTaskQueue(&queue, raster_tasks);
- raster_worker_pool_->ScheduleTasks(&queue);
+ raster_worker_pool_->AsRasterizer()->ScheduleTasks(&queue);
RunMessageLoopUntilAllTasksHaveCompleted();
timer_.NextLap();
} while (!timer_.HasTimeLimitExpired());
RasterTaskQueue empty;
- raster_worker_pool_->ScheduleTasks(&empty);
+ raster_worker_pool_->AsRasterizer()->ScheduleTasks(&empty);
RunMessageLoopUntilAllTasksHaveCompleted();
perf_test::PrintResult("schedule_and_execute_tasks",
@@ -408,7 +379,7 @@ class RasterWorkerPoolPerfTest
return std::string();
}
- RasterWorkerPool* raster_worker_pool_;
+ scoped_ptr<RasterWorkerPool> raster_worker_pool_;
};
TEST_P(RasterWorkerPoolPerfTest, ScheduleTasks) {
@@ -450,7 +421,7 @@ class RasterWorkerPoolCommonPerfTest : public RasterWorkerPoolPerfTestBase,
void RunBuildRasterTaskQueueTest(const std::string& test_name,
unsigned num_raster_tasks,
unsigned num_image_decode_tasks) {
- internal::WorkerPoolTask::Vector image_decode_tasks;
+ internal::ImageDecodeTask::Vector image_decode_tasks;
RasterTaskVector raster_tasks;
CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks);
CreateRasterTasks(num_raster_tasks, image_decode_tasks, &raster_tasks);
« no previous file with comments | « cc/resources/raster_worker_pool_delegate.cc ('k') | cc/resources/raster_worker_pool_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698