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

Side by Side Diff: cc/resources/resource_pool.cc

Issue 21159007: cc: Adding support for RGBA_4444 tile textures (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Code review comments Created 7 years, 3 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
OLDNEW
1 // Copyright 2012 The Chromium Authors. All rights reserved. 1 // Copyright 2012 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 "cc/resources/resource_pool.h" 5 #include "cc/resources/resource_pool.h"
6 6
7 #include "cc/resources/resource_provider.h" 7 #include "cc/resources/resource_provider.h"
8 8
9 namespace cc { 9 namespace cc {
10 10
11 ResourcePool::Resource::Resource(cc::ResourceProvider* resource_provider, 11 ResourcePool::Resource::Resource(cc::ResourceProvider* resource_provider,
12 gfx::Size size, 12 gfx::Size size,
13 GLenum format) 13 GLenum format,
epennerAtGoogle 2013/09/06 03:24:44 Again, I we should be able to have one Enum that f
14 cc::ResourceProvider::TextureType type)
14 : cc::Resource(resource_provider->CreateManagedResource( 15 : cc::Resource(resource_provider->CreateManagedResource(
15 size, 16 size,
16 format, 17 format,
17 ResourceProvider::TextureUsageAny), 18 ResourceProvider::TextureUsageAny),
18 size, 19 size,
19 format), 20 format,
21 type),
20 resource_provider_(resource_provider) { 22 resource_provider_(resource_provider) {
21 DCHECK(id()); 23 DCHECK(id());
22 } 24 }
23 25
24 ResourcePool::Resource::~Resource() { 26 ResourcePool::Resource::~Resource() {
25 DCHECK(id()); 27 DCHECK(id());
26 DCHECK(resource_provider_); 28 DCHECK(resource_provider_);
27 resource_provider_->DeleteResource(id()); 29 resource_provider_->DeleteResource(id());
28 } 30 }
29 31
30 ResourcePool::ResourcePool(ResourceProvider* resource_provider) 32 ResourcePool::ResourcePool(ResourceProvider* resource_provider)
31 : resource_provider_(resource_provider), 33 : resource_provider_(resource_provider),
32 max_memory_usage_bytes_(0), 34 max_memory_usage_bytes_(0),
33 max_unused_memory_usage_bytes_(0), 35 max_unused_memory_usage_bytes_(0),
34 max_resource_count_(0), 36 max_resource_count_(0),
35 memory_usage_bytes_(0), 37 memory_usage_bytes_(0),
36 unused_memory_usage_bytes_(0), 38 unused_memory_usage_bytes_(0),
37 resource_count_(0) { 39 resource_count_(0) {
38 } 40 }
39 41
40 ResourcePool::~ResourcePool() { 42 ResourcePool::~ResourcePool() {
41 SetResourceUsageLimits(0, 0, 0); 43 SetResourceUsageLimits(0, 0, 0);
42 } 44 }
43 45
44 scoped_ptr<ResourcePool::Resource> ResourcePool::AcquireResource( 46 scoped_ptr<ResourcePool::Resource> ResourcePool::AcquireResource(
45 gfx::Size size, GLenum format) { 47 gfx::Size size, GLenum format, ResourceProvider::TextureType type) {
46 for (ResourceList::iterator it = unused_resources_.begin(); 48 for (ResourceList::iterator it = unused_resources_.begin();
47 it != unused_resources_.end(); ++it) { 49 it != unused_resources_.end(); ++it) {
48 Resource* resource = *it; 50 Resource* resource = *it;
49 51
50 if (!resource_provider_->CanLockForWrite(resource->id())) 52 if (!resource_provider_->CanLockForWrite(resource->id()))
51 continue; 53 continue;
52 if (resource->size() != size) 54 if (resource->size() != size)
53 continue; 55 continue;
54 if (resource->format() != format) 56 if (resource->format() != format)
55 continue; 57 continue;
56 58
57 unused_resources_.erase(it); 59 unused_resources_.erase(it);
58 unused_memory_usage_bytes_ -= resource->bytes(); 60 unused_memory_usage_bytes_ -= resource->bytes();
59 return make_scoped_ptr(resource); 61 return make_scoped_ptr(resource);
60 } 62 }
61 63
62 // Create new resource. 64 // Create new resource.
63 Resource* resource = new Resource(resource_provider_, size, format); 65 Resource* resource = new Resource(
66 resource_provider_, size, format, type);
64 67
65 // Extend all read locks on all resources until the resource is 68 // Extend all read locks on all resources until the resource is
66 // finished being used, such that we know when resources are 69 // finished being used, such that we know when resources are
67 // truly safe to recycle. 70 // truly safe to recycle.
68 resource_provider_->EnableReadLockFences(resource->id(), true); 71 resource_provider_->EnableReadLockFences(resource->id(), true);
69 72
70 memory_usage_bytes_ += resource->bytes(); 73 memory_usage_bytes_ += resource->bytes();
71 ++resource_count_; 74 ++resource_count_;
72 return make_scoped_ptr(resource); 75 return make_scoped_ptr(resource);
73 } 76 }
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after
120 if (resource_count_ > max_resource_count_) 123 if (resource_count_ > max_resource_count_)
121 return true; 124 return true;
122 if (memory_usage_bytes_ > max_memory_usage_bytes_) 125 if (memory_usage_bytes_ > max_memory_usage_bytes_)
123 return true; 126 return true;
124 if (unused_memory_usage_bytes_ > max_unused_memory_usage_bytes_) 127 if (unused_memory_usage_bytes_ > max_unused_memory_usage_bytes_)
125 return true; 128 return true;
126 return false; 129 return false;
127 } 130 }
128 131
129 } // namespace cc 132 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698