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

Unified Diff: content/common/gpu/gpu_memory_manager_unittest.cc

Issue 9289052: Adding GpuMemoryManager to track GpuCommandBufferStub visibility and last_used_time and dictate mem… (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: . Created 8 years, 11 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 | « content/common/gpu/gpu_memory_manager.cc ('k') | content/content_common.gypi » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/common/gpu/gpu_memory_manager_unittest.cc
diff --git a/content/common/gpu/gpu_memory_manager_unittest.cc b/content/common/gpu/gpu_memory_manager_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..2d718b686330a22dd1f069766997c9ab2d818eab
--- /dev/null
+++ b/content/common/gpu/gpu_memory_manager_unittest.cc
@@ -0,0 +1,251 @@
+// Copyright (c) 2011 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 "content/common/gpu/gpu_command_buffer_stub.h"
+#include "content/common/gpu/gpu_memory_allocation.h"
+#include "content/common/gpu/gpu_memory_manager.h"
+
+#include "testing/gtest/include/gtest/gtest.h"
+
+class FakeCommandBufferStub : public GpuCommandBufferStubBase {
+ public:
+ SurfaceState surface_state_;
+ GpuMemoryAllocation allocation_;
+
+ FakeCommandBufferStub()
+ : surface_state_(0, false, base::TimeTicks()) {
+ }
+
+ FakeCommandBufferStub(int32 surface_id,
+ bool visible,
+ base::TimeTicks last_used_time)
+ : surface_state_(surface_id, visible, last_used_time) {
+ }
+
+ virtual bool has_surface_state() { return surface_state_.surface_id != 0; }
+ virtual const SurfaceState& surface_state() { return surface_state_; }
+ virtual void SendMemoryAllocationToProxy(const GpuMemoryAllocation& alloc) {
+ allocation_ = alloc;
+ }
+};
+
+class FakeClient : public GpuMemoryManagerClient {
+ public:
+ std::vector<GpuCommandBufferStubBase*> stubs_;
+
+ virtual void AppendAllCommandBufferStubs(
+ std::vector<GpuCommandBufferStubBase*>& stubs) {
+ stubs.insert(stubs.end(), stubs_.begin(), stubs_.end());
+ }
+};
+
+class GpuMemoryManagerTest : public testing::Test {
+ protected:
+ static const size_t kFrontbufferLimitForTest = 3;
+
+ GpuMemoryManagerTest()
+ : memory_manager_(&client_, kFrontbufferLimitForTest) {
+ }
+
+ virtual void SetUp() {
+ older_ = base::TimeTicks::FromInternalValue(1);
+ newer_ = base::TimeTicks::FromInternalValue(2);
+ newest_ = base::TimeTicks::FromInternalValue(3);
+ }
+
+ static int32 GenerateUniqueSurfaceId() {
+ static int32 surface_id_ = 1;
+ return surface_id_++;
+ }
+
+ static bool is_more_important(GpuCommandBufferStubBase* lhs,
+ GpuCommandBufferStubBase* rhs) {
+ return GpuMemoryManager::StubWithSurfaceComparator()(lhs, rhs);
+ }
+
+ void Manage() {
+ memory_manager_.Manage();
+ }
+
+ base::TimeTicks older_, newer_, newest_;
+ FakeClient client_;
+ GpuMemoryManager memory_manager_;
+};
+
+
+// Create fake stubs with every combination of {visibilty,last_use_time}
+// and make sure they compare correctly. Only compare stubs with surfaces.
+// Expect {more visible, newer} surfaces to be more important, in that order.
+TEST_F(GpuMemoryManagerTest, ComparatorTests) {
+ FakeCommandBufferStub stub_true1(GenerateUniqueSurfaceId(), true, older_),
+ stub_true2(GenerateUniqueSurfaceId(), true, newer_),
+ stub_true3(GenerateUniqueSurfaceId(), true, newest_),
+ stub_false1(GenerateUniqueSurfaceId(), false, older_),
+ stub_false2(GenerateUniqueSurfaceId(), false, newer_),
+ stub_false3(GenerateUniqueSurfaceId(), false, newest_);
+
+ // Should never be more important than self:
+ EXPECT_FALSE(is_more_important(&stub_true1, &stub_true1));
+ EXPECT_FALSE(is_more_important(&stub_true2, &stub_true2));
+ EXPECT_FALSE(is_more_important(&stub_true3, &stub_true3));
+ EXPECT_FALSE(is_more_important(&stub_false1, &stub_false1));
+ EXPECT_FALSE(is_more_important(&stub_false2, &stub_false2));
+ EXPECT_FALSE(is_more_important(&stub_false3, &stub_false3));
+
+ // Visible should always be more important than non visible:
+ EXPECT_TRUE(is_more_important(&stub_true1, &stub_false1));
+ EXPECT_TRUE(is_more_important(&stub_true1, &stub_false2));
+ EXPECT_TRUE(is_more_important(&stub_true1, &stub_false3));
+ EXPECT_TRUE(is_more_important(&stub_true2, &stub_false1));
+ EXPECT_TRUE(is_more_important(&stub_true2, &stub_false2));
+ EXPECT_TRUE(is_more_important(&stub_true2, &stub_false3));
+ EXPECT_TRUE(is_more_important(&stub_true3, &stub_false1));
+ EXPECT_TRUE(is_more_important(&stub_true3, &stub_false2));
+ EXPECT_TRUE(is_more_important(&stub_true3, &stub_false3));
+
+ // Not visible should never be more important than visible:
+ EXPECT_FALSE(is_more_important(&stub_false1, &stub_true1));
+ EXPECT_FALSE(is_more_important(&stub_false1, &stub_true2));
+ EXPECT_FALSE(is_more_important(&stub_false1, &stub_true3));
+ EXPECT_FALSE(is_more_important(&stub_false2, &stub_true1));
+ EXPECT_FALSE(is_more_important(&stub_false2, &stub_true2));
+ EXPECT_FALSE(is_more_important(&stub_false2, &stub_true3));
+ EXPECT_FALSE(is_more_important(&stub_false3, &stub_true1));
+ EXPECT_FALSE(is_more_important(&stub_false3, &stub_true2));
+ EXPECT_FALSE(is_more_important(&stub_false3, &stub_true3));
+
+ // Newer should always be more important than older:
+ EXPECT_TRUE(is_more_important(&stub_true2, &stub_true1));
+ EXPECT_TRUE(is_more_important(&stub_true3, &stub_true1));
+ EXPECT_TRUE(is_more_important(&stub_true3, &stub_true2));
+ EXPECT_TRUE(is_more_important(&stub_false2, &stub_false1));
+ EXPECT_TRUE(is_more_important(&stub_false3, &stub_false1));
+ EXPECT_TRUE(is_more_important(&stub_false3, &stub_false2));
+
+ // Older should never be more important than newer:
+ EXPECT_FALSE(is_more_important(&stub_true1, &stub_true2));
+ EXPECT_FALSE(is_more_important(&stub_true1, &stub_true3));
+ EXPECT_FALSE(is_more_important(&stub_true2, &stub_true3));
+ EXPECT_FALSE(is_more_important(&stub_false1, &stub_false2));
+ EXPECT_FALSE(is_more_important(&stub_false1, &stub_false3));
+ EXPECT_FALSE(is_more_important(&stub_false2, &stub_false3));
+}
+
+// Test GpuMemoryManager::Manage basic functionality.
+// Expect memory allocation to set hasFrontbuffer, hasBackbuffer according
+// to visibility and last used time.
+TEST_F(GpuMemoryManagerTest, TestManageBasicFunctionality) {
+ FakeCommandBufferStub stub1(GenerateUniqueSurfaceId(), true, older_),
+ stub2(GenerateUniqueSurfaceId(), false, older_);
+ client_.stubs_.push_back(&stub1);
+ client_.stubs_.push_back(&stub2);
+
+ Manage();
+ EXPECT_EQ(stub1.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub1.allocation_.hasBackbuffer, true);
+ EXPECT_EQ(stub2.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub2.allocation_.hasBackbuffer, false);
+}
+
+// Test GpuMemoryManager::Manage functionality: Test changing visibility
+// Expect memory allocation to set hasFrontbuffer, hasBackbuffer according
+// to visibility and last used time.
+TEST_F(GpuMemoryManagerTest, TestManageChangingVisibility) {
+ FakeCommandBufferStub stub1(GenerateUniqueSurfaceId(), true, older_),
+ stub2(GenerateUniqueSurfaceId(), false, older_);
+ client_.stubs_.push_back(&stub1);
+ client_.stubs_.push_back(&stub2);
+
+ Manage();
+ EXPECT_EQ(stub1.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub1.allocation_.hasBackbuffer, true);
+ EXPECT_EQ(stub2.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub2.allocation_.hasBackbuffer, false);
+
+ stub1.surface_state_.visible = false;
+ stub2.surface_state_.visible = true;
+
+ Manage();
+ EXPECT_EQ(stub1.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub1.allocation_.hasBackbuffer, false);
+ EXPECT_EQ(stub2.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub2.allocation_.hasBackbuffer, true);
+}
+
+// Test GpuMemoryManager::Manage functionality: Test more than threshold number
+// of visible stubs.
+// Expect all allocations to continue to have frontbuffer.
+TEST_F(GpuMemoryManagerTest, TestManageManyVisibleStubs) {
+ FakeCommandBufferStub stub1(GenerateUniqueSurfaceId(), true, older_),
+ stub2(GenerateUniqueSurfaceId(), true, older_),
+ stub3(GenerateUniqueSurfaceId(), true, older_),
+ stub4(GenerateUniqueSurfaceId(), true, older_);
+ client_.stubs_.push_back(&stub1);
+ client_.stubs_.push_back(&stub2);
+ client_.stubs_.push_back(&stub3);
+ client_.stubs_.push_back(&stub4);
+
+ Manage();
+ EXPECT_EQ(stub1.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub1.allocation_.hasBackbuffer, true);
+ EXPECT_EQ(stub2.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub2.allocation_.hasBackbuffer, true);
+ EXPECT_EQ(stub3.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub3.allocation_.hasBackbuffer, true);
+ EXPECT_EQ(stub4.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub4.allocation_.hasBackbuffer, true);
+}
+
+// Test GpuMemoryManager::Manage functionality: Test more than threshold number
+// of not visible stubs.
+// Expect the stubs surpassing the threshold to not have a backbuffer.
+TEST_F(GpuMemoryManagerTest, TestManageManyNotVisibleStubs) {
+ FakeCommandBufferStub stub1(GenerateUniqueSurfaceId(), false, newer_),
+ stub2(GenerateUniqueSurfaceId(), false, newer_),
+ stub3(GenerateUniqueSurfaceId(), false, newer_),
+ stub4(GenerateUniqueSurfaceId(), false, older_);
+ client_.stubs_.push_back(&stub1);
+ client_.stubs_.push_back(&stub2);
+ client_.stubs_.push_back(&stub3);
+ client_.stubs_.push_back(&stub4);
+
+ Manage();
+ EXPECT_EQ(stub1.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub1.allocation_.hasBackbuffer, false);
+ EXPECT_EQ(stub2.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub2.allocation_.hasBackbuffer, false);
+ EXPECT_EQ(stub3.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub3.allocation_.hasBackbuffer, false);
+ EXPECT_EQ(stub4.allocation_.hasFrontbuffer, false);
+ EXPECT_EQ(stub4.allocation_.hasBackbuffer, false);
+}
+
+// Test GpuMemoryManager::Manage functionality: Test changing the last used
+// time of stubs when doing so causes change in which stubs surpass threshold.
+// Expect frontbuffer to be dropped for the older stub.
+TEST_F(GpuMemoryManagerTest, TestManageChangingLastUsedTime) {
+ FakeCommandBufferStub stub1(GenerateUniqueSurfaceId(), false, newer_),
+ stub2(GenerateUniqueSurfaceId(), false, newer_),
+ stub3(GenerateUniqueSurfaceId(), false, newer_),
+ stub4(GenerateUniqueSurfaceId(), false, older_);
+ client_.stubs_.push_back(&stub1);
+ client_.stubs_.push_back(&stub2);
+ client_.stubs_.push_back(&stub3);
+ client_.stubs_.push_back(&stub4);
+
+ Manage();
+ EXPECT_EQ(stub3.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub3.allocation_.hasBackbuffer, false);
+ EXPECT_EQ(stub4.allocation_.hasFrontbuffer, false);
+ EXPECT_EQ(stub4.allocation_.hasBackbuffer, false);
+
+ stub3.surface_state_.last_used_time = older_;
+ stub4.surface_state_.last_used_time = newer_;
+
+ Manage();
+ EXPECT_EQ(stub3.allocation_.hasFrontbuffer, false);
+ EXPECT_EQ(stub3.allocation_.hasBackbuffer, false);
+ EXPECT_EQ(stub4.allocation_.hasFrontbuffer, true);
+ EXPECT_EQ(stub4.allocation_.hasBackbuffer, false);
+}
« no previous file with comments | « content/common/gpu/gpu_memory_manager.cc ('k') | content/content_common.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698