2011-07-28 14:26:00 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2011 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
2011-03-30 21:26:44 +00:00
|
|
|
*/
|
|
|
|
|
2014-07-25 15:35:45 +00:00
|
|
|
#include "GrGpuResource.h"
|
2015-06-01 08:37:26 +00:00
|
|
|
#include "GrContext.h"
|
2018-01-16 20:07:54 +00:00
|
|
|
#include "GrContextPriv.h"
|
2015-02-11 18:49:59 +00:00
|
|
|
#include "GrResourceCache.h"
|
2011-03-30 21:26:44 +00:00
|
|
|
#include "GrGpu.h"
|
2015-02-13 22:20:05 +00:00
|
|
|
#include "GrGpuResourcePriv.h"
|
2015-09-15 21:16:10 +00:00
|
|
|
#include "SkTraceMemoryDump.h"
|
2011-03-30 21:26:44 +00:00
|
|
|
|
2015-02-11 18:49:59 +00:00
|
|
|
static inline GrResourceCache* get_resource_cache(GrGpu* gpu) {
|
2014-09-05 20:34:00 +00:00
|
|
|
SkASSERT(gpu);
|
|
|
|
SkASSERT(gpu->getContext());
|
2018-01-16 20:07:54 +00:00
|
|
|
SkASSERT(gpu->getContext()->contextPriv().getResourceCache());
|
|
|
|
return gpu->getContext()->contextPriv().getResourceCache();
|
2014-08-21 20:02:13 +00:00
|
|
|
}
|
|
|
|
|
Refactor to separate backend object lifecycle and GpuResource budget decision
Refactor GrGpuResource to contain two different pieces of state:
a) instance is budgeted or not budgeted
b) instance references wrapped backend objects or not
The "object lifecycle" was also attached to backend object
handles (ids), which made the code a bit unclear. Backend objects
would be associated with GrGpuResource::LifeCycle, even though
GrGpuResource::LifeCycle refers to the GpuResource, and individual
backend objects in one GpuResource might be governed with different
"lifecycle".
Mark the budgeted/not budgeted with SkBudgeted::kYes, SkBudgeted::kNo.
This was previously GrGpuResource::kCached_LifeCycle,
GrGpuResource::kUncached_LifeCycle.
Mark the "references wrapped object" with boolean. This was previously
GrGpuResource::kBorrowed_LifeCycle,
GrGpuResource::kAdopted_LifeCycle for GrGpuResource.
Associate the backend object ownership status with
GrBackendObjectOwnership for the backend object handles.
The resource type leaf constuctors, such has GrGLTexture or
GrGLTextureRenderTarget take "budgeted" parameter. This parameter
is passed to GrGpuResource::registerWithCache().
The resource type intermediary constructors, such as GrGLTexture
constructors for class GrGLTextureRenderTarget do not take "budgeted"
parameters, intermediary construtors do not call registerWithCache.
Removes the need for tagging GrGpuResource -derived subclass
constructors with "Derived" parameter.
Makes instances that wrap backend objects be registered with
a new function GrGpuResource::registerWithCacheWrapped().
Removes "budgeted" parameter from classes such as StencilAttahment, as
they are always cached and never wrap any external backend objects.
Removes the use of concept "external" from the member function names.
The API refers to the objects as "wrapped", so make all related
functions use the term consistently.
No change in functionality. Resources referencing wrapped objects are
always inserted to the cache with budget decision kNo.
BUG=594928
GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1862043002
Review URL: https://codereview.chromium.org/1862043002
2016-04-22 08:48:29 +00:00
|
|
|
GrGpuResource::GrGpuResource(GrGpu* gpu)
|
2016-09-22 19:42:11 +00:00
|
|
|
: fExternalFlushCntWhenBecamePurgeable(0)
|
|
|
|
, fGpu(gpu)
|
2014-11-12 19:13:39 +00:00
|
|
|
, fGpuMemorySize(kInvalidGpuMemorySize)
|
Refactor to separate backend object lifecycle and GpuResource budget decision
Refactor GrGpuResource to contain two different pieces of state:
a) instance is budgeted or not budgeted
b) instance references wrapped backend objects or not
The "object lifecycle" was also attached to backend object
handles (ids), which made the code a bit unclear. Backend objects
would be associated with GrGpuResource::LifeCycle, even though
GrGpuResource::LifeCycle refers to the GpuResource, and individual
backend objects in one GpuResource might be governed with different
"lifecycle".
Mark the budgeted/not budgeted with SkBudgeted::kYes, SkBudgeted::kNo.
This was previously GrGpuResource::kCached_LifeCycle,
GrGpuResource::kUncached_LifeCycle.
Mark the "references wrapped object" with boolean. This was previously
GrGpuResource::kBorrowed_LifeCycle,
GrGpuResource::kAdopted_LifeCycle for GrGpuResource.
Associate the backend object ownership status with
GrBackendObjectOwnership for the backend object handles.
The resource type leaf constuctors, such has GrGLTexture or
GrGLTextureRenderTarget take "budgeted" parameter. This parameter
is passed to GrGpuResource::registerWithCache().
The resource type intermediary constructors, such as GrGLTexture
constructors for class GrGLTextureRenderTarget do not take "budgeted"
parameters, intermediary construtors do not call registerWithCache.
Removes the need for tagging GrGpuResource -derived subclass
constructors with "Derived" parameter.
Makes instances that wrap backend objects be registered with
a new function GrGpuResource::registerWithCacheWrapped().
Removes "budgeted" parameter from classes such as StencilAttahment, as
they are always cached and never wrap any external backend objects.
Removes the use of concept "external" from the member function names.
The API refers to the objects as "wrapped", so make all related
functions use the term consistently.
No change in functionality. Resources referencing wrapped objects are
always inserted to the cache with budget decision kNo.
BUG=594928
GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1862043002
Review URL: https://codereview.chromium.org/1862043002
2016-04-22 08:48:29 +00:00
|
|
|
, fBudgeted(SkBudgeted::kNo)
|
|
|
|
, fRefsWrappedObjects(false)
|
2014-11-17 17:33:27 +00:00
|
|
|
, fUniqueID(CreateUniqueID()) {
|
2015-02-17 19:47:40 +00:00
|
|
|
SkDEBUGCODE(fCacheArrayIndex = -1);
|
2014-08-26 21:01:07 +00:00
|
|
|
}
|
|
|
|
|
Refactor to separate backend object lifecycle and GpuResource budget decision
Refactor GrGpuResource to contain two different pieces of state:
a) instance is budgeted or not budgeted
b) instance references wrapped backend objects or not
The "object lifecycle" was also attached to backend object
handles (ids), which made the code a bit unclear. Backend objects
would be associated with GrGpuResource::LifeCycle, even though
GrGpuResource::LifeCycle refers to the GpuResource, and individual
backend objects in one GpuResource might be governed with different
"lifecycle".
Mark the budgeted/not budgeted with SkBudgeted::kYes, SkBudgeted::kNo.
This was previously GrGpuResource::kCached_LifeCycle,
GrGpuResource::kUncached_LifeCycle.
Mark the "references wrapped object" with boolean. This was previously
GrGpuResource::kBorrowed_LifeCycle,
GrGpuResource::kAdopted_LifeCycle for GrGpuResource.
Associate the backend object ownership status with
GrBackendObjectOwnership for the backend object handles.
The resource type leaf constuctors, such has GrGLTexture or
GrGLTextureRenderTarget take "budgeted" parameter. This parameter
is passed to GrGpuResource::registerWithCache().
The resource type intermediary constructors, such as GrGLTexture
constructors for class GrGLTextureRenderTarget do not take "budgeted"
parameters, intermediary construtors do not call registerWithCache.
Removes the need for tagging GrGpuResource -derived subclass
constructors with "Derived" parameter.
Makes instances that wrap backend objects be registered with
a new function GrGpuResource::registerWithCacheWrapped().
Removes "budgeted" parameter from classes such as StencilAttahment, as
they are always cached and never wrap any external backend objects.
Removes the use of concept "external" from the member function names.
The API refers to the objects as "wrapped", so make all related
functions use the term consistently.
No change in functionality. Resources referencing wrapped objects are
always inserted to the cache with budget decision kNo.
BUG=594928
GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1862043002
Review URL: https://codereview.chromium.org/1862043002
2016-04-22 08:48:29 +00:00
|
|
|
void GrGpuResource::registerWithCache(SkBudgeted budgeted) {
|
|
|
|
SkASSERT(fBudgeted == SkBudgeted::kNo);
|
|
|
|
fBudgeted = budgeted;
|
|
|
|
this->computeScratchKey(&fScratchKey);
|
|
|
|
get_resource_cache(fGpu)->resourceAccess().insertResource(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GrGpuResource::registerWithCacheWrapped() {
|
|
|
|
SkASSERT(fBudgeted == SkBudgeted::kNo);
|
|
|
|
// Currently resources referencing wrapped objects are not budgeted.
|
|
|
|
fRefsWrappedObjects = true;
|
2015-02-11 18:49:59 +00:00
|
|
|
get_resource_cache(fGpu)->resourceAccess().insertResource(this);
|
2011-03-30 21:26:44 +00:00
|
|
|
}
|
|
|
|
|
2014-07-25 15:35:45 +00:00
|
|
|
GrGpuResource::~GrGpuResource() {
|
2014-11-14 21:33:09 +00:00
|
|
|
// The cache should have released or destroyed this resource.
|
2014-05-02 21:38:22 +00:00
|
|
|
SkASSERT(this->wasDestroyed());
|
2012-04-27 17:24:09 +00:00
|
|
|
}
|
|
|
|
|
2016-03-29 16:03:52 +00:00
|
|
|
void GrGpuResource::release() {
|
2014-11-14 21:33:09 +00:00
|
|
|
SkASSERT(fGpu);
|
|
|
|
this->onRelease();
|
2015-02-11 18:49:59 +00:00
|
|
|
get_resource_cache(fGpu)->resourceAccess().removeResource(this);
|
2015-08-27 14:41:13 +00:00
|
|
|
fGpu = nullptr;
|
2014-11-14 21:33:09 +00:00
|
|
|
fGpuMemorySize = 0;
|
2011-03-30 21:26:44 +00:00
|
|
|
}
|
|
|
|
|
2014-07-25 15:35:45 +00:00
|
|
|
void GrGpuResource::abandon() {
|
2015-09-24 14:07:40 +00:00
|
|
|
if (this->wasDestroyed()) {
|
|
|
|
return;
|
|
|
|
}
|
2014-11-14 21:33:09 +00:00
|
|
|
SkASSERT(fGpu);
|
|
|
|
this->onAbandon();
|
2015-02-11 18:49:59 +00:00
|
|
|
get_resource_cache(fGpu)->resourceAccess().removeResource(this);
|
2015-08-27 14:41:13 +00:00
|
|
|
fGpu = nullptr;
|
2014-11-14 21:33:09 +00:00
|
|
|
fGpuMemorySize = 0;
|
2011-03-30 21:26:44 +00:00
|
|
|
}
|
2011-11-15 19:42:07 +00:00
|
|
|
|
2015-09-15 21:16:10 +00:00
|
|
|
void GrGpuResource::dumpMemoryStatistics(SkTraceMemoryDump* traceMemoryDump) const {
|
|
|
|
// Dump resource as "skia/gpu_resources/resource_#".
|
|
|
|
SkString dumpName("skia/gpu_resources/resource_");
|
2016-11-11 17:38:40 +00:00
|
|
|
dumpName.appendU32(this->uniqueID().asUInt());
|
2015-09-15 21:16:10 +00:00
|
|
|
|
|
|
|
traceMemoryDump->dumpNumericValue(dumpName.c_str(), "size", "bytes", this->gpuMemorySize());
|
|
|
|
|
|
|
|
if (this->isPurgeable()) {
|
|
|
|
traceMemoryDump->dumpNumericValue(dumpName.c_str(), "purgeable_size", "bytes",
|
|
|
|
this->gpuMemorySize());
|
|
|
|
}
|
|
|
|
|
|
|
|
// Call setMemoryBacking to allow sub-classes with implementation specific backings (such as GL
|
|
|
|
// objects) to provide additional information.
|
|
|
|
this->setMemoryBacking(traceMemoryDump, dumpName);
|
|
|
|
}
|
|
|
|
|
2014-07-25 15:35:45 +00:00
|
|
|
const GrContext* GrGpuResource::getContext() const {
|
2014-09-05 20:34:00 +00:00
|
|
|
if (fGpu) {
|
2011-11-15 19:42:07 +00:00
|
|
|
return fGpu->getContext();
|
|
|
|
} else {
|
2015-08-27 14:41:13 +00:00
|
|
|
return nullptr;
|
2011-11-15 19:42:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-25 15:35:45 +00:00
|
|
|
GrContext* GrGpuResource::getContext() {
|
2014-09-05 20:34:00 +00:00
|
|
|
if (fGpu) {
|
2011-11-15 19:42:07 +00:00
|
|
|
return fGpu->getContext();
|
|
|
|
} else {
|
2015-08-27 14:41:13 +00:00
|
|
|
return nullptr;
|
2011-11-15 19:42:07 +00:00
|
|
|
}
|
|
|
|
}
|
2014-07-25 14:32:33 +00:00
|
|
|
|
2014-11-14 20:10:14 +00:00
|
|
|
void GrGpuResource::didChangeGpuMemorySize() const {
|
|
|
|
if (this->wasDestroyed()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t oldSize = fGpuMemorySize;
|
|
|
|
SkASSERT(kInvalidGpuMemorySize != oldSize);
|
|
|
|
fGpuMemorySize = kInvalidGpuMemorySize;
|
2015-02-11 18:49:59 +00:00
|
|
|
get_resource_cache(fGpu)->resourceAccess().didChangeGpuMemorySize(this, oldSize);
|
2014-11-14 20:10:14 +00:00
|
|
|
}
|
|
|
|
|
2015-02-19 15:24:21 +00:00
|
|
|
void GrGpuResource::removeUniqueKey() {
|
2015-09-24 14:07:40 +00:00
|
|
|
if (this->wasDestroyed()) {
|
|
|
|
return;
|
|
|
|
}
|
2015-02-19 15:24:21 +00:00
|
|
|
SkASSERT(fUniqueKey.isValid());
|
2015-02-19 16:24:16 +00:00
|
|
|
get_resource_cache(fGpu)->resourceAccess().removeUniqueKey(this);
|
2015-02-06 19:54:28 +00:00
|
|
|
}
|
|
|
|
|
2015-02-19 16:24:16 +00:00
|
|
|
void GrGpuResource::setUniqueKey(const GrUniqueKey& key) {
|
2014-11-11 15:27:16 +00:00
|
|
|
SkASSERT(this->internalHasRef());
|
2015-02-06 19:54:28 +00:00
|
|
|
SkASSERT(key.isValid());
|
2014-11-17 15:34:06 +00:00
|
|
|
|
2017-05-08 15:16:39 +00:00
|
|
|
// Uncached resources can never have a unique key, unless they're wrapped resources. Wrapped
|
|
|
|
// resources are a special case: the unique keys give us a weak ref so that we can reuse the
|
|
|
|
// same resource (rather than re-wrapping). When a wrapped resource is no longer referenced,
|
|
|
|
// it will always be released - it is never converted to a scratch resource.
|
|
|
|
if (SkBudgeted::kNo == this->resourcePriv().isBudgeted() && !this->fRefsWrappedObjects) {
|
2015-02-19 16:24:16 +00:00
|
|
|
return;
|
2014-11-17 15:34:06 +00:00
|
|
|
}
|
2014-11-17 17:33:27 +00:00
|
|
|
|
2015-02-19 16:24:16 +00:00
|
|
|
if (this->wasDestroyed()) {
|
|
|
|
return;
|
2014-11-10 18:19:06 +00:00
|
|
|
}
|
|
|
|
|
2015-02-19 16:24:16 +00:00
|
|
|
get_resource_cache(fGpu)->resourceAccess().changeUniqueKey(this, key);
|
2014-11-10 18:19:06 +00:00
|
|
|
}
|
|
|
|
|
2015-04-08 18:01:54 +00:00
|
|
|
void GrGpuResource::notifyAllCntsAreZero(CntType lastCntTypeToReachZero) const {
|
2014-11-14 21:33:09 +00:00
|
|
|
if (this->wasDestroyed()) {
|
|
|
|
// We've already been removed from the cache. Goodbye cruel world!
|
2015-08-26 20:07:48 +00:00
|
|
|
delete this;
|
2015-04-08 18:01:54 +00:00
|
|
|
return;
|
2014-10-08 15:40:09 +00:00
|
|
|
}
|
2015-04-08 18:01:54 +00:00
|
|
|
|
|
|
|
// We should have already handled this fully in notifyRefCntIsZero().
|
|
|
|
SkASSERT(kRef_CntType != lastCntTypeToReachZero);
|
|
|
|
|
|
|
|
GrGpuResource* mutableThis = const_cast<GrGpuResource*>(this);
|
|
|
|
static const uint32_t kFlag =
|
|
|
|
GrResourceCache::ResourceAccess::kAllCntsReachedZero_RefNotificationFlag;
|
|
|
|
get_resource_cache(fGpu)->resourceAccess().notifyCntReachedZero(mutableThis, kFlag);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool GrGpuResource::notifyRefCountIsZero() const {
|
|
|
|
if (this->wasDestroyed()) {
|
|
|
|
// handle this in notifyAllCntsAreZero().
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
GrGpuResource* mutableThis = const_cast<GrGpuResource*>(this);
|
2017-05-11 18:14:30 +00:00
|
|
|
uint32_t flags = GrResourceCache::ResourceAccess::kRefCntReachedZero_RefNotificationFlag;
|
2015-04-08 18:01:54 +00:00
|
|
|
if (!this->internalHasPendingIO()) {
|
|
|
|
flags |= GrResourceCache::ResourceAccess::kAllCntsReachedZero_RefNotificationFlag;
|
|
|
|
}
|
|
|
|
get_resource_cache(fGpu)->resourceAccess().notifyCntReachedZero(mutableThis, flags);
|
|
|
|
|
|
|
|
// There is no need to call our notifyAllCntsAreZero function at this point since we already
|
|
|
|
// told the cache about the state of cnts.
|
|
|
|
return false;
|
2014-10-08 15:40:09 +00:00
|
|
|
}
|
|
|
|
|
2014-11-25 13:52:06 +00:00
|
|
|
void GrGpuResource::removeScratchKey() {
|
2014-12-30 20:50:52 +00:00
|
|
|
if (!this->wasDestroyed() && fScratchKey.isValid()) {
|
2015-02-11 18:49:59 +00:00
|
|
|
get_resource_cache(fGpu)->resourceAccess().willRemoveScratchKey(this);
|
2014-12-30 20:50:52 +00:00
|
|
|
fScratchKey.reset();
|
2014-11-25 13:52:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-16 15:32:33 +00:00
|
|
|
void GrGpuResource::makeBudgeted() {
|
Refactor to separate backend object lifecycle and GpuResource budget decision
Refactor GrGpuResource to contain two different pieces of state:
a) instance is budgeted or not budgeted
b) instance references wrapped backend objects or not
The "object lifecycle" was also attached to backend object
handles (ids), which made the code a bit unclear. Backend objects
would be associated with GrGpuResource::LifeCycle, even though
GrGpuResource::LifeCycle refers to the GpuResource, and individual
backend objects in one GpuResource might be governed with different
"lifecycle".
Mark the budgeted/not budgeted with SkBudgeted::kYes, SkBudgeted::kNo.
This was previously GrGpuResource::kCached_LifeCycle,
GrGpuResource::kUncached_LifeCycle.
Mark the "references wrapped object" with boolean. This was previously
GrGpuResource::kBorrowed_LifeCycle,
GrGpuResource::kAdopted_LifeCycle for GrGpuResource.
Associate the backend object ownership status with
GrBackendObjectOwnership for the backend object handles.
The resource type leaf constuctors, such has GrGLTexture or
GrGLTextureRenderTarget take "budgeted" parameter. This parameter
is passed to GrGpuResource::registerWithCache().
The resource type intermediary constructors, such as GrGLTexture
constructors for class GrGLTextureRenderTarget do not take "budgeted"
parameters, intermediary construtors do not call registerWithCache.
Removes the need for tagging GrGpuResource -derived subclass
constructors with "Derived" parameter.
Makes instances that wrap backend objects be registered with
a new function GrGpuResource::registerWithCacheWrapped().
Removes "budgeted" parameter from classes such as StencilAttahment, as
they are always cached and never wrap any external backend objects.
Removes the use of concept "external" from the member function names.
The API refers to the objects as "wrapped", so make all related
functions use the term consistently.
No change in functionality. Resources referencing wrapped objects are
always inserted to the cache with budget decision kNo.
BUG=594928
GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1862043002
Review URL: https://codereview.chromium.org/1862043002
2016-04-22 08:48:29 +00:00
|
|
|
if (!this->wasDestroyed() && SkBudgeted::kNo == fBudgeted) {
|
|
|
|
// Currently resources referencing wrapped objects are not budgeted.
|
|
|
|
SkASSERT(!fRefsWrappedObjects);
|
|
|
|
fBudgeted = SkBudgeted::kYes;
|
2015-02-11 18:49:59 +00:00
|
|
|
get_resource_cache(fGpu)->resourceAccess().didChangeBudgetStatus(this);
|
2015-01-16 15:32:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-23 15:19:22 +00:00
|
|
|
void GrGpuResource::makeUnbudgeted() {
|
Refactor to separate backend object lifecycle and GpuResource budget decision
Refactor GrGpuResource to contain two different pieces of state:
a) instance is budgeted or not budgeted
b) instance references wrapped backend objects or not
The "object lifecycle" was also attached to backend object
handles (ids), which made the code a bit unclear. Backend objects
would be associated with GrGpuResource::LifeCycle, even though
GrGpuResource::LifeCycle refers to the GpuResource, and individual
backend objects in one GpuResource might be governed with different
"lifecycle".
Mark the budgeted/not budgeted with SkBudgeted::kYes, SkBudgeted::kNo.
This was previously GrGpuResource::kCached_LifeCycle,
GrGpuResource::kUncached_LifeCycle.
Mark the "references wrapped object" with boolean. This was previously
GrGpuResource::kBorrowed_LifeCycle,
GrGpuResource::kAdopted_LifeCycle for GrGpuResource.
Associate the backend object ownership status with
GrBackendObjectOwnership for the backend object handles.
The resource type leaf constuctors, such has GrGLTexture or
GrGLTextureRenderTarget take "budgeted" parameter. This parameter
is passed to GrGpuResource::registerWithCache().
The resource type intermediary constructors, such as GrGLTexture
constructors for class GrGLTextureRenderTarget do not take "budgeted"
parameters, intermediary construtors do not call registerWithCache.
Removes the need for tagging GrGpuResource -derived subclass
constructors with "Derived" parameter.
Makes instances that wrap backend objects be registered with
a new function GrGpuResource::registerWithCacheWrapped().
Removes "budgeted" parameter from classes such as StencilAttahment, as
they are always cached and never wrap any external backend objects.
Removes the use of concept "external" from the member function names.
The API refers to the objects as "wrapped", so make all related
functions use the term consistently.
No change in functionality. Resources referencing wrapped objects are
always inserted to the cache with budget decision kNo.
BUG=594928
GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1862043002
Review URL: https://codereview.chromium.org/1862043002
2016-04-22 08:48:29 +00:00
|
|
|
if (!this->wasDestroyed() && SkBudgeted::kYes == fBudgeted &&
|
2015-09-24 14:07:40 +00:00
|
|
|
!fUniqueKey.isValid()) {
|
Refactor to separate backend object lifecycle and GpuResource budget decision
Refactor GrGpuResource to contain two different pieces of state:
a) instance is budgeted or not budgeted
b) instance references wrapped backend objects or not
The "object lifecycle" was also attached to backend object
handles (ids), which made the code a bit unclear. Backend objects
would be associated with GrGpuResource::LifeCycle, even though
GrGpuResource::LifeCycle refers to the GpuResource, and individual
backend objects in one GpuResource might be governed with different
"lifecycle".
Mark the budgeted/not budgeted with SkBudgeted::kYes, SkBudgeted::kNo.
This was previously GrGpuResource::kCached_LifeCycle,
GrGpuResource::kUncached_LifeCycle.
Mark the "references wrapped object" with boolean. This was previously
GrGpuResource::kBorrowed_LifeCycle,
GrGpuResource::kAdopted_LifeCycle for GrGpuResource.
Associate the backend object ownership status with
GrBackendObjectOwnership for the backend object handles.
The resource type leaf constuctors, such has GrGLTexture or
GrGLTextureRenderTarget take "budgeted" parameter. This parameter
is passed to GrGpuResource::registerWithCache().
The resource type intermediary constructors, such as GrGLTexture
constructors for class GrGLTextureRenderTarget do not take "budgeted"
parameters, intermediary construtors do not call registerWithCache.
Removes the need for tagging GrGpuResource -derived subclass
constructors with "Derived" parameter.
Makes instances that wrap backend objects be registered with
a new function GrGpuResource::registerWithCacheWrapped().
Removes "budgeted" parameter from classes such as StencilAttahment, as
they are always cached and never wrap any external backend objects.
Removes the use of concept "external" from the member function names.
The API refers to the objects as "wrapped", so make all related
functions use the term consistently.
No change in functionality. Resources referencing wrapped objects are
always inserted to the cache with budget decision kNo.
BUG=594928
GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1862043002
Review URL: https://codereview.chromium.org/1862043002
2016-04-22 08:48:29 +00:00
|
|
|
fBudgeted = SkBudgeted::kNo;
|
2015-02-11 18:49:59 +00:00
|
|
|
get_resource_cache(fGpu)->resourceAccess().didChangeBudgetStatus(this);
|
2015-01-23 15:19:22 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-25 15:35:45 +00:00
|
|
|
uint32_t GrGpuResource::CreateUniqueID() {
|
2014-07-25 14:32:33 +00:00
|
|
|
static int32_t gUniqueID = SK_InvalidUniqueID;
|
|
|
|
uint32_t id;
|
|
|
|
do {
|
|
|
|
id = static_cast<uint32_t>(sk_atomic_inc(&gUniqueID) + 1);
|
|
|
|
} while (id == SK_InvalidUniqueID);
|
|
|
|
return id;
|
|
|
|
}
|