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

Side by Side Diff: gpu/command_buffer/client/mapped_memory_unittest.cc

Issue 8953006: Free the command buffer when tabs are switched (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 9 years 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 "gpu/command_buffer/client/mapped_memory.h" 5 #include "gpu/command_buffer/client/mapped_memory.h"
6 #include "base/bind.h" 6 #include "base/bind.h"
7 #include "base/message_loop.h" 7 #include "base/message_loop.h"
8 #include "base/memory/scoped_ptr.h" 8 #include "base/memory/scoped_ptr.h"
9 #include "gpu/command_buffer/client/cmd_buffer_helper.h" 9 #include "gpu/command_buffer/client/cmd_buffer_helper.h"
10 #include "gpu/command_buffer/service/mocks.h" 10 #include "gpu/command_buffer/service/mocks.h"
(...skipping 26 matching lines...) Expand all
37 EXPECT_CALL(*api_mock_, DoCommand(cmd::kNoop, 0, _)) 37 EXPECT_CALL(*api_mock_, DoCommand(cmd::kNoop, 0, _))
38 .WillRepeatedly(Return(error::kNoError)); 38 .WillRepeatedly(Return(error::kNoError));
39 // Forward the SetToken calls to the engine 39 // Forward the SetToken calls to the engine
40 EXPECT_CALL(*api_mock_.get(), DoCommand(cmd::kSetToken, 1, _)) 40 EXPECT_CALL(*api_mock_.get(), DoCommand(cmd::kSetToken, 1, _))
41 .WillRepeatedly(DoAll(Invoke(api_mock_.get(), &AsyncAPIMock::SetToken), 41 .WillRepeatedly(DoAll(Invoke(api_mock_.get(), &AsyncAPIMock::SetToken),
42 Return(error::kNoError))); 42 Return(error::kNoError)));
43 43
44 command_buffer_.reset(new CommandBufferService); 44 command_buffer_.reset(new CommandBufferService);
45 command_buffer_->Initialize(); 45 command_buffer_->Initialize();
46 46
47 parser_ = new CommandParser(api_mock_.get());
48
49 gpu_scheduler_.reset(new GpuScheduler( 47 gpu_scheduler_.reset(new GpuScheduler(
50 command_buffer_.get(), NULL, parser_)); 48 command_buffer_.get(), api_mock_.get(), NULL));
51 command_buffer_->SetPutOffsetChangeCallback(base::Bind( 49 command_buffer_->SetPutOffsetChangeCallback(base::Bind(
52 &GpuScheduler::PutChanged, base::Unretained(gpu_scheduler_.get()))); 50 &GpuScheduler::PutChanged, base::Unretained(gpu_scheduler_.get())));
51 command_buffer_->SetGetBufferChangeCallback(base::Bind(
52 &GpuScheduler::SetGetBuffer, base::Unretained(gpu_scheduler_.get())));
53 53
54 api_mock_->set_engine(gpu_scheduler_.get()); 54 api_mock_->set_engine(gpu_scheduler_.get());
55 55
56 helper_.reset(new CommandBufferHelper(command_buffer_.get())); 56 helper_.reset(new CommandBufferHelper(command_buffer_.get()));
57 helper_->Initialize(kBufferSize); 57 helper_->Initialize(kBufferSize);
58
59 // Note: parser->SetBuffer would normally be called through
60 // helper_->Initialize but currently it needs a GpuCommandBufferStub as the
61 // CommandBuffer instead of the CommandBufferService for that to happen.
62 Buffer ring_buffer = helper_->get_ring_buffer();
63 parser_->SetBuffer(ring_buffer.ptr, ring_buffer.size, 0, ring_buffer.size);
64 } 58 }
65 59
66 int32 GetToken() { 60 int32 GetToken() {
67 return command_buffer_->GetState().token; 61 return command_buffer_->GetState().token;
68 } 62 }
69 63
70 #if defined(OS_MACOSX) 64 #if defined(OS_MACOSX)
71 base::mac::ScopedNSAutoreleasePool autorelease_pool_; 65 base::mac::ScopedNSAutoreleasePool autorelease_pool_;
72 #endif 66 #endif
73 MessageLoop message_loop_; 67 MessageLoop message_loop_;
74 scoped_ptr<AsyncAPIMock> api_mock_; 68 scoped_ptr<AsyncAPIMock> api_mock_;
75 scoped_ptr<CommandBufferService> command_buffer_; 69 scoped_ptr<CommandBufferService> command_buffer_;
76 scoped_ptr<GpuScheduler> gpu_scheduler_; 70 scoped_ptr<GpuScheduler> gpu_scheduler_;
77 CommandParser* parser_;
78 scoped_ptr<CommandBufferHelper> helper_; 71 scoped_ptr<CommandBufferHelper> helper_;
79 }; 72 };
80 73
81 #ifndef _MSC_VER 74 #ifndef _MSC_VER
82 const unsigned int MappedMemoryTestBase::kBufferSize; 75 const unsigned int MappedMemoryTestBase::kBufferSize;
83 #endif 76 #endif
84 77
85 // Test fixture for MemoryChunk test - Creates a MemoryChunk, using a 78 // Test fixture for MemoryChunk test - Creates a MemoryChunk, using a
86 // CommandBufferHelper with a mock AsyncAPIInterface for its interface (calling 79 // CommandBufferHelper with a mock AsyncAPIInterface for its interface (calling
87 // it directly, not through the RPC mechanism), making sure Noops are ignored 80 // it directly, not through the RPC mechanism), making sure Noops are ignored
(...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after
297 ASSERT_TRUE(mem3); 290 ASSERT_TRUE(mem3);
298 EXPECT_NE(-1, id1); 291 EXPECT_NE(-1, id1);
299 EXPECT_EQ(id1, id2); 292 EXPECT_EQ(id1, id2);
300 EXPECT_NE(id2, id3); 293 EXPECT_NE(id2, id3);
301 EXPECT_EQ(0u, offset1); 294 EXPECT_EQ(0u, offset1);
302 EXPECT_EQ(kSize, offset2); 295 EXPECT_EQ(kSize, offset2);
303 EXPECT_EQ(0u, offset3); 296 EXPECT_EQ(0u, offset3);
304 } 297 }
305 298
306 } // namespace gpu 299 } // namespace gpu
OLDNEW
« no previous file with comments | « gpu/command_buffer/client/gles2_implementation.cc ('k') | gpu/command_buffer/client/ring_buffer_test.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698