diff options
author | 2018-07-11 15:58:57 -0400 | |
---|---|---|
committer | 2018-07-11 20:00:11 +0000 | |
commit | f4c5bb9aba485aa47c27b15905d81992b7cf4707 (patch) | |
tree | 7d433499c4e7d1ea33d09c56fb746ed1d20b58a7 /src/gpu/GrProxyProvider.cpp | |
parent | b188da121c1575caa6b0b9755e3f80a6b5e44611 (diff) |
Make GPU cache invalidation SkMessageBus messages go to one GrContext.
Makes it so the template param to SkMessageBus must implement:
bool shouldSend(uint32_t inboxID) const
Updates all GPU backend message types to only go to the GrContext that
is adding a cache entry.
Bug: skia:
Change-Id: I3e8a4eb90654b7b8ac57cac9fb508c0ef1d51058
Reviewed-on: https://skia-review.googlesource.com/140220
Reviewed-by: Robert Phillips <robertphillips@google.com>
Reviewed-by: Jim Van Verth <jvanverth@google.com>
Diffstat (limited to 'src/gpu/GrProxyProvider.cpp')
-rw-r--r-- | src/gpu/GrProxyProvider.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/src/gpu/GrProxyProvider.cpp b/src/gpu/GrProxyProvider.cpp index e259e34e28..df7b61e700 100644 --- a/src/gpu/GrProxyProvider.cpp +++ b/src/gpu/GrProxyProvider.cpp @@ -37,11 +37,32 @@ GrProxyProvider::GrProxyProvider(GrResourceProvider* resourceProvider, , fResourceCache(resourceCache) , fAbandoned(false) , fCaps(caps) + , fContextUniqueID(resourceCache->contextUniqueID()) #ifdef SK_DEBUG , fSingleOwner(owner) #endif { + SkASSERT(fResourceProvider); + SkASSERT(fResourceCache); + SkASSERT(fCaps); + SkASSERT(fSingleOwner); +} +GrProxyProvider::GrProxyProvider(uint32_t contextUniqueID, + sk_sp<const GrCaps> caps, + GrSingleOwner* owner) + : fResourceProvider(nullptr) + , fResourceCache(nullptr) + , fAbandoned(false) + , fCaps(caps) + , fContextUniqueID(contextUniqueID) +#ifdef SK_DEBUG + , fSingleOwner(owner) +#endif +{ + SkASSERT(fContextUniqueID != SK_InvalidUniqueID); + SkASSERT(fCaps); + SkASSERT(fSingleOwner); } GrProxyProvider::~GrProxyProvider() { |