| 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 GrGpuResource_DEFINED | 8 #ifndef GrGpuResource_DEFINED |
| 9 #define GrGpuResource_DEFINED | 9 #define GrGpuResource_DEFINED |
| 10 | 10 |
| (...skipping 173 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 184 | 184 |
| 185 GrGpu* getGpu() const { return fGpu; } | 185 GrGpu* getGpu() const { return fGpu; } |
| 186 | 186 |
| 187 /** Overridden to free GPU resources in the backend API. */ | 187 /** Overridden to free GPU resources in the backend API. */ |
| 188 virtual void onRelease() { } | 188 virtual void onRelease() { } |
| 189 /** Overridden to abandon any internal handles, ptrs, etc to backend API res
ources. | 189 /** Overridden to abandon any internal handles, ptrs, etc to backend API res
ources. |
| 190 This may be called when the underlying 3D context is no longer valid and
so no | 190 This may be called when the underlying 3D context is no longer valid and
so no |
| 191 backend API calls should be made. */ | 191 backend API calls should be made. */ |
| 192 virtual void onAbandon() { } | 192 virtual void onAbandon() { } |
| 193 | 193 |
| 194 bool isWrapped() const { return kWrapped_FlagBit & fFlags; } | 194 bool isWrapped() const { return SkToBool(kWrapped_Flag & fFlags); } |
| 195 | 195 |
| 196 /** | 196 /** |
| 197 * This entry point should be called whenever gpuMemorySize() should report
a different size. | 197 * This entry point should be called whenever gpuMemorySize() should report
a different size. |
| 198 * The cache will call gpuMemorySize() to update the current size of the res
ource. | 198 * The cache will call gpuMemorySize() to update the current size of the res
ource. |
| 199 */ | 199 */ |
| 200 void didChangeGpuMemorySize() const; | 200 void didChangeGpuMemorySize() const; |
| 201 | 201 |
| 202 /** | 202 /** |
| 203 * Optionally called by the GrGpuResource subclass if the resource can be us
ed as scratch. | 203 * Optionally called by the GrGpuResource subclass if the resource can be us
ed as scratch. |
| 204 * By default resources are not usable as scratch. This should only be calle
d once. | 204 * By default resources are not usable as scratch. This should only be calle
d once. |
| 205 **/ | 205 **/ |
| 206 void setScratchKey(const GrResourceKey& scratchKey); | 206 void setScratchKey(const GrResourceKey& scratchKey); |
| 207 | 207 |
| 208 private: | 208 private: |
| 209 /** | 209 /** |
| 210 * Frees the object in the underlying 3D API. Called by CacheAccess. | 210 * Frees the object in the underlying 3D API. Called by CacheAccess. |
| 211 */ | 211 */ |
| 212 void release(); | 212 void release(); |
| 213 | 213 |
| 214 /** | 214 /** |
| 215 * Removes references to objects in the underlying 3D API without freeing th
em. | 215 * Removes references to objects in the underlying 3D API without freeing th
em. |
| 216 * Called by CacheAccess. | 216 * Called by CacheAccess. |
| 217 */ | 217 */ |
| 218 void abandon(); | 218 void abandon(); |
| 219 | 219 |
| 220 virtual size_t onGpuMemorySize() const = 0; | 220 virtual size_t onGpuMemorySize() const = 0; |
| 221 | 221 |
| 222 // See comments in CacheAccess. | 222 // See comments in CacheAccess. |
| 223 bool setContentKey(const GrResourceKey& contentKey); | 223 bool setContentKey(const GrResourceKey& contentKey); |
| 224 | 224 void setBudgeted(bool countsAgainstBudget); |
| 225 void notifyIsPurgable() const; | 225 void notifyIsPurgable() const; |
| 226 | 226 |
| 227 #ifdef SK_DEBUG | 227 #ifdef SK_DEBUG |
| 228 friend class GrGpu; // for assert in GrGpu to access getGpu | 228 friend class GrGpu; // for assert in GrGpu to access getGpu |
| 229 #endif | 229 #endif |
| 230 | 230 |
| 231 static uint32_t CreateUniqueID(); | 231 static uint32_t CreateUniqueID(); |
| 232 | 232 |
| 233 // We're in an internal doubly linked list owned by GrResourceCache2 | 233 // We're in an internal doubly linked list owned by GrResourceCache2 |
| 234 SK_DECLARE_INTERNAL_LLIST_INTERFACE(GrGpuResource); | 234 SK_DECLARE_INTERNAL_LLIST_INTERFACE(GrGpuResource); |
| 235 | 235 |
| 236 // This is not ref'ed but abandon() or release() will be called before the G
rGpu object | |
| 237 // is destroyed. Those calls set will this to NULL. | |
| 238 GrGpu* fGpu; | |
| 239 | 236 |
| 237 static const size_t kInvalidGpuMemorySize = ~static_cast<size_t>(0); |
| 240 enum Flags { | 238 enum Flags { |
| 241 /** | 239 /** |
| 242 * This object wraps a GPU object given to us by the user. | 240 * The resource counts against the resource cache's budget. |
| 243 * Lifetime management is left up to the user (i.e., we will not | |
| 244 * free it). | |
| 245 */ | 241 */ |
| 246 kWrapped_FlagBit = 0x1, | 242 kBudgeted_Flag = 0x1, |
| 243 |
| 244 /** |
| 245 * This object wraps a GPU object given to us by Skia's client. Skia wil
l not free the |
| 246 * underlying backend API GPU resources when the GrGpuResource is destro
yed. This also |
| 247 * implies that kBudgeted_Flag is not set. |
| 248 */ |
| 249 kWrapped_Flag = 0x2, |
| 250 |
| 251 /** |
| 252 * If set then fContentKey is valid and the resource is cached based on
its content. |
| 253 */ |
| 254 kContentKeySet_Flag = 0x4, |
| 247 }; | 255 }; |
| 248 | 256 |
| 249 static const size_t kInvalidGpuMemorySize = ~static_cast<size_t>(0); | |
| 250 | |
| 251 uint32_t fFlags; | |
| 252 | |
| 253 mutable size_t fGpuMemorySize; | |
| 254 const uint32_t fUniqueID; | |
| 255 | |
| 256 // TODO(bsalomon): Remove GrResourceKey and use different simpler types for
content and scratch | 257 // TODO(bsalomon): Remove GrResourceKey and use different simpler types for
content and scratch |
| 257 // keys. | 258 // keys. |
| 258 GrResourceKey fScratchKey; | 259 GrResourceKey fScratchKey; |
| 259 GrResourceKey fContentKey; | 260 GrResourceKey fContentKey; |
| 260 bool fContentKeySet; | 261 |
| 262 // This is not ref'ed but abandon() or release() will be called before the G
rGpu object |
| 263 // is destroyed. Those calls set will this to NULL. |
| 264 GrGpu* fGpu; |
| 265 mutable size_t fGpuMemorySize; |
| 266 |
| 267 uint32_t fFlags; |
| 268 const uint32_t fUniqueID; |
| 261 | 269 |
| 262 typedef GrIORef<GrGpuResource> INHERITED; | 270 typedef GrIORef<GrGpuResource> INHERITED; |
| 263 friend class GrIORef<GrGpuResource>; // to access notifyIsPurgable. | 271 friend class GrIORef<GrGpuResource>; // to access notifyIsPurgable. |
| 264 }; | 272 }; |
| 265 | 273 |
| 266 #endif | 274 #endif |
| OLD | NEW |