Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(208)

Unified Diff: gpu/command_buffer/service/program_cache_lru_helper.cc

Issue 10797055: gpu in-memory program cache implementation with a memory limit + lru eviction. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: simplified binary loading logic Created 8 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: gpu/command_buffer/service/program_cache_lru_helper.cc
diff --git a/gpu/command_buffer/service/program_cache_lru_helper.cc b/gpu/command_buffer/service/program_cache_lru_helper.cc
new file mode 100644
index 0000000000000000000000000000000000000000..a1f455524a40266420095ccbb6459c92a5231198
--- /dev/null
+++ b/gpu/command_buffer/service/program_cache_lru_helper.cc
@@ -0,0 +1,49 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "gpu/command_buffer/service/program_cache_lru_helper.h"
+
+namespace gpu {
+namespace gles2 {
+
+ProgramCacheLruHelper::ProgramCacheLruHelper() {}
+ProgramCacheLruHelper::~ProgramCacheLruHelper() {}
+
+void ProgramCacheLruHelper::Clear() {
+ location_map.clear();
+ queue.clear();
+}
+
+bool ProgramCacheLruHelper::IsEmpty() {
+ return queue.empty();
+}
+
+void ProgramCacheLruHelper::KeyUsed(const std::string& key) {
+ IteratorMap::iterator location_iterator = location_map.find(key);
+ if (location_iterator != location_map.end()) {
+ // already exists, erase it
+ queue.erase(location_iterator->second);
+ }
+ queue.push_front(key);
+ location_map[key] = queue.begin();
+}
+
+const std::string* ProgramCacheLruHelper::PeekKey() {
+ if (queue.empty()) {
+ return NULL;
+ }
+ return &queue.back();
+}
+
+void ProgramCacheLruHelper::PopKey() {
+ if (queue.empty()) {
+ return;
+ }
+ const std::string& last = queue.back();
+ location_map.erase(last);
+ queue.pop_back();
+}
+
+} // namespace gpu
+} // namespace gles2

Powered by Google App Engine
This is Rietveld 408576698