Update GrResourceCache changeUniqueKey to stay in valid state after each step

The issues are that we are intertwining removing things from the old and new
resource. This changes it so we do all the removal on the old resource first
then start updating the new resource.

Bug: skia:
Change-Id: I7ce4a309290cd499cdc4398c87d1cfd42ef6994d
Reviewed-on: https://skia-review.googlesource.com/44242
Reviewed-by: Brian Salomon <bsalomon@google.com>
Commit-Queue: Greg Daniel <egdaniel@google.com>
This commit is contained in:
Greg Daniel 2017-09-08 11:44:14 -04:00 committed by Skia Commit-Bot
parent 33fea05c3f
commit 0d53780b8c

View File

@ -294,6 +294,16 @@ void GrResourceCache::changeUniqueKey(GrGpuResource* resource, const GrUniqueKey
// If another resource has the new key, remove its key then install the key on this resource. // If another resource has the new key, remove its key then install the key on this resource.
if (newKey.isValid()) { if (newKey.isValid()) {
if (GrGpuResource* old = fUniqueHash.find(newKey)) {
// If the old resource using the key is purgeable and is unreachable, then remove it.
if (!old->resourcePriv().getScratchKey().isValid() && old->isPurgeable()) {
old->cacheAccess().release();
} else {
this->removeUniqueKey(old);
}
}
SkASSERT(nullptr == fUniqueHash.find(newKey));
// Remove the entry for this resource if it already has a unique key. // Remove the entry for this resource if it already has a unique key.
if (resource->getUniqueKey().isValid()) { if (resource->getUniqueKey().isValid()) {
SkASSERT(resource == fUniqueHash.find(resource->getUniqueKey())); SkASSERT(resource == fUniqueHash.find(resource->getUniqueKey()));
@ -307,18 +317,6 @@ void GrResourceCache::changeUniqueKey(GrGpuResource* resource, const GrUniqueKey
} }
} }
if (GrGpuResource* old = fUniqueHash.find(newKey)) {
// If the old resource using the key is purgeable and is unreachable, then remove it.
if (!old->resourcePriv().getScratchKey().isValid() && old->isPurgeable()) {
// release may call validate() which will assert that resource is in fUniqueHash
// if it has a valid key. So in debug reset the key here before we assign it.
SkDEBUGCODE(resource->cacheAccess().removeUniqueKey();)
old->cacheAccess().release();
} else {
this->removeUniqueKey(old);
}
}
SkASSERT(nullptr == fUniqueHash.find(newKey));
resource->cacheAccess().setUniqueKey(newKey); resource->cacheAccess().setUniqueKey(newKey);
fUniqueHash.add(resource); fUniqueHash.add(resource);
} else { } else {