diff options
author | 2016-05-13 14:46:28 -0700 | |
---|---|---|
committer | 2016-05-16 10:16:22 -0700 | |
commit | 8494943e2e4ca98f2087dbacfae1dedefc853a4b (patch) | |
tree | c931bfa11f66a8a68bcfb8b7945b23e10c1d7d68 | |
parent | b68b354db33957cd20ca444cdb49b957781f70c9 (diff) |
Make quick frames of proxy methods visited if they're constructors.
Also adds a test case for getting annotations during moving GC.
Bug: 28510922
(cherry-picked from commit 12c08f03f65acc1c308491fc7ab6c57f682e2f24)
Change-Id: I0d5cc9d5bb8bbff6bd6b108f7486a63402a15993
-rw-r--r-- | runtime/thread.cc | 2 | ||||
-rwxr-xr-x | test/148-multithread-gc-annotations/check | 22 | ||||
-rw-r--r-- | test/148-multithread-gc-annotations/expected.txt | 0 | ||||
-rw-r--r-- | test/148-multithread-gc-annotations/gc_coverage.cc | 42 | ||||
-rw-r--r-- | test/148-multithread-gc-annotations/info.txt | 1 | ||||
-rw-r--r-- | test/148-multithread-gc-annotations/src/AnnoClass1.java | 23 | ||||
-rw-r--r-- | test/148-multithread-gc-annotations/src/AnnoClass2.java | 23 | ||||
-rw-r--r-- | test/148-multithread-gc-annotations/src/AnnoClass3.java | 23 | ||||
-rw-r--r-- | test/148-multithread-gc-annotations/src/AnnotationThread.java | 32 | ||||
-rw-r--r-- | test/148-multithread-gc-annotations/src/Main.java | 32 | ||||
-rw-r--r-- | test/148-multithread-gc-annotations/src/MovingGCThread.java | 62 | ||||
-rw-r--r-- | test/Android.libarttest.mk | 1 |
12 files changed, 262 insertions, 1 deletions
diff --git a/runtime/thread.cc b/runtime/thread.cc index fb248282be..8b287acb35 100644 --- a/runtime/thread.cc +++ b/runtime/thread.cc @@ -2764,7 +2764,7 @@ class ReferenceMapVisitor : public StackVisitor { VisitDeclaringClass(m); // Process register map (which native and runtime methods don't have) - if (!m->IsNative() && !m->IsRuntimeMethod() && !m->IsProxyMethod()) { + if (!m->IsNative() && !m->IsRuntimeMethod() && (!m->IsProxyMethod() || m->IsConstructor())) { const OatQuickMethodHeader* method_header = GetCurrentOatQuickMethodHeader(); DCHECK(method_header->IsOptimized()); auto* vreg_base = reinterpret_cast<StackReference<mirror::Object>*>( diff --git a/test/148-multithread-gc-annotations/check b/test/148-multithread-gc-annotations/check new file mode 100755 index 0000000000..842bdc6ae8 --- /dev/null +++ b/test/148-multithread-gc-annotations/check @@ -0,0 +1,22 @@ +#!/bin/bash +# +# Copyright (C) 2015 The Android Open Source Project +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Check that the string "error" isn't present +if grep error "$2"; then + exit 1 +else + exit 0 +fi diff --git a/test/148-multithread-gc-annotations/expected.txt b/test/148-multithread-gc-annotations/expected.txt new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/test/148-multithread-gc-annotations/expected.txt diff --git a/test/148-multithread-gc-annotations/gc_coverage.cc b/test/148-multithread-gc-annotations/gc_coverage.cc new file mode 100644 index 0000000000..263eefd3ab --- /dev/null +++ b/test/148-multithread-gc-annotations/gc_coverage.cc @@ -0,0 +1,42 @@ +/* + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "gc/heap.h" +#include "jni.h" +#include "runtime.h" +#include "scoped_thread_state_change.h" +#include "thread-inl.h" + +namespace art { +namespace { + +extern "C" JNIEXPORT jboolean JNICALL Java_MovingGCThread_performHomogeneousSpaceCompact(JNIEnv*, jclass) { + return Runtime::Current()->GetHeap()->PerformHomogeneousSpaceCompact() == gc::kSuccess ? + JNI_TRUE : JNI_FALSE; +} + +extern "C" JNIEXPORT jboolean JNICALL Java_MovingGCThread_supportHomogeneousSpaceCompact(JNIEnv*, jclass) { + return Runtime::Current()->GetHeap()->SupportHomogeneousSpaceCompactAndCollectorTransitions() ? + JNI_TRUE : JNI_FALSE; +} + +extern "C" JNIEXPORT jlong JNICALL Java_MovingGCThread_objectAddress(JNIEnv* env, jclass, jobject object) { + ScopedObjectAccess soa(env); + return reinterpret_cast<jlong>(soa.Decode<mirror::Object*>(object)); +} + +} // namespace +} // namespace art diff --git a/test/148-multithread-gc-annotations/info.txt b/test/148-multithread-gc-annotations/info.txt new file mode 100644 index 0000000000..c62e544e08 --- /dev/null +++ b/test/148-multithread-gc-annotations/info.txt @@ -0,0 +1 @@ +Tests that getting annotations works during moving gc. diff --git a/test/148-multithread-gc-annotations/src/AnnoClass1.java b/test/148-multithread-gc-annotations/src/AnnoClass1.java new file mode 100644 index 0000000000..b82c61fd5b --- /dev/null +++ b/test/148-multithread-gc-annotations/src/AnnoClass1.java @@ -0,0 +1,23 @@ +/* + * Copyright (C) 2016 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import java.lang.annotation.*; + +@Retention(RetentionPolicy.RUNTIME) +@Target(ElementType.TYPE) +public @interface AnnoClass1 { + Class value(); +} diff --git a/test/148-multithread-gc-annotations/src/AnnoClass2.java b/test/148-multithread-gc-annotations/src/AnnoClass2.java new file mode 100644 index 0000000000..c75d950e2a --- /dev/null +++ b/test/148-multithread-gc-annotations/src/AnnoClass2.java @@ -0,0 +1,23 @@ +/* + * Copyright (C) 2016 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import java.lang.annotation.*; + +@Retention(RetentionPolicy.RUNTIME) +@Target(ElementType.TYPE) +public @interface AnnoClass2 { + Class value(); +} diff --git a/test/148-multithread-gc-annotations/src/AnnoClass3.java b/test/148-multithread-gc-annotations/src/AnnoClass3.java new file mode 100644 index 0000000000..5b4a378091 --- /dev/null +++ b/test/148-multithread-gc-annotations/src/AnnoClass3.java @@ -0,0 +1,23 @@ +/* + * Copyright (C) 2016 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import java.lang.annotation.*; + +@Retention(RetentionPolicy.RUNTIME) +@Target(ElementType.TYPE) +public @interface AnnoClass3 { + Class value(); +} diff --git a/test/148-multithread-gc-annotations/src/AnnotationThread.java b/test/148-multithread-gc-annotations/src/AnnotationThread.java new file mode 100644 index 0000000000..ebc14e96bb --- /dev/null +++ b/test/148-multithread-gc-annotations/src/AnnotationThread.java @@ -0,0 +1,32 @@ +/* + * Copyright (C) 2016 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import java.lang.annotation.*; + +@AnnoClass1(AnnoClass2.class) +@AnnoClass2(AnnoClass3.class) +@AnnoClass3(AnnoClass1.class) +public class AnnotationThread implements Runnable { + public void run() { + for (int i = 0; i < 20; i++) { + Annotation[] annotations = AnnotationThread.class.getAnnotations(); + if (annotations == null) { + System.out.println("error: AnnotationThread class has no annotations"); + return; + } + } + } +} diff --git a/test/148-multithread-gc-annotations/src/Main.java b/test/148-multithread-gc-annotations/src/Main.java new file mode 100644 index 0000000000..b652ed6519 --- /dev/null +++ b/test/148-multithread-gc-annotations/src/Main.java @@ -0,0 +1,32 @@ +/* + * Copyright (C) 2016 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +public class Main { + public static void main(String[] args) { + System.loadLibrary(args[0]); + Thread annoThread = new Thread(new AnnotationThread(), "Annotation thread"); + Thread gcThread = new Thread(new MovingGCThread(), "Moving GC thread"); + annoThread.start(); + gcThread.start(); + try { + annoThread.join(); + gcThread.join(); + } catch (InterruptedException e) { + System.out.println("error: " + e); + } + System.out.println("Done."); + } +} diff --git a/test/148-multithread-gc-annotations/src/MovingGCThread.java b/test/148-multithread-gc-annotations/src/MovingGCThread.java new file mode 100644 index 0000000000..87de9f4ec6 --- /dev/null +++ b/test/148-multithread-gc-annotations/src/MovingGCThread.java @@ -0,0 +1,62 @@ +/* + * Copyright (C) 2016 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import java.util.TreeMap; + +public class MovingGCThread implements Runnable { + private static TreeMap treeMap = new TreeMap(); + + public void run() { + for (int i = 0; i < 20; i++) { + testHomogeneousCompaction(); + } + } + + public static void testHomogeneousCompaction() { + final boolean supportHSC = supportHomogeneousSpaceCompact(); + if (!supportHSC) { + return; + } + Object o = new Object(); + long addressBefore = objectAddress(o); + allocateStuff(); + final boolean success = performHomogeneousSpaceCompact(); + allocateStuff(); + if (!success) { + System.out.println("error: Expected " + supportHSC + " but got " + success); + } + allocateStuff(); + long addressAfter = objectAddress(o); + // This relies on the compaction copying from one space to another space and there being + // no overlap. + if (addressBefore == addressAfter) { + System.out.println("error: Expected different adddress " + addressBefore + " vs " + + addressAfter); + } + } + + private static void allocateStuff() { + for (int i = 0; i < 1000; ++i) { + Object o = new Object(); + treeMap.put(o.hashCode(), o); + } + } + + // Methods to get access to ART internals. + private static native boolean supportHomogeneousSpaceCompact(); + private static native boolean performHomogeneousSpaceCompact(); + private static native long objectAddress(Object object); +} diff --git a/test/Android.libarttest.mk b/test/Android.libarttest.mk index 21f8141c66..97204d34c4 100644 --- a/test/Android.libarttest.mk +++ b/test/Android.libarttest.mk @@ -34,6 +34,7 @@ LIBARTTEST_COMMON_SRC_FILES := \ 137-cfi/cfi.cc \ 139-register-natives/regnative.cc \ 141-class-unload/jni_unload.cc \ + 148-multithread-gc-annotations/gc_coverage.cc \ 454-get-vreg/get_vreg_jni.cc \ 457-regs/regs_jni.cc \ 461-get-reference-vreg/get_reference_vreg_jni.cc \ |