From 272eb6824b15d1b86382bc826902fb35fd7d40d8 Mon Sep 17 00:00:00 2001 From: Doug Simon Date: Tue, 23 Oct 2018 18:49:32 +0200 Subject: [PATCH] 8212817: [JVMCI] ResolvedJavaMethod.isInVirtualMethodTable throws InternalError Reviewed-by: never, iveresov --- .../ci/hotspot/HotSpotResolvedJavaMethodImpl.java | 2 +- .../vm/ci/runtime/test/TestResolvedJavaMethod.java | 13 +++++++++++++ 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedJavaMethodImpl.java b/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedJavaMethodImpl.java index 3a60592cc9f..d4739f7dcbe 100644 --- a/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedJavaMethodImpl.java +++ b/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotResolvedJavaMethodImpl.java @@ -725,7 +725,7 @@ final class HotSpotResolvedJavaMethodImpl extends HotSpotMethod implements HotSp return config().invalidVtableIndex; } if (holder.isInterface()) { - if (resolved.isInterface()) { + if (resolved.isInterface() || !resolved.isLinked()) { return config().invalidVtableIndex; } return getVtableIndexForInterfaceMethod(resolved); diff --git a/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaMethod.java b/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaMethod.java index e94ed85eb1d..430745c715e 100644 --- a/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaMethod.java +++ b/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaMethod.java @@ -429,11 +429,24 @@ public class TestResolvedJavaMethod extends MethodUniverse { } } + static class UnlinkedType { + } + /** * All public non-final methods should be available in the vtable. */ @Test public void testVirtualMethodTableAccess() { + ResolvedJavaType unlinkedType = metaAccess.lookupJavaType(UnlinkedType.class); + assertTrue(!unlinkedType.isLinked()); + for (Class c : classes) { + if (c.isInterface()) { + for (Method m : c.getDeclaredMethods()) { + ResolvedJavaMethod method = metaAccess.lookupJavaMethod(m); + method.isInVirtualMethodTable(unlinkedType); + } + } + } for (Class c : classes) { if (c.isPrimitive() || c.isInterface()) { continue;