summaryrefslogtreecommitdiffstats
path: root/components/html_viewer/discardable_memory_allocator.h
diff options
context:
space:
mode:
Diffstat (limited to 'components/html_viewer/discardable_memory_allocator.h')
-rw-r--r--components/html_viewer/discardable_memory_allocator.h61
1 files changed, 61 insertions, 0 deletions
diff --git a/components/html_viewer/discardable_memory_allocator.h b/components/html_viewer/discardable_memory_allocator.h
new file mode 100644
index 0000000..be7f063
--- /dev/null
+++ b/components/html_viewer/discardable_memory_allocator.h
@@ -0,0 +1,61 @@
+// Copyright 2015 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.
+
+#ifndef COMPONENTS_HTML_VIEWER_DISCARDABLE_MEMORY_ALLOCATOR_H_
+#define COMPONENTS_HTML_VIEWER_DISCARDABLE_MEMORY_ALLOCATOR_H_
+
+#include <list>
+
+#include "base/memory/discardable_memory_allocator.h"
+
+namespace html_viewer {
+
+// A discarable memory allocator which will unallocate chunks on new
+// allocations.
+class DiscardableMemoryAllocator : public base::DiscardableMemoryAllocator {
+ public:
+ class OwnedMemoryChunk;
+
+ explicit DiscardableMemoryAllocator(size_t desired_max_memory);
+ ~DiscardableMemoryAllocator() override;
+
+ // Overridden from DiscardableMemoryAllocator:
+ scoped_ptr<base::DiscardableMemory> AllocateLockedDiscardableMemory(
+ size_t size) override;
+
+ private:
+ friend class OwnedMemoryChunk;
+
+ // Called by OwnedMemoryChunks when they are unlocked. This puts them at the
+ // end of the live_unlocked_chunks_ list and passes an iterator to their
+ // position in the unlocked chunk list.
+ std::list<OwnedMemoryChunk*>::iterator NotifyUnlocked(
+ OwnedMemoryChunk* chunk);
+
+ // Called by OwnedMemoryChunks when they are locked. This removes the passed
+ // in unlocked chunk list.
+ void NotifyLocked(std::list<OwnedMemoryChunk*>::iterator it);
+
+ // The amount of memory we can allocate before we try to free unlocked
+ // chunks. We can go over this amount if all callers keep their discardable
+ // chunks locked.
+ const size_t desired_max_memory_;
+
+ // A count of the sum of memory. Used to trigger discarding the oldest
+ // memory.
+ size_t total_live_memory_;
+
+ // The number of locked chunks.
+ int locked_chunks_;
+
+ // A linked list of unlocked allocated chunks so that the tail is most
+ // recently accessed chunks.
+ std::list<OwnedMemoryChunk*> live_unlocked_chunks_;
+
+ DISALLOW_COPY_AND_ASSIGN(DiscardableMemoryAllocator);
+};
+
+} // namespace html_viewer
+
+#endif // COMPONENTS_HTML_VIEWER_DISCARDABLE_MEMORY_ALLOCATOR_H_