blob: 4772bc8f78da4f90a52de93819e3822432c2b2fc [file] [log] [blame]
Chris Craik551fcf42012-12-05 10:36:45 -08001/*
2 * Copyright 2012, The Android Open Source Project
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
6 * are met:
7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 *
13 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */
25
26#ifndef ANDROID_LINEARALLOCATOR_H
27#define ANDROID_LINEARALLOCATOR_H
28
29#include <stddef.h>
30
31namespace android {
32
33/**
34 * A memory manager that internally allocates multi-kbyte buffers for placing objects in. It avoids
35 * the overhead of malloc when many objects are allocated. It is most useful when creating many
36 * small objects with a similar lifetime, and doesn't add significant overhead for large
37 * allocations.
38 */
39class LinearAllocator {
40public:
41 LinearAllocator();
42 ~LinearAllocator();
43
44 /**
45 * Reserves and returns a region of memory of at least size 'size', aligning as needed.
46 * Typically this is used in an object's overridden new() method or as a replacement for malloc.
47 *
48 * The lifetime of the returned buffers is tied to that of the LinearAllocator. If calling
49 * delete() on an object stored in a buffer is needed, it should be overridden to use
50 * rewindIfLastAlloc()
51 */
52 void* alloc(size_t size);
53
54 /**
55 * Attempt to deallocate the given buffer, with the LinearAllocator attempting to rewind its
56 * state if possible. No destructors are called.
57 */
58 void rewindIfLastAlloc(void* ptr, size_t allocSize);
59
60 /**
61 * Dump memory usage statistics to the log (allocated and wasted space)
62 */
63 void dumpMemoryStats(const char* prefix = "");
64
65 /**
66 * The number of bytes used for buffers allocated in the LinearAllocator (does not count space
67 * wasted)
68 */
69 size_t usedSize() const { return mTotalAllocated - mWastedSpace; }
70
71private:
72 LinearAllocator(const LinearAllocator& other);
73
74 class Page;
75
76 Page* newPage(size_t pageSize);
77 bool fitsInCurrentPage(size_t size);
78 void ensureNext(size_t size);
79 void* start(Page *p);
80 void* end(Page* p);
81
82 size_t mPageSize;
83 size_t mMaxAllocSize;
84 void* mNext;
85 Page* mCurrentPage;
86 Page* mPages;
87
88 // Memory usage tracking
89 size_t mTotalAllocated;
90 size_t mWastedSpace;
91 size_t mPageCount;
92 size_t mDedicatedPageCount;
93};
94
95}; // namespace android
96
97#endif // ANDROID_LINEARALLOCATOR_H