| OLD | NEW |
| 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 #ifndef CC_RESOURCES_RESOURCE_POOL_H_ | 5 #ifndef CC_RESOURCES_RESOURCE_POOL_H_ |
| 6 #define CC_RESOURCES_RESOURCE_POOL_H_ | 6 #define CC_RESOURCES_RESOURCE_POOL_H_ |
| 7 | 7 |
| 8 #include <list> | 8 #include <deque> |
| 9 | 9 |
| 10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
| 11 #include "cc/base/cc_export.h" | 11 #include "cc/base/cc_export.h" |
| 12 #include "cc/output/renderer.h" | 12 #include "cc/output/renderer.h" |
| 13 #include "cc/resources/resource.h" | 13 #include "cc/resources/resource.h" |
| 14 #include "cc/resources/resource_format.h" | 14 #include "cc/resources/resource_format.h" |
| 15 | 15 |
| 16 namespace cc { | 16 namespace cc { |
| 17 class ScopedResource; | 17 class ScopedResource; |
| 18 | 18 |
| 19 class CC_EXPORT ResourcePool { | 19 class CC_EXPORT ResourcePool { |
| 20 public: | 20 public: |
| 21 static scoped_ptr<ResourcePool> Create(ResourceProvider* resource_provider, | 21 static scoped_ptr<ResourcePool> Create(ResourceProvider* resource_provider, |
| 22 GLenum target) { | 22 GLenum target) { |
| 23 return make_scoped_ptr(new ResourcePool(resource_provider, target)); | 23 return make_scoped_ptr(new ResourcePool(resource_provider, target)); |
| 24 } | 24 } |
| 25 | 25 |
| 26 virtual ~ResourcePool(); | 26 virtual ~ResourcePool(); |
| 27 | 27 |
| 28 scoped_ptr<ScopedResource> AcquireResource(const gfx::Size& size, | 28 scoped_ptr<ScopedResource> AcquireResource(const gfx::Size& size, |
| 29 ResourceFormat format); | 29 ResourceFormat format); |
| 30 void ReleaseResource(scoped_ptr<ScopedResource>); | 30 scoped_ptr<ScopedResource> TryAcquireOldResource(const gfx::Size& size, |
| 31 ResourceFormat format, |
| 32 uint64 id); |
| 33 scoped_ptr<ScopedResource> TryAcquireOldBusyResource(const gfx::Size& size, |
| 34 ResourceFormat format, |
| 35 uint64 id); |
| 36 void ReleaseResource(scoped_ptr<ScopedResource> resource, uint64_t id); |
| 31 | 37 |
| 32 void SetResourceUsageLimits(size_t max_memory_usage_bytes, | 38 void SetResourceUsageLimits(size_t max_memory_usage_bytes, |
| 33 size_t max_unused_memory_usage_bytes, | 39 size_t max_unused_memory_usage_bytes, |
| 34 size_t max_resource_count); | 40 size_t max_resource_count); |
| 35 | 41 |
| 36 void ReduceResourceUsage(); | 42 void ReduceResourceUsage(); |
| 37 // This might block if |wait_if_needed| is true and one of the currently | 43 // This might block if |wait_if_needed| is true and one of the currently |
| 38 // busy resources has a read lock fence that needs to be waited upon before | 44 // busy resources has a read lock fence that needs to be waited upon before |
| 39 // it can be locked for write again. | 45 // it can be locked for write again. |
| 40 void CheckBusyResources(bool wait_if_needed); | 46 void CheckBusyResources(bool wait_if_needed); |
| 41 | 47 |
| 42 size_t total_memory_usage_bytes() const { return memory_usage_bytes_; } | 48 size_t total_memory_usage_bytes() const { return memory_usage_bytes_; } |
| 43 size_t acquired_memory_usage_bytes() const { | 49 size_t acquired_memory_usage_bytes() const { |
| 44 return memory_usage_bytes_ - unused_memory_usage_bytes_; | 50 return memory_usage_bytes_ - unused_memory_usage_bytes_; |
| 45 } | 51 } |
| 46 size_t total_resource_count() const { return resource_count_; } | 52 size_t total_resource_count() const { return resource_count_; } |
| 47 size_t acquired_resource_count() const { | 53 size_t acquired_resource_count() const { |
| 48 return resource_count_ - unused_resources_.size(); | 54 return resource_count_ - unused_resources_.size(); |
| 49 } | 55 } |
| 50 size_t busy_resource_count() const { return busy_resources_.size(); } | 56 size_t busy_resource_count() const { return busy_resources_.size(); } |
| 51 | 57 |
| 52 protected: | 58 protected: |
| 53 ResourcePool(ResourceProvider* resource_provider, GLenum target); | 59 ResourcePool(ResourceProvider* resource_provider, GLenum target); |
| 54 | 60 |
| 55 bool ResourceUsageTooHigh(); | 61 bool ResourceUsageTooHigh(); |
| 56 | 62 |
| 57 private: | 63 private: |
| 58 void DidFinishUsingResource(ScopedResource* resource); | 64 void DidFinishUsingResource(ScopedResource* resource, uint64_t id); |
| 59 | 65 |
| 60 ResourceProvider* resource_provider_; | 66 ResourceProvider* resource_provider_; |
| 61 const GLenum target_; | 67 const GLenum target_; |
| 62 size_t max_memory_usage_bytes_; | 68 size_t max_memory_usage_bytes_; |
| 63 size_t max_unused_memory_usage_bytes_; | 69 size_t max_unused_memory_usage_bytes_; |
| 64 size_t max_resource_count_; | 70 size_t max_resource_count_; |
| 65 size_t memory_usage_bytes_; | 71 size_t memory_usage_bytes_; |
| 66 size_t unused_memory_usage_bytes_; | 72 size_t unused_memory_usage_bytes_; |
| 67 size_t resource_count_; | 73 size_t resource_count_; |
| 68 | 74 |
| 69 typedef std::list<ScopedResource*> ResourceList; | 75 struct PoolResource { |
| 76 PoolResource(ScopedResource* resource, uint64_t id) |
| 77 : resource(resource), id(id) {} |
| 78 ScopedResource* resource; |
| 79 uint64_t id; |
| 80 }; |
| 81 typedef std::deque<PoolResource> ResourceList; |
| 70 ResourceList unused_resources_; | 82 ResourceList unused_resources_; |
| 71 ResourceList busy_resources_; | 83 ResourceList busy_resources_; |
| 72 | 84 |
| 73 DISALLOW_COPY_AND_ASSIGN(ResourcePool); | 85 DISALLOW_COPY_AND_ASSIGN(ResourcePool); |
| 74 }; | 86 }; |
| 75 | 87 |
| 76 } // namespace cc | 88 } // namespace cc |
| 77 | 89 |
| 78 #endif // CC_RESOURCES_RESOURCE_POOL_H_ | 90 #endif // CC_RESOURCES_RESOURCE_POOL_H_ |
| OLD | NEW |