OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #ifndef GrResourceCache_DEFINED | 8 #ifndef GrResourceCache_DEFINED |
9 #define GrResourceCache_DEFINED | 9 #define GrResourceCache_DEFINED |
10 | 10 |
11 #include "GrGpuResource.h" | 11 #include "GrGpuResource.h" |
12 #include "GrGpuResourceCacheAccess.h" | 12 #include "GrGpuResourceCacheAccess.h" |
13 #include "GrGpuResourcePriv.h" | 13 #include "GrGpuResourcePriv.h" |
| 14 #include "GrResourceCache.h" |
14 #include "GrResourceKey.h" | 15 #include "GrResourceKey.h" |
15 #include "SkMessageBus.h" | 16 #include "SkMessageBus.h" |
16 #include "SkRefCnt.h" | 17 #include "SkRefCnt.h" |
17 #include "SkTArray.h" | 18 #include "SkTArray.h" |
18 #include "SkTDPQueue.h" | 19 #include "SkTDPQueue.h" |
19 #include "SkTInternalLList.h" | 20 #include "SkTInternalLList.h" |
20 #include "SkTMultiMap.h" | 21 #include "SkTMultiMap.h" |
21 | 22 |
22 class GrCaps; | 23 class GrCaps; |
23 class SkString; | 24 class SkString; |
(...skipping 132 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
156 return SkToBool(fUniqueHash.find(key)); | 157 return SkToBool(fUniqueHash.find(key)); |
157 } | 158 } |
158 | 159 |
159 /** Purges resources to become under budget and processes resources with inv
alidated unique | 160 /** Purges resources to become under budget and processes resources with inv
alidated unique |
160 keys. */ | 161 keys. */ |
161 void purgeAsNeeded(); | 162 void purgeAsNeeded(); |
162 | 163 |
163 /** Purges all resources that don't have external owners. */ | 164 /** Purges all resources that don't have external owners. */ |
164 void purgeAllUnlocked(); | 165 void purgeAllUnlocked(); |
165 | 166 |
166 /** | 167 /** Returns true if the cache would like a flush to occur in order to make m
ore resources |
167 * The callback function used by the cache when it is still over budget afte
r a purge. The | 168 purgeable. */ |
168 * passed in 'data' is the same 'data' handed to setOverbudgetCallback. | 169 bool requestsFlush() const { return fRequestFlush; } |
169 */ | |
170 typedef void (*PFOverBudgetCB)(void* data); | |
171 | 170 |
172 /** | 171 enum FlushType { |
173 * Set the callback the cache should use when it is still over budget after
a purge. The 'data' | 172 kExternal, |
174 * provided here will be passed back to the callback. Note that the cache wi
ll attempt to purge | 173 kImmediateMode, |
175 * any resources newly freed by the callback. | 174 kCacheRequested, |
176 */ | 175 }; |
177 void setOverBudgetCallback(PFOverBudgetCB overBudgetCB, void* data) { | 176 void notifyFlushOccurred(FlushType); |
178 fOverBudgetCB = overBudgetCB; | |
179 fOverBudgetData = data; | |
180 } | |
181 | |
182 void notifyFlushOccurred(); | |
183 | 177 |
184 #if GR_CACHE_STATS | 178 #if GR_CACHE_STATS |
185 struct Stats { | 179 struct Stats { |
186 int fTotal; | 180 int fTotal; |
187 int fNumPurgeable; | 181 int fNumPurgeable; |
188 int fNumNonPurgeable; | 182 int fNumNonPurgeable; |
189 | 183 |
190 int fScratch; | 184 int fScratch; |
191 int fWrapped; | 185 int fWrapped; |
192 size_t fUnbudgetedSize; | 186 size_t fUnbudgetedSize; |
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
319 #endif | 313 #endif |
320 | 314 |
321 // our current stats for all resources | 315 // our current stats for all resources |
322 SkDEBUGCODE(int fCount;) | 316 SkDEBUGCODE(int fCount;) |
323 size_t fBytes; | 317 size_t fBytes; |
324 | 318 |
325 // our current stats for resources that count against the budget | 319 // our current stats for resources that count against the budget |
326 int fBudgetedCount; | 320 int fBudgetedCount; |
327 size_t fBudgetedBytes; | 321 size_t fBudgetedBytes; |
328 | 322 |
329 PFOverBudgetCB fOverBudgetCB; | 323 bool fRequestFlush; |
330 void* fOverBudgetData; | |
331 | 324 |
332 // We keep track of the "timestamps" of the last n flushes. If a resource ha
sn't been used in | 325 // We keep track of the "timestamps" of the last n flushes. If a resource ha
sn't been used in |
333 // that time then we well preemptively purge it to reduce memory usage. | 326 // that time then we well preemptively purge it to reduce memory usage. |
334 uint32_t* fFlushTimestamps; | 327 uint32_t* fFlushTimestamps; |
335 int fLastFlushTimestampIndex; | 328 int fLastFlushTimestampIndex; |
336 | 329 |
337 InvalidUniqueKeyInbox fInvalidUniqueKeyInbox; | 330 InvalidUniqueKeyInbox fInvalidUniqueKeyInbox; |
338 | 331 |
339 // This resource is allowed to be in the nonpurgeable array for the sake of
validate() because | 332 // This resource is allowed to be in the nonpurgeable array for the sake of
validate() because |
340 // we're in the midst of converting it to purgeable status. | 333 // we're in the midst of converting it to purgeable status. |
(...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
420 | 413 |
421 friend class GrGpuResource; // To access all the proxy inline methods. | 414 friend class GrGpuResource; // To access all the proxy inline methods. |
422 friend class GrResourceCache; // To create this type. | 415 friend class GrResourceCache; // To create this type. |
423 }; | 416 }; |
424 | 417 |
425 inline GrResourceCache::ResourceAccess GrResourceCache::resourceAccess() { | 418 inline GrResourceCache::ResourceAccess GrResourceCache::resourceAccess() { |
426 return ResourceAccess(this); | 419 return ResourceAccess(this); |
427 } | 420 } |
428 | 421 |
429 #endif | 422 #endif |
OLD | NEW |