blob: 3248c7af1460cfe63e21206c053ee50f58f97de1 [file] [log] [blame]
bsalomon453cf402014-11-11 14:15:57 -08001/*
2 * Copyright 2014 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#ifndef GrGpuResourceCacheAccess_DEFINED
9#define GrGpuResourceCacheAccess_DEFINED
10
11#include "GrGpuResource.h"
bsalomon3582d3e2015-02-13 14:20:05 -080012#include "GrGpuResourcePriv.h"
13
14namespace skiatest {
15 class Reporter;
16}
bsalomon453cf402014-11-11 14:15:57 -080017
18/**
bsalomon3582d3e2015-02-13 14:20:05 -080019 * This class allows GrResourceCache increased privileged access to GrGpuResource objects.
bsalomon453cf402014-11-11 14:15:57 -080020 */
21class GrGpuResource::CacheAccess {
bsalomon3582d3e2015-02-13 14:20:05 -080022private:
bsalomon453cf402014-11-11 14:15:57 -080023 /**
bsalomonc2f35b72015-01-23 07:19:22 -080024 * Is the resource currently cached as scratch? This means it is cached, has a valid scratch
bsalomon8718aaf2015-02-19 07:24:21 -080025 * key, and does not have a unique key.
bsalomon453cf402014-11-11 14:15:57 -080026 */
27 bool isScratch() const {
bsalomon8718aaf2015-02-19 07:24:21 -080028 return !fResource->getUniqueKey().isValid() && fResource->fScratchKey.isValid() &&
bsalomon5ec26ae2016-02-25 08:33:02 -080029 SkBudgeted::kYes == fResource->resourcePriv().isBudgeted();
bsalomon453cf402014-11-11 14:15:57 -080030 }
31
bsalomon10e23ca2014-11-25 05:52:06 -080032 /**
bsalomon12299ab2014-11-14 13:33:09 -080033 * Called by the cache to delete the resource under normal circumstances.
34 */
35 void release() {
36 fResource->release();
halcanary385fe4d2015-08-26 13:07:48 -070037 if (fResource->isPurgeable()) {
38 delete fResource;
bsalomon12299ab2014-11-14 13:33:09 -080039 }
40 }
41
42 /**
43 * Called by the cache to delete the resource when the backend 3D context is no longer valid.
44 */
45 void abandon() {
46 fResource->abandon();
halcanary385fe4d2015-08-26 13:07:48 -070047 if (fResource->isPurgeable()) {
48 delete fResource;
bsalomon12299ab2014-11-14 13:33:09 -080049 }
50 }
51
bsalomonf99e9612015-02-19 08:24:16 -080052 /** Called by the cache to assign a new unique key. */
53 void setUniqueKey(const GrUniqueKey& key) { fResource->fUniqueKey = key; }
54
55 /** Called by the cache to make the unique key invalid. */
56 void removeUniqueKey() { fResource->fUniqueKey.reset(); }
57
bsalomon9f2d1572015-02-17 11:47:40 -080058 uint32_t timestamp() const { return fResource->fTimestamp; }
59 void setTimestamp(uint32_t ts) { fResource->fTimestamp = ts; }
60
Brian Salomon5e150852017-03-22 14:53:13 -040061 void setTimeWhenResourceBecomePurgeable() {
62 SkASSERT(fResource->isPurgeable());
63 fResource->fTimeWhenBecamePurgeable = GrStdSteadyClock::now();
64 }
bsalomone2e87f32016-09-22 12:42:11 -070065 /**
Brian Salomon5e150852017-03-22 14:53:13 -040066 * Called by the cache to determine whether this resource should be purged based on the length
67 * of time it has been available for purging.
68 */
69 GrStdSteadyClock::time_point timeWhenResourceBecamePurgeable() {
70 SkASSERT(fResource->isPurgeable());
71 return fResource->fTimeWhenBecamePurgeable;
72 }
bsalomone2e87f32016-09-22 12:42:11 -070073
bsalomon9f2d1572015-02-17 11:47:40 -080074 int* accessCacheIndex() const { return &fResource->fCacheArrayIndex; }
75
bsalomon3582d3e2015-02-13 14:20:05 -080076 CacheAccess(GrGpuResource* resource) : fResource(resource) {}
77 CacheAccess(const CacheAccess& that) : fResource(that.fResource) {}
bsalomon453cf402014-11-11 14:15:57 -080078 CacheAccess& operator=(const CacheAccess&); // unimpl
79
80 // No taking addresses of this type.
81 const CacheAccess* operator&() const;
82 CacheAccess* operator&();
83
84 GrGpuResource* fResource;
85
86 friend class GrGpuResource; // to construct/copy this type.
bsalomon3582d3e2015-02-13 14:20:05 -080087 friend class GrResourceCache; // to use this type
88 friend void test_unbudgeted_to_scratch(skiatest::Reporter* reporter); // for unit testing
bsalomon453cf402014-11-11 14:15:57 -080089};
90
91inline GrGpuResource::CacheAccess GrGpuResource::cacheAccess() { return CacheAccess(this); }
92
93inline const GrGpuResource::CacheAccess GrGpuResource::cacheAccess() const {
94 return CacheAccess(const_cast<GrGpuResource*>(this));
95}
96
97#endif