src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMetaAccessProvider.java
Index Unified diffs Context diffs Sdiffs Frames Patch New Old Previous File Next File
*** old/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMetaAccessProvider.java	Thu Mar 28 11:23:54 2019
--- new/src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMetaAccessProvider.java	Thu Mar 28 11:23:54 2019

*** 1,7 **** --- 1,7 ---- /* ! * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. ! * Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation.
*** 20,33 **** --- 20,29 ---- * or visit www.oracle.com if you need additional information or have any * questions. */ package jdk.vm.ci.hotspot; import static jdk.vm.ci.hotspot.HotSpotResolvedObjectTypeImpl.fromObjectClass; import static jdk.vm.ci.hotspot.UnsafeAccess.UNSAFE; import java.lang.reflect.Array; import java.lang.reflect.Executable; import java.lang.reflect.Field; import java.lang.reflect.Modifier; import java.util.Objects;
*** 41,50 **** --- 37,48 ---- import jdk.vm.ci.meta.ResolvedJavaField; import jdk.vm.ci.meta.ResolvedJavaMethod; import jdk.vm.ci.meta.ResolvedJavaType; import jdk.vm.ci.meta.Signature; import jdk.vm.ci.meta.SpeculationLog; + import jdk.vm.ci.meta.SpeculationLog.NoSpeculationReason; + import jdk.vm.ci.meta.SpeculationLog.Speculation; // JaCoCo Exclude /** * HotSpot implementation of {@link MetaAccessProvider}.
*** 85,108 **** --- 83,105 ---- @Override public ResolvedJavaField lookupJavaField(Field reflectionField) { Class<?> fieldHolder = reflectionField.getDeclaringClass(); ! HotSpotResolvedObjectType holder = fromObjectClass(fieldHolder); ! HotSpotResolvedJavaType holder = runtime.fromClass(fieldHolder); + assert holder != null : fieldHolder; + ResolvedJavaField[] fields; if (Modifier.isStatic(reflectionField.getModifiers())) { ! final long offset = UNSAFE.staticFieldOffset(reflectionField); for (ResolvedJavaField field : holder.getStaticFields()) { if (offset == ((HotSpotResolvedJavaField) field).getOffset()) { return field; } } ! fields = holder.getStaticFields(); } else { ! final long offset = UNSAFE.objectFieldOffset(reflectionField); for (ResolvedJavaField field : holder.getInstanceFields(false)) { if (offset == ((HotSpotResolvedJavaField) field).getOffset()) { return field; ! fields = holder.getInstanceFields(false); } + ResolvedJavaType fieldType = lookupJavaType(reflectionField.getType()); + for (ResolvedJavaField field : fields) { + if (reflectionField.getName().equals(field.getName()) && field.getType().equals(fieldType)) { + assert Modifier.isStatic(reflectionField.getModifiers()) == field.isStatic(); + return field; } } throw new JVMCIError("unresolved field %s", reflectionField); }
*** 145,167 **** --- 142,166 ---- HotSpotVMConfig config = runtime.getConfig(); return ((~constant.asInt()) >> config.deoptimizationDebugIdShift) & intMaskRight(config.deoptimizationDebugIdBits); } @Override - public JavaConstant encodeSpeculation(SpeculationLog.Speculation speculation) { - if (speculation.getReason() instanceof SpeculationLog.NoSpeculationReason) { return JavaConstant.LONG_0; } return ((HotSpotSpeculationLog.HotSpotSpeculation) speculation).getEncoding(); } @Override - public SpeculationLog.Speculation decodeSpeculation(JavaConstant constant, SpeculationLog speculationLog) { if (constant.equals(JavaConstant.LONG_0)) { return SpeculationLog.NO_SPECULATION; } assert speculationLog != null : "Must have a speculation log"; + if (speculationLog == null) { + throw new IllegalArgumentException("A speculation log is required to decode the speculation denoted by " + constant); + } return speculationLog.lookupSpeculation(constant); } public int convertDeoptAction(DeoptimizationAction action) { HotSpotVMConfig config = runtime.getConfig();
*** 301,315 **** --- 300,314 ---- if (lookupJavaType == null) { return 0; } else { if (lookupJavaType.isArray()) { ! int length = Array.getLength(((HotSpotObjectConstantImpl) constant).object()); ! int length = runtime.getHostJVMCIBackend().getConstantReflection().readArrayLength(constant); ResolvedJavaType elementType = lookupJavaType.getComponentType(); JavaKind elementKind = elementType.getJavaKind(); ! final int headerSize = runtime.getArrayBaseOffset(elementKind); ! int sizeOfElement = runtime.getArrayIndexScale(elementKind); int log2ElementSize = CodeUtil.log2(sizeOfElement); return computeArrayAllocationSize(length, headerSize, log2ElementSize); } return lookupJavaType.instanceSize(); }

src/jdk.internal.vm.ci/share/classes/jdk.vm.ci.hotspot/src/jdk/vm/ci/hotspot/HotSpotMetaAccessProvider.java
Index Unified diffs Context diffs Sdiffs Frames Patch New Old Previous File Next File