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

Unified Diff: cc/resources/tile_task_worker_pool_perftest.cc

Issue 1144693002: cc: Move files out of cc/resources/. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: resources: android Created 5 years, 7 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/tile_task_worker_pool.cc ('k') | cc/resources/tile_task_worker_pool_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/resources/tile_task_worker_pool_perftest.cc
diff --git a/cc/resources/tile_task_worker_pool_perftest.cc b/cc/resources/tile_task_worker_pool_perftest.cc
deleted file mode 100644
index 27b0154697edcffe614c4fe8894a7690a18fc79b..0000000000000000000000000000000000000000
--- a/cc/resources/tile_task_worker_pool_perftest.cc
+++ /dev/null
@@ -1,521 +0,0 @@
-// Copyright 2013 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "cc/resources/tile_task_worker_pool.h"
-
-#include "base/test/test_simple_task_runner.h"
-#include "base/time/time.h"
-#include "cc/debug/lap_timer.h"
-#include "cc/output/context_provider.h"
-#include "cc/resources/bitmap_tile_task_worker_pool.h"
-#include "cc/resources/gpu_rasterizer.h"
-#include "cc/resources/gpu_tile_task_worker_pool.h"
-#include "cc/resources/one_copy_tile_task_worker_pool.h"
-#include "cc/resources/pixel_buffer_tile_task_worker_pool.h"
-#include "cc/resources/raster_buffer.h"
-#include "cc/resources/resource_pool.h"
-#include "cc/resources/resource_provider.h"
-#include "cc/resources/scoped_resource.h"
-#include "cc/resources/tile_task_runner.h"
-#include "cc/resources/zero_copy_tile_task_worker_pool.h"
-#include "cc/test/fake_output_surface.h"
-#include "cc/test/fake_output_surface_client.h"
-#include "cc/test/test_context_support.h"
-#include "cc/test/test_gpu_memory_buffer_manager.h"
-#include "cc/test/test_shared_bitmap_manager.h"
-#include "cc/test/test_web_graphics_context_3d.h"
-#include "testing/gtest/include/gtest/gtest.h"
-#include "testing/perf/perf_test.h"
-#include "third_party/khronos/GLES2/gl2.h"
-#include "third_party/skia/include/gpu/GrContext.h"
-#include "third_party/skia/include/gpu/gl/GrGLInterface.h"
-
-namespace cc {
-namespace {
-
-class PerfGLES2Interface : public gpu::gles2::GLES2InterfaceStub {
- // Overridden from gpu::gles2::GLES2Interface:
- GLuint CreateImageCHROMIUM(ClientBuffer buffer,
- GLsizei width,
- GLsizei height,
- GLenum internalformat) override {
- return 1u;
- }
- void GenBuffers(GLsizei n, GLuint* buffers) override {
- for (GLsizei i = 0; i < n; ++i)
- buffers[i] = 1u;
- }
- void GenTextures(GLsizei n, GLuint* textures) override {
- for (GLsizei i = 0; i < n; ++i)
- textures[i] = 1u;
- }
- void GetIntegerv(GLenum pname, GLint* params) override {
- if (pname == GL_MAX_TEXTURE_SIZE)
- *params = INT_MAX;
- }
- void GenQueriesEXT(GLsizei n, GLuint* queries) override {
- for (GLsizei i = 0; i < n; ++i)
- queries[i] = 1u;
- }
- void GetQueryObjectuivEXT(GLuint query,
- GLenum pname,
- GLuint* params) override {
- if (pname == GL_QUERY_RESULT_AVAILABLE_EXT)
- *params = 1;
- }
-};
-
-class PerfContextProvider : public ContextProvider {
- public:
- PerfContextProvider() : context_gl_(new PerfGLES2Interface) {}
-
- bool BindToCurrentThread() override { return true; }
- Capabilities ContextCapabilities() override {
- Capabilities capabilities;
- capabilities.gpu.image = true;
- capabilities.gpu.sync_query = true;
- return capabilities;
- }
- gpu::gles2::GLES2Interface* ContextGL() override { return context_gl_.get(); }
- gpu::ContextSupport* ContextSupport() override { return &support_; }
- class GrContext* GrContext() override {
- if (gr_context_)
- return gr_context_.get();
-
- skia::RefPtr<const GrGLInterface> null_interface =
- skia::AdoptRef(GrGLCreateNullInterface());
- gr_context_ = skia::AdoptRef(GrContext::Create(
- kOpenGL_GrBackend,
- reinterpret_cast<GrBackendContext>(null_interface.get())));
- return gr_context_.get();
- }
- void InvalidateGrContext(uint32_t state) override {
- if (gr_context_)
- gr_context_.get()->resetContext(state);
- }
- void SetupLock() override {}
- base::Lock* GetLock() override { return &context_lock_; }
- bool IsContextLost() override { return false; }
- void VerifyContexts() override {}
- void DeleteCachedResources() override {}
- bool DestroyedOnMainThread() override { return false; }
- void SetLostContextCallback(const LostContextCallback& cb) override {}
- void SetMemoryPolicyChangedCallback(
- const MemoryPolicyChangedCallback& cb) override {}
-
- private:
- ~PerfContextProvider() override {}
-
- scoped_ptr<PerfGLES2Interface> context_gl_;
- skia::RefPtr<class GrContext> gr_context_;
- TestContextSupport support_;
- base::Lock context_lock_;
-};
-
-enum TileTaskWorkerPoolType {
- TILE_TASK_WORKER_POOL_TYPE_PIXEL_BUFFER,
- TILE_TASK_WORKER_POOL_TYPE_ZERO_COPY,
- TILE_TASK_WORKER_POOL_TYPE_ONE_COPY,
- TILE_TASK_WORKER_POOL_TYPE_GPU,
- TILE_TASK_WORKER_POOL_TYPE_BITMAP
-};
-
-static const int kTimeLimitMillis = 2000;
-static const int kWarmupRuns = 5;
-static const int kTimeCheckInterval = 10;
-
-class PerfImageDecodeTaskImpl : public ImageDecodeTask {
- public:
- PerfImageDecodeTaskImpl() {}
-
- // Overridden from Task:
- void RunOnWorkerThread() override {}
-
- // Overridden from TileTask:
- void ScheduleOnOriginThread(TileTaskClient* client) override {}
- void CompleteOnOriginThread(TileTaskClient* client) override {}
- void RunReplyOnOriginThread() override { Reset(); }
-
- void Reset() {
- did_run_ = false;
- did_complete_ = false;
- }
-
- protected:
- ~PerfImageDecodeTaskImpl() override {}
-
- private:
- DISALLOW_COPY_AND_ASSIGN(PerfImageDecodeTaskImpl);
-};
-
-class PerfRasterTaskImpl : public RasterTask {
- public:
- PerfRasterTaskImpl(scoped_ptr<ScopedResource> resource,
- ImageDecodeTask::Vector* dependencies)
- : RasterTask(resource.get(), dependencies), resource_(resource.Pass()) {}
-
- // Overridden from Task:
- void RunOnWorkerThread() override {}
-
- // Overridden from TileTask:
- void ScheduleOnOriginThread(TileTaskClient* client) override {
- raster_buffer_ = client->AcquireBufferForRaster(resource());
- }
- void CompleteOnOriginThread(TileTaskClient* client) override {
- client->ReleaseBufferForRaster(raster_buffer_.Pass());
- }
- void RunReplyOnOriginThread() override { Reset(); }
-
- void Reset() {
- did_run_ = false;
- did_complete_ = false;
- }
-
- protected:
- ~PerfRasterTaskImpl() override {}
-
- private:
- scoped_ptr<ScopedResource> resource_;
- scoped_ptr<RasterBuffer> raster_buffer_;
-
- DISALLOW_COPY_AND_ASSIGN(PerfRasterTaskImpl);
-};
-
-class TileTaskWorkerPoolPerfTestBase {
- public:
- typedef std::vector<scoped_refptr<RasterTask>> RasterTaskVector;
-
- enum NamedTaskSet { REQUIRED_FOR_ACTIVATION, REQUIRED_FOR_DRAW, ALL };
-
- TileTaskWorkerPoolPerfTestBase()
- : context_provider_(make_scoped_refptr(new PerfContextProvider)),
- task_runner_(new base::TestSimpleTaskRunner),
- task_graph_runner_(new TaskGraphRunner),
- timer_(kWarmupRuns,
- base::TimeDelta::FromMilliseconds(kTimeLimitMillis),
- kTimeCheckInterval) {}
-
- void CreateImageDecodeTasks(unsigned num_image_decode_tasks,
- ImageDecodeTask::Vector* image_decode_tasks) {
- for (unsigned i = 0; i < num_image_decode_tasks; ++i)
- image_decode_tasks->push_back(new PerfImageDecodeTaskImpl);
- }
-
- void CreateRasterTasks(unsigned num_raster_tasks,
- const ImageDecodeTask::Vector& image_decode_tasks,
- RasterTaskVector* raster_tasks) {
- const gfx::Size size(1, 1);
-
- for (unsigned i = 0; i < num_raster_tasks; ++i) {
- scoped_ptr<ScopedResource> resource(
- ScopedResource::Create(resource_provider_.get()));
- resource->Allocate(size, ResourceProvider::TEXTURE_HINT_IMMUTABLE,
- RGBA_8888);
-
- ImageDecodeTask::Vector dependencies = image_decode_tasks;
- raster_tasks->push_back(
- new PerfRasterTaskImpl(resource.Pass(), &dependencies));
- }
- }
-
- void BuildTileTaskQueue(TileTaskQueue* queue,
- const RasterTaskVector& raster_tasks) {
- for (size_t i = 0u; i < raster_tasks.size(); ++i) {
- bool required_for_activation = (i % 2) == 0;
- TaskSetCollection task_set_collection;
- task_set_collection[ALL] = true;
- task_set_collection[REQUIRED_FOR_ACTIVATION] = required_for_activation;
- queue->items.push_back(
- TileTaskQueue::Item(raster_tasks[i].get(), task_set_collection));
- }
- }
-
- protected:
- scoped_refptr<ContextProvider> context_provider_;
- FakeOutputSurfaceClient output_surface_client_;
- scoped_ptr<FakeOutputSurface> output_surface_;
- scoped_ptr<ResourceProvider> resource_provider_;
- scoped_refptr<base::TestSimpleTaskRunner> task_runner_;
- scoped_ptr<TaskGraphRunner> task_graph_runner_;
- LapTimer timer_;
-};
-
-class TileTaskWorkerPoolPerfTest
- : public TileTaskWorkerPoolPerfTestBase,
- public testing::TestWithParam<TileTaskWorkerPoolType>,
- public TileTaskRunnerClient {
- public:
- // Overridden from testing::Test:
- void SetUp() override {
- switch (GetParam()) {
- case TILE_TASK_WORKER_POOL_TYPE_PIXEL_BUFFER:
- Create3dOutputSurfaceAndResourceProvider();
- tile_task_worker_pool_ = PixelBufferTileTaskWorkerPool::Create(
- task_runner_.get(), task_graph_runner_.get(),
- context_provider_.get(), resource_provider_.get(),
- std::numeric_limits<size_t>::max());
- break;
- case TILE_TASK_WORKER_POOL_TYPE_ZERO_COPY:
- Create3dOutputSurfaceAndResourceProvider();
- tile_task_worker_pool_ = ZeroCopyTileTaskWorkerPool::Create(
- task_runner_.get(), task_graph_runner_.get(),
- resource_provider_.get());
- break;
- case TILE_TASK_WORKER_POOL_TYPE_ONE_COPY:
- Create3dOutputSurfaceAndResourceProvider();
- staging_resource_pool_ = ResourcePool::Create(resource_provider_.get(),
- GL_TEXTURE_2D);
- tile_task_worker_pool_ = OneCopyTileTaskWorkerPool::Create(
- task_runner_.get(), task_graph_runner_.get(),
- context_provider_.get(), resource_provider_.get(),
- staging_resource_pool_.get());
- break;
- case TILE_TASK_WORKER_POOL_TYPE_GPU:
- Create3dOutputSurfaceAndResourceProvider();
- tile_task_worker_pool_ = GpuTileTaskWorkerPool::Create(
- task_runner_.get(), task_graph_runner_.get(),
- context_provider_.get(), resource_provider_.get(), false, 0);
- break;
- case TILE_TASK_WORKER_POOL_TYPE_BITMAP:
- CreateSoftwareOutputSurfaceAndResourceProvider();
- tile_task_worker_pool_ = BitmapTileTaskWorkerPool::Create(
- task_runner_.get(), task_graph_runner_.get(),
- resource_provider_.get());
- break;
- }
-
- DCHECK(tile_task_worker_pool_);
- tile_task_worker_pool_->AsTileTaskRunner()->SetClient(this);
- }
- void TearDown() override {
- tile_task_worker_pool_->AsTileTaskRunner()->Shutdown();
- tile_task_worker_pool_->AsTileTaskRunner()->CheckForCompletedTasks();
- }
-
- // Overriden from TileTaskRunnerClient:
- void DidFinishRunningTileTasks(TaskSet task_set) override {
- tile_task_worker_pool_->AsTileTaskRunner()->CheckForCompletedTasks();
- }
- TaskSetCollection TasksThatShouldBeForcedToComplete() const override {
- return TaskSetCollection();
- }
-
- void RunMessageLoopUntilAllTasksHaveCompleted() {
- task_graph_runner_->RunUntilIdle();
- task_runner_->RunUntilIdle();
- }
-
- void RunScheduleTasksTest(const std::string& test_name,
- unsigned num_raster_tasks,
- unsigned num_image_decode_tasks) {
- 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);
-
- // Avoid unnecessary heap allocations by reusing the same queue.
- TileTaskQueue queue;
-
- timer_.Reset();
- do {
- queue.Reset();
- BuildTileTaskQueue(&queue, raster_tasks);
- tile_task_worker_pool_->AsTileTaskRunner()->ScheduleTasks(&queue);
- tile_task_worker_pool_->AsTileTaskRunner()->CheckForCompletedTasks();
- timer_.NextLap();
- } while (!timer_.HasTimeLimitExpired());
-
- TileTaskQueue empty;
- tile_task_worker_pool_->AsTileTaskRunner()->ScheduleTasks(&empty);
- RunMessageLoopUntilAllTasksHaveCompleted();
-
- perf_test::PrintResult("schedule_tasks", TestModifierString(), test_name,
- timer_.LapsPerSecond(), "runs/s", true);
- }
-
- void RunScheduleAlternateTasksTest(const std::string& test_name,
- unsigned num_raster_tasks,
- unsigned num_image_decode_tasks) {
- const size_t kNumVersions = 2;
- 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]);
- CreateRasterTasks(num_raster_tasks, image_decode_tasks[i],
- &raster_tasks[i]);
- }
-
- // Avoid unnecessary heap allocations by reusing the same queue.
- TileTaskQueue queue;
-
- size_t count = 0;
- timer_.Reset();
- do {
- queue.Reset();
- BuildTileTaskQueue(&queue, raster_tasks[count % kNumVersions]);
- tile_task_worker_pool_->AsTileTaskRunner()->ScheduleTasks(&queue);
- tile_task_worker_pool_->AsTileTaskRunner()->CheckForCompletedTasks();
- ++count;
- timer_.NextLap();
- } while (!timer_.HasTimeLimitExpired());
-
- TileTaskQueue empty;
- tile_task_worker_pool_->AsTileTaskRunner()->ScheduleTasks(&empty);
- RunMessageLoopUntilAllTasksHaveCompleted();
-
- perf_test::PrintResult("schedule_alternate_tasks", TestModifierString(),
- test_name, timer_.LapsPerSecond(), "runs/s", true);
- }
-
- void RunScheduleAndExecuteTasksTest(const std::string& test_name,
- unsigned num_raster_tasks,
- unsigned num_image_decode_tasks) {
- 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);
-
- // Avoid unnecessary heap allocations by reusing the same queue.
- TileTaskQueue queue;
-
- timer_.Reset();
- do {
- queue.Reset();
- BuildTileTaskQueue(&queue, raster_tasks);
- tile_task_worker_pool_->AsTileTaskRunner()->ScheduleTasks(&queue);
- RunMessageLoopUntilAllTasksHaveCompleted();
- timer_.NextLap();
- } while (!timer_.HasTimeLimitExpired());
-
- TileTaskQueue empty;
- tile_task_worker_pool_->AsTileTaskRunner()->ScheduleTasks(&empty);
- RunMessageLoopUntilAllTasksHaveCompleted();
-
- perf_test::PrintResult("schedule_and_execute_tasks", TestModifierString(),
- test_name, timer_.LapsPerSecond(), "runs/s", true);
- }
-
- private:
- void Create3dOutputSurfaceAndResourceProvider() {
- output_surface_ = FakeOutputSurface::Create3d(context_provider_).Pass();
- CHECK(output_surface_->BindToClient(&output_surface_client_));
- resource_provider_ = ResourceProvider::Create(output_surface_.get(), NULL,
- &gpu_memory_buffer_manager_,
- NULL, 0, false, 1).Pass();
- }
-
- void CreateSoftwareOutputSurfaceAndResourceProvider() {
- output_surface_ = FakeOutputSurface::CreateSoftware(
- make_scoped_ptr(new SoftwareOutputDevice));
- CHECK(output_surface_->BindToClient(&output_surface_client_));
- resource_provider_ =
- ResourceProvider::Create(output_surface_.get(), &shared_bitmap_manager_,
- NULL, NULL, 0, false, 1).Pass();
- }
-
- std::string TestModifierString() const {
- switch (GetParam()) {
- case TILE_TASK_WORKER_POOL_TYPE_PIXEL_BUFFER:
- return std::string("_pixel_tile_task_worker_pool");
- case TILE_TASK_WORKER_POOL_TYPE_ZERO_COPY:
- return std::string("_zero_copy_tile_task_worker_pool");
- case TILE_TASK_WORKER_POOL_TYPE_ONE_COPY:
- return std::string("_one_copy_tile_task_worker_pool");
- case TILE_TASK_WORKER_POOL_TYPE_GPU:
- return std::string("_gpu_tile_task_worker_pool");
- case TILE_TASK_WORKER_POOL_TYPE_BITMAP:
- return std::string("_bitmap_tile_task_worker_pool");
- }
- NOTREACHED();
- return std::string();
- }
-
- scoped_ptr<ResourcePool> staging_resource_pool_;
- scoped_ptr<TileTaskWorkerPool> tile_task_worker_pool_;
- TestGpuMemoryBufferManager gpu_memory_buffer_manager_;
- TestSharedBitmapManager shared_bitmap_manager_;
-};
-
-TEST_P(TileTaskWorkerPoolPerfTest, ScheduleTasks) {
- RunScheduleTasksTest("1_0", 1, 0);
- RunScheduleTasksTest("32_0", 32, 0);
- RunScheduleTasksTest("1_1", 1, 1);
- RunScheduleTasksTest("32_1", 32, 1);
- RunScheduleTasksTest("1_4", 1, 4);
- RunScheduleTasksTest("32_4", 32, 4);
-}
-
-TEST_P(TileTaskWorkerPoolPerfTest, ScheduleAlternateTasks) {
- RunScheduleAlternateTasksTest("1_0", 1, 0);
- RunScheduleAlternateTasksTest("32_0", 32, 0);
- RunScheduleAlternateTasksTest("1_1", 1, 1);
- RunScheduleAlternateTasksTest("32_1", 32, 1);
- RunScheduleAlternateTasksTest("1_4", 1, 4);
- RunScheduleAlternateTasksTest("32_4", 32, 4);
-}
-
-TEST_P(TileTaskWorkerPoolPerfTest, ScheduleAndExecuteTasks) {
- RunScheduleAndExecuteTasksTest("1_0", 1, 0);
- RunScheduleAndExecuteTasksTest("32_0", 32, 0);
- RunScheduleAndExecuteTasksTest("1_1", 1, 1);
- RunScheduleAndExecuteTasksTest("32_1", 32, 1);
- RunScheduleAndExecuteTasksTest("1_4", 1, 4);
- RunScheduleAndExecuteTasksTest("32_4", 32, 4);
-}
-
-INSTANTIATE_TEST_CASE_P(
- TileTaskWorkerPoolPerfTests,
- TileTaskWorkerPoolPerfTest,
- ::testing::Values(TILE_TASK_WORKER_POOL_TYPE_PIXEL_BUFFER,
- TILE_TASK_WORKER_POOL_TYPE_ZERO_COPY,
- TILE_TASK_WORKER_POOL_TYPE_ONE_COPY,
- TILE_TASK_WORKER_POOL_TYPE_GPU,
- TILE_TASK_WORKER_POOL_TYPE_BITMAP));
-
-class TileTaskWorkerPoolCommonPerfTest : public TileTaskWorkerPoolPerfTestBase,
- public testing::Test {
- public:
- // Overridden from testing::Test:
- void SetUp() override {
- output_surface_ = FakeOutputSurface::Create3d(context_provider_).Pass();
- CHECK(output_surface_->BindToClient(&output_surface_client_));
- resource_provider_ =
- ResourceProvider::Create(output_surface_.get(), NULL, NULL, NULL, 0,
- false, 1).Pass();
- }
-
- void RunBuildTileTaskQueueTest(const std::string& test_name,
- unsigned num_raster_tasks,
- unsigned num_image_decode_tasks) {
- 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);
-
- // Avoid unnecessary heap allocations by reusing the same queue.
- TileTaskQueue queue;
-
- timer_.Reset();
- do {
- queue.Reset();
- BuildTileTaskQueue(&queue, raster_tasks);
- timer_.NextLap();
- } while (!timer_.HasTimeLimitExpired());
-
- perf_test::PrintResult("build_raster_task_queue", "", test_name,
- timer_.LapsPerSecond(), "runs/s", true);
- }
-};
-
-TEST_F(TileTaskWorkerPoolCommonPerfTest, BuildTileTaskQueue) {
- RunBuildTileTaskQueueTest("1_0", 1, 0);
- RunBuildTileTaskQueueTest("32_0", 32, 0);
- RunBuildTileTaskQueueTest("1_1", 1, 1);
- RunBuildTileTaskQueueTest("32_1", 32, 1);
- RunBuildTileTaskQueueTest("1_4", 1, 4);
- RunBuildTileTaskQueueTest("32_4", 32, 4);
-}
-
-} // namespace
-} // namespace cc
« no previous file with comments | « cc/resources/tile_task_worker_pool.cc ('k') | cc/resources/tile_task_worker_pool_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698