OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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_TILES_SOFTWARE_IMAGE_DECODE_CONTROLLER_H_ | 5 #ifndef CC_TILES_SOFTWARE_IMAGE_DECODE_CONTROLLER_H_ |
6 #define CC_TILES_SOFTWARE_IMAGE_DECODE_CONTROLLER_H_ | 6 #define CC_TILES_SOFTWARE_IMAGE_DECODE_CONTROLLER_H_ |
7 | 7 |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 | 9 |
| 10 #include <memory> |
10 #include <unordered_map> | 11 #include <unordered_map> |
11 #include <unordered_set> | 12 #include <unordered_set> |
12 | 13 |
13 #include "base/atomic_sequence_num.h" | 14 #include "base/atomic_sequence_num.h" |
14 #include "base/containers/mru_cache.h" | 15 #include "base/containers/mru_cache.h" |
15 #include "base/hash.h" | 16 #include "base/hash.h" |
16 #include "base/memory/discardable_memory_allocator.h" | 17 #include "base/memory/discardable_memory_allocator.h" |
17 #include "base/memory/ref_counted.h" | 18 #include "base/memory/ref_counted.h" |
18 #include "base/numerics/safe_math.h" | 19 #include "base/numerics/safe_math.h" |
19 #include "base/threading/thread_checker.h" | 20 #include "base/threading/thread_checker.h" |
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
125 // MemoryDumpProvider overrides. | 126 // MemoryDumpProvider overrides. |
126 bool OnMemoryDump(const base::trace_event::MemoryDumpArgs& args, | 127 bool OnMemoryDump(const base::trace_event::MemoryDumpArgs& args, |
127 base::trace_event::ProcessMemoryDump* pmd) override; | 128 base::trace_event::ProcessMemoryDump* pmd) override; |
128 | 129 |
129 private: | 130 private: |
130 // DecodedImage is a convenience storage for discardable memory. It can also | 131 // DecodedImage is a convenience storage for discardable memory. It can also |
131 // construct an image out of SkImageInfo and stored discardable memory. | 132 // construct an image out of SkImageInfo and stored discardable memory. |
132 class DecodedImage { | 133 class DecodedImage { |
133 public: | 134 public: |
134 DecodedImage(const SkImageInfo& info, | 135 DecodedImage(const SkImageInfo& info, |
135 scoped_ptr<base::DiscardableMemory> memory, | 136 std::unique_ptr<base::DiscardableMemory> memory, |
136 const SkSize& src_rect_offset, | 137 const SkSize& src_rect_offset, |
137 uint64_t tracing_id); | 138 uint64_t tracing_id); |
138 ~DecodedImage(); | 139 ~DecodedImage(); |
139 | 140 |
140 SkImage* image() const { | 141 SkImage* image() const { |
141 DCHECK(locked_); | 142 DCHECK(locked_); |
142 return image_.get(); | 143 return image_.get(); |
143 } | 144 } |
144 | 145 |
145 const SkSize& src_rect_offset() const { return src_rect_offset_; } | 146 const SkSize& src_rect_offset() const { return src_rect_offset_; } |
146 | 147 |
147 bool is_locked() const { return locked_; } | 148 bool is_locked() const { return locked_; } |
148 bool Lock(); | 149 bool Lock(); |
149 void Unlock(); | 150 void Unlock(); |
150 | 151 |
151 const base::DiscardableMemory* memory() const { return memory_.get(); } | 152 const base::DiscardableMemory* memory() const { return memory_.get(); } |
152 | 153 |
153 // An ID which uniquely identifies this DecodedImage within the image decode | 154 // An ID which uniquely identifies this DecodedImage within the image decode |
154 // controller. Used in memory tracing. | 155 // controller. Used in memory tracing. |
155 uint64_t tracing_id() const { return tracing_id_; } | 156 uint64_t tracing_id() const { return tracing_id_; } |
156 | 157 |
157 private: | 158 private: |
158 bool locked_; | 159 bool locked_; |
159 SkImageInfo image_info_; | 160 SkImageInfo image_info_; |
160 scoped_ptr<base::DiscardableMemory> memory_; | 161 std::unique_ptr<base::DiscardableMemory> memory_; |
161 skia::RefPtr<SkImage> image_; | 162 skia::RefPtr<SkImage> image_; |
162 SkSize src_rect_offset_; | 163 SkSize src_rect_offset_; |
163 uint64_t tracing_id_; | 164 uint64_t tracing_id_; |
164 }; | 165 }; |
165 | 166 |
166 // MemoryBudget is a convenience class for memory bookkeeping and ensuring | 167 // MemoryBudget is a convenience class for memory bookkeeping and ensuring |
167 // that we don't go over the limit when pre-decoding. | 168 // that we don't go over the limit when pre-decoding. |
168 class MemoryBudget { | 169 class MemoryBudget { |
169 public: | 170 public: |
170 explicit MemoryBudget(size_t limit_bytes); | 171 explicit MemoryBudget(size_t limit_bytes); |
171 | 172 |
172 size_t AvailableMemoryBytes() const; | 173 size_t AvailableMemoryBytes() const; |
173 void AddUsage(size_t usage); | 174 void AddUsage(size_t usage); |
174 void SubtractUsage(size_t usage); | 175 void SubtractUsage(size_t usage); |
175 void ResetUsage(); | 176 void ResetUsage(); |
176 | 177 |
177 private: | 178 private: |
178 size_t GetCurrentUsageSafe() const; | 179 size_t GetCurrentUsageSafe() const; |
179 | 180 |
180 size_t limit_bytes_; | 181 size_t limit_bytes_; |
181 base::CheckedNumeric<size_t> current_usage_bytes_; | 182 base::CheckedNumeric<size_t> current_usage_bytes_; |
182 }; | 183 }; |
183 | 184 |
184 using ImageMRUCache = | 185 using ImageMRUCache = base::HashingMRUCache<ImageKey, |
185 base::HashingMRUCache<ImageKey, scoped_ptr<DecodedImage>, ImageKeyHash>; | 186 std::unique_ptr<DecodedImage>, |
| 187 ImageKeyHash>; |
186 | 188 |
187 // Looks for the key in the cache and returns true if it was found and was | 189 // Looks for the key in the cache and returns true if it was found and was |
188 // successfully locked (or if it was already locked). Note that if this | 190 // successfully locked (or if it was already locked). Note that if this |
189 // function returns true, then a ref count is increased for the image. | 191 // function returns true, then a ref count is increased for the image. |
190 bool LockDecodedImageIfPossibleAndRef(const ImageKey& key); | 192 bool LockDecodedImageIfPossibleAndRef(const ImageKey& key); |
191 | 193 |
192 // Actually decode the image. Note that this function can (and should) be | 194 // Actually decode the image. Note that this function can (and should) be |
193 // called with no lock acquired, since it can do a lot of work. Note that it | 195 // called with no lock acquired, since it can do a lot of work. Note that it |
194 // can also return nullptr to indicate the decode failed. | 196 // can also return nullptr to indicate the decode failed. |
195 scoped_ptr<DecodedImage> DecodeImageInternal(const ImageKey& key, | 197 std::unique_ptr<DecodedImage> DecodeImageInternal( |
196 const DrawImage& draw_image); | 198 const ImageKey& key, |
| 199 const DrawImage& draw_image); |
197 | 200 |
198 // Get the decoded draw image for the given key and draw_image. Note that this | 201 // Get the decoded draw image for the given key and draw_image. Note that this |
199 // function has to be called with no lock acquired, since it will acquire its | 202 // function has to be called with no lock acquired, since it will acquire its |
200 // own locks and might call DecodeImageInternal above. Also note that this | 203 // own locks and might call DecodeImageInternal above. Also note that this |
201 // function will use the provided key, even if | 204 // function will use the provided key, even if |
202 // ImageKey::FromDrawImage(draw_image) would return a different key. | 205 // ImageKey::FromDrawImage(draw_image) would return a different key. |
203 // Note that when used internally, we still require that | 206 // Note that when used internally, we still require that |
204 // DrawWithImageFinished() is called afterwards. | 207 // DrawWithImageFinished() is called afterwards. |
205 DecodedDrawImage GetDecodedImageForDrawInternal(const ImageKey& key, | 208 DecodedDrawImage GetDecodedImageForDrawInternal(const ImageKey& key, |
206 const DrawImage& draw_image); | 209 const DrawImage& draw_image); |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
247 | 250 |
248 ResourceFormat format_; | 251 ResourceFormat format_; |
249 | 252 |
250 // Used to uniquely identify DecodedImages for memory traces. | 253 // Used to uniquely identify DecodedImages for memory traces. |
251 base::AtomicSequenceNumber next_tracing_id_; | 254 base::AtomicSequenceNumber next_tracing_id_; |
252 }; | 255 }; |
253 | 256 |
254 } // namespace cc | 257 } // namespace cc |
255 | 258 |
256 #endif // CC_TILES_SOFTWARE_IMAGE_DECODE_CONTROLLER_H_ | 259 #endif // CC_TILES_SOFTWARE_IMAGE_DECODE_CONTROLLER_H_ |
OLD | NEW |