From 6fac447555dc94a935b78198479cce645c837b89 Mon Sep 17 00:00:00 2001 From: Ian Rogers Date: Tue, 25 Feb 2014 17:01:10 -0800 Subject: Make allocations report usable size. Work-in-progress to allow arrays to fill usable size. Bug: 13028925. Use C++11's override keyword on GCC >= 2.7 to ensure that we override GC and allocator methods. Move initial mirror::Class set up into a Functor so that all allocated objects have non-zero sizes. Use this property to assert that all objects are never larger than their usable size. Other bits of GC related clean-up, missing initialization, missing use of const, hot methods in .cc files, "unimplemented" functions that fail at runtime in header files, reducing header file includes, move valgrind's space into its own files, reduce number of array allocation routines. Change-Id: Id5760041a2d7f94dcaf17ec760f6095ec75dadaa --- runtime/native/java_lang_reflect_Array.cc | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'runtime/native/java_lang_reflect_Array.cc') diff --git a/runtime/native/java_lang_reflect_Array.cc b/runtime/native/java_lang_reflect_Array.cc index fc30aa6..a991818 100644 --- a/runtime/native/java_lang_reflect_Array.cc +++ b/runtime/native/java_lang_reflect_Array.cc @@ -50,14 +50,17 @@ static jobject Array_createObjectArray(JNIEnv* env, jclass, jclass javaElementCl ThrowNegativeArraySizeException(length); return NULL; } - ClassLinker* class_linker = Runtime::Current()->GetClassLinker(); + Runtime* runtime = Runtime::Current(); + ClassLinker* class_linker = runtime->GetClassLinker(); mirror::Class* array_class = class_linker->FindArrayClass(soa.Self(), element_class); if (UNLIKELY(array_class == NULL)) { CHECK(soa.Self()->IsExceptionPending()); return NULL; } - DCHECK(array_class->IsArrayClass()); - mirror::Array* new_array = mirror::Array::Alloc(soa.Self(), array_class, length); + DCHECK(array_class->IsObjectArrayClass()); + mirror::Array* new_array = mirror::Array::Alloc(soa.Self(), array_class, length, + sizeof(mirror::HeapReference), + runtime->GetHeap()->GetCurrentAllocator()); return soa.AddLocalReference(new_array); } -- cgit v1.1