aboutsummaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/core/SkGlyphCache.cpp77
-rw-r--r--src/core/SkGlyphCache.h12
-rw-r--r--src/core/SkGraphics.cpp39
3 files changed, 59 insertions, 69 deletions
diff --git a/src/core/SkGlyphCache.cpp b/src/core/SkGlyphCache.cpp
index f6fa3a00ce..b020f04411 100644
--- a/src/core/SkGlyphCache.cpp
+++ b/src/core/SkGlyphCache.cpp
@@ -387,6 +387,10 @@ void SkGlyphCache::invokeAndRemoveAuxProcs() {
///////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////
+#ifndef SK_DEFAULT_FONT_CACHE_LIMIT
+ #define SK_DEFAULT_FONT_CACHE_LIMIT (2 * 1024 * 1024)
+#endif
+
#ifdef USE_CACHE_HASH
#define HASH_BITCOUNT 6
#define HASH_COUNT (1 << HASH_BITCOUNT)
@@ -413,6 +417,8 @@ public:
SkGlyphCache_Globals() {
fHead = NULL;
fTotalMemoryUsed = 0;
+ fFontCacheLimit = SK_DEFAULT_FONT_CACHE_LIMIT;
+
#ifdef USE_CACHE_HASH
sk_bzero(fHash, sizeof(fHash));
#endif
@@ -430,14 +436,45 @@ public:
#else
void validate() const {}
#endif
+
+ size_t getFontCacheLimit() const { return fFontCacheLimit; }
+ size_t setFontCacheLimit(size_t limit);
+
+private:
+ size_t fFontCacheLimit;
};
-static SkGlyphCache_Globals& getGlobals() {
+size_t SkGlyphCache_Globals::setFontCacheLimit(size_t newLimit) {
+ static const size_t minLimit = 256 * 1024;
+ if (newLimit < minLimit) {
+ newLimit = minLimit;
+ }
+
+ size_t prevLimit = fFontCacheLimit;
+ fFontCacheLimit = newLimit;
+
+ size_t currUsed = fTotalMemoryUsed;
+ if (currUsed > newLimit) {
+ fMutex.acquire();
+ SkGlyphCache::InternalFreeCache(this, currUsed - newLimit);
+ fMutex.release();
+ }
+ return prevLimit;
+}
+
+// Returns the shared globals
+static SkGlyphCache_Globals& getSharedGlobals() {
// we leak this, so we don't incur any shutdown cost of the destructor
static SkGlyphCache_Globals* gGlobals = new SkGlyphCache_Globals;
return *gGlobals;
}
+// Returns the TLS globals (if set), or the shared globals
+static SkGlyphCache_Globals& getGlobals() {
+ // TODO: Check TLS for local globals...
+ return getSharedGlobals();
+}
+
void SkGlyphCache::VisitAllCaches(bool (*proc)(SkGlyphCache*, void*),
void* context) {
SkGlyphCache_Globals& globals = getGlobals();
@@ -555,22 +592,6 @@ void SkGlyphCache::AttachCache(SkGlyphCache* cache) {
globals.validate();
}
-size_t SkGlyphCache::GetCacheUsed() {
- return getGlobals().fTotalMemoryUsed;
-}
-
-bool SkGlyphCache::SetCacheUsed(size_t bytesUsed) {
- size_t curr = SkGlyphCache::GetCacheUsed();
-
- if (curr > bytesUsed) {
- SkGlyphCache_Globals& globals = getGlobals();
- SkAutoMutexAcquire ac(globals.fMutex);
-
- return InternalFreeCache(&globals, curr - bytesUsed) > 0;
- }
- return false;
-}
-
///////////////////////////////////////////////////////////////////////////////
SkGlyphCache* SkGlyphCache::FindTail(SkGlyphCache* cache) {
@@ -644,8 +665,8 @@ size_t SkGlyphCache::InternalFreeCache(SkGlyphCache_Globals* globals,
}
///////////////////////////////////////////////////////////////////////////////
-#ifdef SK_DEBUG
+#ifdef SK_DEBUG
void SkGlyphCache::validate() const {
int count = fGlyphArray.count();
for (int i = 0; i < count; i++) {
@@ -657,5 +678,23 @@ void SkGlyphCache::validate() const {
}
}
}
-
#endif
+
+///////////////////////////////////////////////////////////////////////////////
+///////////////////////////////////////////////////////////////////////////////
+
+#include "SkTypefaceCache.h"
+
+size_t SkGraphics::GetFontCacheLimit() {
+ return getSharedGlobals().getFontCacheLimit();
+}
+
+size_t SkGraphics::SetFontCacheLimit(size_t bytes) {
+ return getSharedGlobals().setFontCacheLimit(bytes);
+}
+
+void SkGraphics::PurgeFontCache() {
+ getSharedGlobals().setFontCacheLimit(0);
+ SkTypefaceCache::PurgeAll();
+}
+
diff --git a/src/core/SkGlyphCache.h b/src/core/SkGlyphCache.h
index e1ab63530c..dfd2df8a96 100644
--- a/src/core/SkGlyphCache.h
+++ b/src/core/SkGlyphCache.h
@@ -156,18 +156,6 @@ public:
return VisitCache(desc, DetachProc, NULL);
}
- /** Return the approximate number of bytes used by the font cache
- */
- static size_t GetCacheUsed();
-
- /** This can be called to purge old font data, in an attempt to free
- enough bytes such that the font cache is not using more than the
- specified number of bytes. It is thread-safe, and may be called at
- any time.
- Return true if some amount of the cache was purged.
- */
- static bool SetCacheUsed(size_t bytesUsed);
-
#ifdef SK_DEBUG
void validate() const;
#else
diff --git a/src/core/SkGraphics.cpp b/src/core/SkGraphics.cpp
index db1c9be311..5334c85016 100644
--- a/src/core/SkGraphics.cpp
+++ b/src/core/SkGraphics.cpp
@@ -120,47 +120,10 @@ void SkGraphics::Init() {
#endif
}
-///////////////////////////////////////////////////////////////////////////////
-
-#include "SkGlyphCache.h"
-#include "SkTypefaceCache.h"
-
void SkGraphics::Term() {
PurgeFontCache();
}
-#ifndef SK_DEFAULT_FONT_CACHE_LIMIT
- #define SK_DEFAULT_FONT_CACHE_LIMIT (2 * 1024 * 1024)
-#endif
-
-#define SK_MIN_FONT_CACHE_LIMIT (256 * 1024)
-
-static size_t gFontCacheLimit = SK_DEFAULT_FONT_CACHE_LIMIT;
-
-size_t SkGraphics::GetFontCacheLimit() {
- return gFontCacheLimit;
-}
-
-size_t SkGraphics::SetFontCacheLimit(size_t bytes) {
- size_t prev = gFontCacheLimit;
-
- if (bytes < SK_MIN_FONT_CACHE_LIMIT) {
- bytes = SK_MIN_FONT_CACHE_LIMIT;
- }
- gFontCacheLimit = bytes;
-
- // trigger a purge if the new size is smaller that our currently used amount
- if (bytes < SkGlyphCache::GetCacheUsed()) {
- SkGlyphCache::SetCacheUsed(bytes);
- }
- return prev;
-}
-
-void SkGraphics::PurgeFontCache() {
- SkGlyphCache::SetCacheUsed(0);
- SkTypefaceCache::PurgeAll();
-}
-
///////////////////////////////////////////////////////////////////////////////
static const char kFontCacheLimitStr[] = "font-cache-limit";
@@ -171,7 +134,7 @@ static const struct {
size_t fLen;
size_t (*fFunc)(size_t);
} gFlags[] = {
- {kFontCacheLimitStr, kFontCacheLimitLen, SkGraphics::SetFontCacheLimit}
+ { kFontCacheLimitStr, kFontCacheLimitLen, SkGraphics::SetFontCacheLimit }
};
/* flags are of the form param; or param=value; */