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

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

Issue 255713008: Change glimage to accept a type. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: no ozone Created 6 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 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/gpu_memory_buffer_tracker.h" 5 #include "gpu/command_buffer/client/gpu_memory_buffer_tracker.h"
6 6
7 #include "base/memory/scoped_ptr.h" 7 #include "base/memory/scoped_ptr.h"
8 #include "gpu/command_buffer/client/gles2_implementation.h" 8 #include "gpu/command_buffer/client/gles2_implementation.h"
9 #include "gpu/command_buffer/common/gpu_control.h" 9 #include "gpu/command_buffer/common/gpu_control.h"
10 10
11 namespace gpu { 11 namespace gpu {
12 namespace gles2 { 12 namespace gles2 {
13 13
14 GpuMemoryBufferTracker::GpuMemoryBufferTracker(GpuControl* gpu_control) 14 GpuMemoryBufferTracker::GpuMemoryBufferTracker(GpuControl* gpu_control)
15 : gpu_control_(gpu_control) { 15 : gpu_control_(gpu_control) {
16 } 16 }
17 17
18 GpuMemoryBufferTracker::~GpuMemoryBufferTracker() { 18 GpuMemoryBufferTracker::~GpuMemoryBufferTracker() {
19 while (!buffers_.empty()) { 19 while (!buffers_.empty()) {
20 RemoveBuffer(buffers_.begin()->first); 20 RemoveBuffer(buffers_.begin()->first);
21 } 21 }
22 } 22 }
23 23
24 int32 GpuMemoryBufferTracker::CreateBuffer( 24 int32 GpuMemoryBufferTracker::CreateBuffer(size_t width,
25 size_t width, size_t height, int32 internalformat) { 25 size_t height,
26 int32 internalformat,
27 gfx::GpuMemoryBuffer::Usage usage) {
26 int32 image_id = 0; 28 int32 image_id = 0;
27 DCHECK(gpu_control_); 29 DCHECK(gpu_control_);
28 gfx::GpuMemoryBuffer* buffer = gpu_control_->CreateGpuMemoryBuffer( 30 gfx::GpuMemoryBuffer* buffer = gpu_control_->CreateGpuMemoryBuffer(
29 width, height, internalformat, &image_id); 31 width, height, internalformat, usage, &image_id);
30 if (!buffer) 32 if (!buffer)
31 return 0; 33 return 0;
32 34
33 std::pair<BufferMap::iterator, bool> result = 35 std::pair<BufferMap::iterator, bool> result =
34 buffers_.insert(std::make_pair(image_id, buffer)); 36 buffers_.insert(std::make_pair(image_id, buffer));
35 DCHECK(result.second); 37 DCHECK(result.second);
36 38
37 return image_id; 39 return image_id;
38 } 40 }
39 41
40 gfx::GpuMemoryBuffer* GpuMemoryBufferTracker::GetBuffer(int32 image_id) { 42 gfx::GpuMemoryBuffer* GpuMemoryBufferTracker::GetBuffer(int32 image_id) {
41 BufferMap::iterator it = buffers_.find(image_id); 43 BufferMap::iterator it = buffers_.find(image_id);
42 return (it != buffers_.end()) ? it->second : NULL; 44 return (it != buffers_.end()) ? it->second : NULL;
43 } 45 }
44 46
45 void GpuMemoryBufferTracker::RemoveBuffer(int32 image_id) { 47 void GpuMemoryBufferTracker::RemoveBuffer(int32 image_id) {
46 BufferMap::iterator buffer_it = buffers_.find(image_id); 48 BufferMap::iterator buffer_it = buffers_.find(image_id);
47 if (buffer_it != buffers_.end()) 49 if (buffer_it != buffers_.end())
48 buffers_.erase(buffer_it); 50 buffers_.erase(buffer_it);
49 DCHECK(gpu_control_); 51 DCHECK(gpu_control_);
50 gpu_control_->DestroyGpuMemoryBuffer(image_id); 52 gpu_control_->DestroyGpuMemoryBuffer(image_id);
51 } 53 }
52 54
53 } // namespace gles2 55 } // namespace gles2
54 } // namespace gpu 56 } // namespace gpu
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698