blob: 8897405b2d5709ebda6a3e03d102df55045adc2f [file] [log] [blame]
Elliott Hughes9d5ccec2011-09-19 13:19:50 -07001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Carl Shapiro1fb86202011-06-27 17:43:13 -070016
17#ifndef ART_SRC_HEAP_H_
18#define ART_SRC_HEAP_H_
19
Carl Shapiro58551df2011-07-24 03:09:51 -070020#include <vector>
21
Ian Rogers5d76c432011-10-31 21:42:49 -070022#include "card_table.h"
Brian Carlstrom578bbdc2011-07-21 14:07:47 -070023#include "globals.h"
Elliott Hughes5e71b522011-10-20 13:12:32 -070024#include "heap_bitmap.h"
Ian Rogers0cfe1fb2011-08-26 03:29:44 -070025#include "offsets.h"
Carl Shapiro1fb86202011-06-27 17:43:13 -070026
Elliott Hughes3e465b12011-09-02 18:26:12 -070027#define VERIFY_OBJECT_ENABLED 0
28
Carl Shapiro1fb86202011-06-27 17:43:13 -070029namespace art {
30
Brian Carlstroma40f9bc2011-07-26 21:26:07 -070031class Class;
Elliott Hughes410c0c82011-09-01 17:58:25 -070032class Mutex;
Brian Carlstroma40f9bc2011-07-26 21:26:07 -070033class Object;
Carl Shapiro69759ea2011-07-21 18:13:35 -070034class Space;
Ian Rogers5d4bdc22011-11-02 22:15:43 -070035class Thread;
Carl Shapiro69759ea2011-07-21 18:13:35 -070036class HeapBitmap;
37
Carl Shapiro1fb86202011-06-27 17:43:13 -070038class Heap {
39 public:
Brian Carlstrom27ec9612011-09-19 20:20:38 -070040 static const size_t kInitialSize = 4 * MB;
Carl Shapiro69759ea2011-07-21 18:13:35 -070041
Brian Carlstrom27ec9612011-09-19 20:20:38 -070042 static const size_t kMaximumSize = 16 * MB;
Carl Shapiro69759ea2011-07-21 18:13:35 -070043
Elliott Hughes410c0c82011-09-01 17:58:25 -070044 typedef void (RootVisitor)(const Object* root, void* arg);
Elliott Hughesc33a32b2011-10-11 18:18:07 -070045 typedef bool (IsMarkedTester)(const Object* object, void* arg);
Brian Carlstrom7e93b502011-08-04 14:16:22 -070046
Brian Carlstrom58ae9412011-10-04 00:56:06 -070047 // Create a heap with the requested sizes. The possible empty
48 // image_file_names names specify Spaces to load based on
49 // ImageWriter output.
Brian Carlstrom6b4ef022011-10-23 14:59:04 -070050 static void Init(bool is_verbose_heap, bool is_verbose_gc,
jeffhaoc1160702011-10-27 15:48:45 -070051 size_t starting_size, size_t maximum_size, size_t growth_size,
Brian Carlstrom58ae9412011-10-04 00:56:06 -070052 const std::vector<std::string>& image_file_names);
Carl Shapiro61e019d2011-07-14 16:53:09 -070053
Carl Shapiro69759ea2011-07-21 18:13:35 -070054 static void Destroy();
Brian Carlstroma7f4f482011-07-17 17:01:34 -070055
Brian Carlstrom6b4ef022011-10-23 14:59:04 -070056 static bool IsVerboseHeap() {
Elliott Hughes352a4242011-10-31 15:15:21 -070057 return is_verbose_heap_ || is_verbose_gc_ /* TODO: remove when pause times are down */;
Brian Carlstrom6b4ef022011-10-23 14:59:04 -070058 }
59
60 static bool IsVerboseGc() {
61 return is_verbose_gc_;
62 }
63
Brian Carlstroma40f9bc2011-07-26 21:26:07 -070064 // Allocates and initializes storage for an object instance.
Carl Shapiro58551df2011-07-24 03:09:51 -070065 static Object* AllocObject(Class* klass, size_t num_bytes);
Brian Carlstroma7f4f482011-07-17 17:01:34 -070066
Elliott Hughesa2501992011-08-26 19:39:54 -070067 // Check sanity of given reference. Requires the heap lock.
Elliott Hughes3e465b12011-09-02 18:26:12 -070068#if VERIFY_OBJECT_ENABLED
Elliott Hughescf4c6c42011-09-01 15:16:42 -070069 static void VerifyObject(const Object *obj);
Elliott Hughes3e465b12011-09-02 18:26:12 -070070#else
71 static void VerifyObject(const Object *obj) {}
72#endif
Ian Rogers408f79a2011-08-23 18:22:33 -070073
Ian Rogers0cfe1fb2011-08-26 03:29:44 -070074 // Check sanity of all live references. Requires the heap lock.
75 static void VerifyHeap();
76
Elliott Hughes6a5bd492011-10-28 14:33:57 -070077 // A weaker test than IsLiveObject or VerifyObject that doesn't require the heap lock,
Elliott Hughesa2501992011-08-26 19:39:54 -070078 // and doesn't abort on error, allowing the caller to report more
79 // meaningful diagnostics.
Elliott Hughescf4c6c42011-09-01 15:16:42 -070080 static bool IsHeapAddress(const Object* obj);
Elliott Hughes6a5bd492011-10-28 14:33:57 -070081 // Returns true if 'obj' is a live heap object, false otherwise (including for invalid addresses).
82 // Requires the heap lock to be held.
83 static bool IsLiveObjectLocked(const Object* obj);
Elliott Hughesa2501992011-08-26 19:39:54 -070084
Carl Shapiro69759ea2011-07-21 18:13:35 -070085 // Initiates an explicit garbage collection.
86 static void CollectGarbage();
87
Elliott Hughesbf86d042011-08-31 17:53:14 -070088 // Implements java.lang.Runtime.maxMemory.
89 static int64_t GetMaxMemory();
90 // Implements java.lang.Runtime.totalMemory.
91 static int64_t GetTotalMemory();
92 // Implements java.lang.Runtime.freeMemory.
93 static int64_t GetFreeMemory();
94
Elliott Hughes9d5ccec2011-09-19 13:19:50 -070095 // Implements VMDebug.countInstancesOfClass.
96 static int64_t CountInstances(Class* c, bool count_assignable);
97
Elliott Hughes7ede61e2011-09-14 18:18:06 -070098 // Implements dalvik.system.VMRuntime.clearGrowthLimit.
jeffhaoc1160702011-10-27 15:48:45 -070099 static void ClearGrowthLimit();
100
Elliott Hughes7ede61e2011-09-14 18:18:06 -0700101 // Implements dalvik.system.VMRuntime.getTargetHeapUtilization.
102 static float GetTargetHeapUtilization() {
Brian Carlstrom395520e2011-09-25 19:35:00 -0700103 return target_utilization_;
Elliott Hughes7ede61e2011-09-14 18:18:06 -0700104 }
105 // Implements dalvik.system.VMRuntime.setTargetHeapUtilization.
106 static void SetTargetHeapUtilization(float target) {
Brian Carlstrom395520e2011-09-25 19:35:00 -0700107 target_utilization_ = target;
Elliott Hughes7ede61e2011-09-14 18:18:06 -0700108 }
Shih-wei Liao7f1caab2011-10-06 12:11:04 -0700109 // Sets the maximum number of bytes that the heap is allowed to allocate
110 // from the system. Clamps to the appropriate maximum value.
Shih-wei Liao8c2f6412011-10-03 22:58:14 -0700111 static void SetIdealFootprint(size_t max_allowed_footprint);
Elliott Hughes7ede61e2011-09-14 18:18:06 -0700112
Carl Shapiro69759ea2011-07-21 18:13:35 -0700113 // Blocks the caller until the garbage collector becomes idle.
114 static void WaitForConcurrentGcToComplete();
115
Brian Carlstrom24a3c2e2011-10-17 18:07:52 -0700116 static pid_t GetLockOwner(); // For SignalCatcher.
Elliott Hughes92b3b562011-09-08 16:32:26 -0700117 static void Lock();
Elliott Hughes92b3b562011-09-08 16:32:26 -0700118 static void Unlock();
Carl Shapiro61e019d2011-07-14 16:53:09 -0700119
Carl Shapiro58551df2011-07-24 03:09:51 -0700120 static const std::vector<Space*>& GetSpaces() {
121 return spaces_;
122 }
Carl Shapiro61e019d2011-07-14 16:53:09 -0700123
Carl Shapiro58551df2011-07-24 03:09:51 -0700124 static HeapBitmap* GetLiveBits() {
125 return live_bitmap_;
Carl Shapiro744ad052011-08-06 15:53:36 -0700126 }
Carl Shapiro58551df2011-07-24 03:09:51 -0700127
128 static HeapBitmap* GetMarkBits() {
129 return mark_bitmap_;
Carl Shapiro744ad052011-08-06 15:53:36 -0700130 }
Carl Shapiro58551df2011-07-24 03:09:51 -0700131
Elliott Hughesadb460d2011-10-05 17:02:34 -0700132 static void SetWellKnownClasses(Class* java_lang_ref_FinalizerReference,
133 Class* java_lang_ref_ReferenceQueue);
134
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700135 static void SetReferenceOffsets(MemberOffset reference_referent_offset,
136 MemberOffset reference_queue_offset,
137 MemberOffset reference_queueNext_offset,
138 MemberOffset reference_pendingNext_offset,
Elliott Hughesadb460d2011-10-05 17:02:34 -0700139 MemberOffset finalizer_reference_zombie_offset);
Brian Carlstrom1f870082011-08-23 16:02:11 -0700140
Elliott Hughesadb460d2011-10-05 17:02:34 -0700141 static Object* GetReferenceReferent(Object* reference);
142 static void ClearReferenceReferent(Object* reference);
Brian Carlstrom1f870082011-08-23 16:02:11 -0700143
Elliott Hughesadb460d2011-10-05 17:02:34 -0700144 // Returns true if the reference object has not yet been enqueued.
145 static bool IsEnqueuable(const Object* ref);
146 static void EnqueueReference(Object* ref, Object** list);
147 static void EnqueuePendingReference(Object* ref, Object** list);
148 static Object* DequeuePendingReference(Object** list);
Brian Carlstrom1f870082011-08-23 16:02:11 -0700149
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700150 static MemberOffset GetReferencePendingNextOffset() {
151 DCHECK_NE(reference_pendingNext_offset_.Uint32Value(), 0U);
Brian Carlstrom1f870082011-08-23 16:02:11 -0700152 return reference_pendingNext_offset_;
153 }
154
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700155 static MemberOffset GetFinalizerReferenceZombieOffset() {
156 DCHECK_NE(finalizer_reference_zombie_offset_.Uint32Value(), 0U);
Brian Carlstrom1f870082011-08-23 16:02:11 -0700157 return finalizer_reference_zombie_offset_;
158 }
159
Elliott Hughes85d15452011-09-16 17:33:01 -0700160 static void EnableObjectValidation() {
161 verify_objects_ = true;
162 }
163
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700164 static void DisableObjectValidation() {
Elliott Hughes85d15452011-09-16 17:33:01 -0700165 verify_objects_ = false;
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700166 }
167
Elliott Hughes92b3b562011-09-08 16:32:26 -0700168 // Callers must hold the heap lock.
Elliott Hughes307f75d2011-10-12 18:04:40 -0700169 static void RecordFreeLocked(size_t freed_objects, size_t freed_bytes);
Brian Carlstrom693267a2011-09-06 09:25:34 -0700170
Elliott Hughes5ea047b2011-09-13 14:38:18 -0700171 // Must be called if a field of an Object in the heap changes, and before any GC safe-point.
172 // The call is not needed if NULL is stored in the field.
Ian Rogers5d76c432011-10-31 21:42:49 -0700173 static void WriteBarrierField(const Object* dest, MemberOffset offset, const Object* new_val) {
174 if (!card_marking_disabled_) {
175 card_table_->MarkCard(dest);
176 }
177 }
178
179 // Write barrier for array operations that update many field positions
180 static void WriteBarrierArray(const Object* dest, int pos, size_t len) {
181 if (UNLIKELY(!card_marking_disabled_)) {
182 card_table_->MarkCard(dest);
183 }
184 }
185
186 static CardTable* GetCardTable() {
187 return card_table_;
188 }
189
190 static void DisableCardMarking() {
191 // TODO: we shouldn't need to disable card marking, this is here to help the image_writer
192 card_marking_disabled_ = true;
Elliott Hughes3a4f8df2011-09-13 15:22:36 -0700193 }
Elliott Hughes5ea047b2011-09-13 14:38:18 -0700194
Elliott Hughes6a5bd492011-10-28 14:33:57 -0700195 // dlmalloc_walk_heap-compatible heap walker.
196 static void WalkHeap(void(*callback)(const void*, size_t, const void*, size_t, void*), void* arg);
197
Ian Rogers5d4bdc22011-11-02 22:15:43 -0700198 static void AddFinalizerReference(Thread* self, Object* object);
Elliott Hughesadb460d2011-10-05 17:02:34 -0700199
Elliott Hughes7162ad92011-10-27 14:08:42 -0700200 static size_t GetBytesAllocated() { return num_bytes_allocated_; }
201 static size_t GetObjectsAllocated() { return num_objects_allocated_; }
202
Ian Rogers5d76c432011-10-31 21:42:49 -0700203 static Space* GetAllocSpace() {
204 return alloc_space_;
205 }
206
Carl Shapiro58551df2011-07-24 03:09:51 -0700207 private:
208 // Allocates uninitialized storage.
Elliott Hughes92b3b562011-09-08 16:32:26 -0700209 static Object* AllocateLocked(size_t num_bytes);
210 static Object* AllocateLocked(Space* space, size_t num_bytes);
Carl Shapiro58551df2011-07-24 03:09:51 -0700211
Elliott Hughesadb460d2011-10-05 17:02:34 -0700212 // Pushes a list of cleared references out to the managed heap.
213 static void EnqueueClearedReferences(Object** cleared_references);
214
Elliott Hughes92b3b562011-09-08 16:32:26 -0700215 static void RecordAllocationLocked(Space* space, const Object* object);
Brian Carlstrom9cff8e12011-08-18 16:47:29 -0700216 static void RecordImageAllocations(Space* space);
Carl Shapiro69759ea2011-07-21 18:13:35 -0700217
218 static void CollectGarbageInternal();
219
220 static void GrowForUtilization();
221
Elliott Hughes92b3b562011-09-08 16:32:26 -0700222 static void VerifyObjectLocked(const Object *obj);
223
Brian Carlstrom78128a62011-09-15 17:21:19 -0700224 static void VerificationCallback(Object* obj, void* arg);
Elliott Hughes92b3b562011-09-08 16:32:26 -0700225
Carl Shapiro69759ea2011-07-21 18:13:35 -0700226 static Mutex* lock_;
227
Brian Carlstrom6b4ef022011-10-23 14:59:04 -0700228 static bool is_verbose_heap_;
229
230 static bool is_verbose_gc_;
231
Carl Shapiro58551df2011-07-24 03:09:51 -0700232 static std::vector<Space*> spaces_;
Carl Shapiro69759ea2011-07-21 18:13:35 -0700233
Brian Carlstrom4a289ed2011-08-16 17:17:49 -0700234 // default Space for allocations
235 static Space* alloc_space_;
236
Carl Shapiro69759ea2011-07-21 18:13:35 -0700237 static HeapBitmap* mark_bitmap_;
238
239 static HeapBitmap* live_bitmap_;
240
Ian Rogers5d76c432011-10-31 21:42:49 -0700241 static CardTable* card_table_;
242
243 // Used by the image writer to disable card marking on copied objects
244 // TODO: remove
245 static bool card_marking_disabled_;
246
Carl Shapiro58551df2011-07-24 03:09:51 -0700247 // The maximum size of the heap in bytes.
Carl Shapiro69759ea2011-07-21 18:13:35 -0700248 static size_t maximum_size_;
249
jeffhaoc1160702011-10-27 15:48:45 -0700250 // The largest size the heap may grow. This value allows the app to limit the
251 // growth below the maximum size. This is a work around until we can
252 // dynamically set the maximum size. This value can range between the starting
253 // size and the maximum size but should never be set below the current
254 // footprint of the heap.
255 static size_t growth_size_;
256
Carl Shapiro58551df2011-07-24 03:09:51 -0700257 // True while the garbage collector is running.
Carl Shapiro69759ea2011-07-21 18:13:35 -0700258 static bool is_gc_running_;
259
Carl Shapiro58551df2011-07-24 03:09:51 -0700260 // Number of bytes allocated. Adjusted after each allocation and
261 // free.
262 static size_t num_bytes_allocated_;
263
264 // Number of objects allocated. Adjusted after each allocation and
265 // free.
266 static size_t num_objects_allocated_;
267
Elliott Hughesadb460d2011-10-05 17:02:34 -0700268 static Class* java_lang_ref_FinalizerReference_;
269 static Class* java_lang_ref_ReferenceQueue_;
270
Brian Carlstrom1f870082011-08-23 16:02:11 -0700271 // offset of java.lang.ref.Reference.referent
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700272 static MemberOffset reference_referent_offset_;
Brian Carlstrom1f870082011-08-23 16:02:11 -0700273
274 // offset of java.lang.ref.Reference.queue
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700275 static MemberOffset reference_queue_offset_;
Brian Carlstrom1f870082011-08-23 16:02:11 -0700276
277 // offset of java.lang.ref.Reference.queueNext
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700278 static MemberOffset reference_queueNext_offset_;
Brian Carlstrom1f870082011-08-23 16:02:11 -0700279
280 // offset of java.lang.ref.Reference.pendingNext
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700281 static MemberOffset reference_pendingNext_offset_;
Brian Carlstrom1f870082011-08-23 16:02:11 -0700282
283 // offset of java.lang.ref.FinalizerReference.zombie
Ian Rogers0cfe1fb2011-08-26 03:29:44 -0700284 static MemberOffset finalizer_reference_zombie_offset_;
285
Brian Carlstrom395520e2011-09-25 19:35:00 -0700286 // Target ideal heap utilization ratio
287 static float target_utilization_;
288
Elliott Hughes85d15452011-09-16 17:33:01 -0700289 static bool verify_objects_;
Brian Carlstrom1f870082011-08-23 16:02:11 -0700290
Carl Shapiro69759ea2011-07-21 18:13:35 -0700291 DISALLOW_IMPLICIT_CONSTRUCTORS(Heap);
292};
293
Elliott Hughes6a5bd492011-10-28 14:33:57 -0700294class ScopedHeapLock {
295 public:
296 ScopedHeapLock() {
297 Heap::Lock();
298 }
299
300 ~ScopedHeapLock() {
301 Heap::Unlock();
302 }
303
304 private:
305 DISALLOW_COPY_AND_ASSIGN(ScopedHeapLock);
306};
307
Carl Shapiro1fb86202011-06-27 17:43:13 -0700308} // namespace art
309
310#endif // ART_SRC_HEAP_H_