blob: 92ba48bcb492fb3f50bd50ea2143ad5016fbc676 [file] [log] [blame]
halcanary@google.com2c7c7ee2013-12-05 18:31:42 +00001/*
2 * Copyright 2013 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 SkDiscardableMemoryPool_DEFINED
9#define SkDiscardableMemoryPool_DEFINED
10
11#include "SkDiscardableMemory.h"
mtklein7b274c72015-02-03 13:38:58 -080012#include "SkMutex.h"
halcanary@google.com2c7c7ee2013-12-05 18:31:42 +000013
commit-bot@chromium.orgcf2f0082014-04-04 16:43:38 +000014#ifndef SK_LAZY_CACHE_STATS
15 #ifdef SK_DEBUG
16 #define SK_LAZY_CACHE_STATS 1
17 #else
18 #define SK_LAZY_CACHE_STATS 0
19 #endif
halcanary@google.com2c7c7ee2013-12-05 18:31:42 +000020#endif
21
22/**
commit-bot@chromium.orgcf2f0082014-04-04 16:43:38 +000023 * An implementation of Discardable Memory that manages a fixed-size
24 * budget of memory. When the allocated memory exceeds this size,
25 * unlocked blocks of memory are purged. If all memory is locked, it
26 * can exceed the memory-use budget.
halcanary@google.com2c7c7ee2013-12-05 18:31:42 +000027 */
halcanary@google.com2c7c7ee2013-12-05 18:31:42 +000028class SkDiscardableMemoryPool : public SkDiscardableMemory::Factory {
29public:
commit-bot@chromium.orgcf2f0082014-04-04 16:43:38 +000030 virtual ~SkDiscardableMemoryPool() { }
reed@google.com772443a2013-12-11 15:30:24 +000031
commit-bot@chromium.orgcf2f0082014-04-04 16:43:38 +000032 virtual size_t getRAMUsed() = 0;
33 virtual void setRAMBudget(size_t budget) = 0;
34 virtual size_t getRAMBudget() = 0;
reed@google.com772443a2013-12-11 15:30:24 +000035
halcanary@google.com2c7c7ee2013-12-05 18:31:42 +000036 /** purges all unlocked DMs */
commit-bot@chromium.orgcf2f0082014-04-04 16:43:38 +000037 virtual void dumpPool() = 0;
reed@google.com772443a2013-12-11 15:30:24 +000038
commit-bot@chromium.orgcf2f0082014-04-04 16:43:38 +000039 #if SK_LAZY_CACHE_STATS
40 /**
41 * These two values are a count of the number of successful and
42 * failed calls to SkDiscardableMemory::lock() for all DMs managed
43 * by this pool.
44 */
45 virtual int getCacheHits() = 0;
46 virtual int getCacheMisses() = 0;
47 virtual void resetCacheHitsAndMisses() = 0;
48 #endif
halcanary@google.com2c7c7ee2013-12-05 18:31:42 +000049
commit-bot@chromium.orgcf2f0082014-04-04 16:43:38 +000050 /**
51 * This non-global pool can be used for unit tests to verify that
52 * the pool works.
53 * Without mutex, will be not be thread safe.
54 */
sclittled9f5d202016-05-04 18:23:30 -070055 static SkDiscardableMemoryPool* Create(
56 size_t size, SkBaseMutex* mutex = nullptr);
halcanary@google.com2c7c7ee2013-12-05 18:31:42 +000057};
58
59/**
60 * Returns (and creates if needed) a threadsafe global
61 * SkDiscardableMemoryPool.
62 */
63SkDiscardableMemoryPool* SkGetGlobalDiscardableMemoryPool();
64
65#if !defined(SK_DEFAULT_GLOBAL_DISCARDABLE_MEMORY_POOL_SIZE)
halcanaryf91b47f2014-08-01 11:54:48 -070066#define SK_DEFAULT_GLOBAL_DISCARDABLE_MEMORY_POOL_SIZE (128 * 1024 * 1024)
halcanary@google.com2c7c7ee2013-12-05 18:31:42 +000067#endif
68
69#endif // SkDiscardableMemoryPool_DEFINED