Mercurial > hg > graal-compiler
view graal/com.oracle.graal.nodes/src/com/oracle/graal/nodes/extended/UnsafeLoadNode.java @ 8501:41fc46da946a
-More fixes and passrate(fop)
author | Christos Kotselidis <christos.kotselidis@oracle.com> |
---|---|
date | Wed, 06 Mar 2013 19:35:04 +0100 |
parents | 0b646334c5f7 |
children | 86b4965f0c9a |
line wrap: on
line source
/* * Copyright (c) 2011, 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. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.oracle.graal.nodes.extended; import com.oracle.graal.api.meta.*; import com.oracle.graal.graph.*; import com.oracle.graal.nodes.*; import com.oracle.graal.nodes.java.*; import com.oracle.graal.nodes.spi.*; import com.oracle.graal.nodes.type.*; /** * Load of a value from a location specified as an offset relative to an object. No null check is * performed before the load. */ public class UnsafeLoadNode extends UnsafeAccessNode implements Lowerable, Virtualizable, Canonicalizable { public UnsafeLoadNode(ValueNode object, int displacement, ValueNode offset, boolean nonNull) { this(nonNull ? StampFactory.objectNonNull() : StampFactory.object(), object, displacement, offset, Kind.Object); } public UnsafeLoadNode(ValueNode object, int displacement, ValueNode offset, Kind accessKind) { this(StampFactory.forKind(accessKind.getStackKind()), object, displacement, offset, accessKind); } public UnsafeLoadNode(Stamp stamp, ValueNode object, int displacement, ValueNode offset, Kind accessKind) { super(stamp, object, displacement, offset, accessKind); } @Override public void lower(LoweringTool tool) { tool.getRuntime().lower(this, tool); } @Override public void virtualize(VirtualizerTool tool) { State state = tool.getObjectState(object()); if (state != null && state.getState() == EscapeState.Virtual) { ValueNode indexValue = tool.getReplacedValue(offset()); if (indexValue.isConstant()) { long offset = indexValue.asConstant().asLong() + displacement(); int entryIndex = state.getVirtualObject().entryIndexForOffset(offset); if (entryIndex != -1 && state.getVirtualObject().entryKind(entryIndex) == accessKind()) { tool.replaceWith(state.getEntry(entryIndex)); } } } } @Override public ValueNode canonical(CanonicalizerTool tool) { if (offset().isConstant()) { long constantOffset = offset().asConstant().asLong(); if (constantOffset != 0) { int intDisplacement = (int) (constantOffset + displacement()); if (constantOffset == intDisplacement) { Graph graph = this.graph(); return graph.add(new UnsafeLoadNode(this.stamp(), object(), intDisplacement, graph.unique(ConstantNode.forInt(0, graph)), accessKind())); } } else if (object().stamp() instanceof ObjectStamp) { // TODO (gd) remove that once // UnsafeAccess only have an // object base ObjectStamp receiverStamp = object().objectStamp(); if (receiverStamp.nonNull()) { ResolvedJavaType receiverType = receiverStamp.type(); ResolvedJavaField field = receiverType.findInstanceFieldWithOffset(displacement()); // ResolvedJavaField[] instanceFields = // tool.runtime().lookupJavaType(java.lang.ref.Reference.class).getInstanceFields(false); // for (ResolvedJavaField field1 : instanceFields) { // if (field != null && (field1.getName() == field.getName())) { // System.out.println("Match field name: " + field.getName()); // } else if (field != null) { // System.out.println("Non matching field name: " + field.getName()); // } // } if (field != null) { return this.graph().add(new LoadFieldNode(object(), field)); } } } } return this; } @NodeIntrinsic public static native <T> T load(Object object, @ConstantNodeParameter int displacement, long offset, @ConstantNodeParameter Kind kind); }