< prev index next >
src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.word/src/org/graalvm/compiler/word/WordCastNode.java
Print this page
rev 52509 : [mq]: graal
@@ -26,11 +26,10 @@
import static org.graalvm.compiler.nodeinfo.NodeCycles.CYCLES_1;
import static org.graalvm.compiler.nodeinfo.NodeSize.SIZE_1;
import org.graalvm.compiler.core.common.LIRKind;
-import org.graalvm.compiler.core.common.type.AbstractObjectStamp;
import org.graalvm.compiler.core.common.type.AbstractPointerStamp;
import org.graalvm.compiler.core.common.type.IntegerStamp;
import org.graalvm.compiler.core.common.type.ObjectStamp;
import org.graalvm.compiler.core.common.type.Stamp;
import org.graalvm.compiler.core.common.type.StampFactory;
@@ -138,12 +137,29 @@
return StampFactory.object();
}
@Override
public boolean inferStamp() {
- if (stamp.equals(StampFactory.object())) {
- return updateStamp(objectStampFor(input));
+ if (stamp instanceof AbstractPointerStamp) {
+ AbstractPointerStamp objectStamp = (AbstractPointerStamp) stamp;
+ if (!objectStamp.alwaysNull() && !objectStamp.nonNull()) {
+ Stamp newStamp = stamp;
+ Stamp inputStamp = input.stamp(NodeView.DEFAULT);
+ if (inputStamp instanceof AbstractPointerStamp) {
+ AbstractPointerStamp pointerStamp = (AbstractPointerStamp) inputStamp;
+ if (pointerStamp.alwaysNull()) {
+ newStamp = objectStamp.asAlwaysNull();
+ } else if (pointerStamp.nonNull()) {
+ newStamp = objectStamp.asNonNull();
+ }
+ } else if (inputStamp instanceof IntegerStamp && !((IntegerStamp) inputStamp).contains(0)) {
+ newStamp = objectStamp.asNonNull();
+ } else if (input.isConstant() && isZeroConstant(input)) {
+ newStamp = objectStamp.asAlwaysNull();
+ }
+ return updateStamp(newStamp);
+ }
}
return false;
}
@Override
@@ -151,17 +167,17 @@
if (tool.allUsagesAvailable() && hasNoUsages()) {
/* If the cast is unused, it can be eliminated. */
return input;
}
- assert !stamp(NodeView.DEFAULT).isCompatible(input.stamp(NodeView.DEFAULT));
+ assert !stamp.isCompatible(input.stamp(NodeView.DEFAULT));
if (input.isConstant()) {
/* Null pointers are uncritical for GC, so they can be constant folded. */
if (input.asJavaConstant().isNull()) {
- return ConstantNode.forIntegerStamp(stamp(NodeView.DEFAULT), 0);
+ return ConstantNode.forIntegerStamp(stamp, 0);
} else if (isZeroConstant(input)) {
- return ConstantNode.forConstant(stamp(NodeView.DEFAULT), JavaConstant.NULL_POINTER, tool.getMetaAccess());
+ return ConstantNode.forConstant(stamp, ((AbstractPointerStamp) stamp).nullConstant(), tool.getMetaAccess());
}
}
return this;
}
@@ -181,11 +197,11 @@
generator.setResult(this, value);
} else {
AllocatableValue result = generator.getLIRGeneratorTool().newVariable(kind);
if (stamp.equals(StampFactory.object())) {
generator.getLIRGeneratorTool().emitConvertZeroToNull(result, value);
- } else if (!trackedPointer && !((AbstractObjectStamp) input.stamp(NodeView.DEFAULT)).nonNull()) {
+ } else if (!trackedPointer && !((AbstractPointerStamp) input.stamp(NodeView.DEFAULT)).nonNull()) {
generator.getLIRGeneratorTool().emitConvertNullToZero(result, value);
} else {
generator.getLIRGeneratorTool().emitMove(result, value);
}
generator.setResult(this, result);
< prev index next >