com.oracle.truffle.sl.nodes.expression.SLDivNodeGen Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of truffle-sl Show documentation
Show all versions of truffle-sl Show documentation
Truffle SL is an example language implemented using the Truffle API.
// CheckStyle: start generated
package com.oracle.truffle.sl.nodes.expression;
import com.oracle.truffle.api.CompilerDirectives;
import com.oracle.truffle.api.CompilerDirectives.CompilationFinal;
import com.oracle.truffle.api.dsl.GeneratedBy;
import com.oracle.truffle.api.frame.VirtualFrame;
import com.oracle.truffle.api.nodes.NodeCost;
import com.oracle.truffle.api.nodes.UnexpectedResultException;
import com.oracle.truffle.sl.nodes.SLExpressionNode;
import com.oracle.truffle.sl.nodes.SLTypesGen;
import com.oracle.truffle.sl.nodes.expression.SLDivNode;
import com.oracle.truffle.sl.runtime.SLBigNumber;
import java.util.concurrent.locks.Lock;
@GeneratedBy(SLDivNode.class)
public final class SLDivNodeGen extends SLDivNode {
@Child private SLExpressionNode leftNode_;
@Child private SLExpressionNode rightNode_;
@CompilationFinal private int state_;
@CompilationFinal private int exclude_;
private SLDivNodeGen(SLExpressionNode leftNode, SLExpressionNode rightNode) {
this.leftNode_ = leftNode;
this.rightNode_ = rightNode;
}
@Override
public Object executeGeneric(VirtualFrame frameValue) {
int state = state_;
if ((state & 0b110) == 0 /* only-active div(long, long) */ && (state & 0b111) != 0 /* is-not div(long, long) && div(SLBigNumber, SLBigNumber) && typeError(Object, Object) */) {
return executeGeneric_long_long0(frameValue, state);
} else {
return executeGeneric_generic1(frameValue, state);
}
}
private Object executeGeneric_long_long0(VirtualFrame frameValue, int state) {
long leftNodeValue_;
try {
leftNodeValue_ = this.leftNode_.executeLong(frameValue);
} catch (UnexpectedResultException ex) {
Object rightNodeValue = this.rightNode_.executeGeneric(frameValue);
return executeAndSpecialize(ex.getResult(), rightNodeValue);
}
long rightNodeValue_;
try {
rightNodeValue_ = this.rightNode_.executeLong(frameValue);
} catch (UnexpectedResultException ex) {
return executeAndSpecialize(leftNodeValue_, ex.getResult());
}
assert (state & 0b1) != 0 /* is-active div(long, long) */;
try {
return div(leftNodeValue_, rightNodeValue_);
} catch (ArithmeticException ex) {
// implicit transferToInterpreterAndInvalidate()
Lock lock = getLock();
lock.lock();
try {
this.exclude_ = this.exclude_ | 0b1 /* add-excluded div(long, long) */;
this.state_ = this.state_ & 0xfffffffe /* remove-active div(long, long) */;
} finally {
lock.unlock();
}
return executeAndSpecialize(leftNodeValue_, rightNodeValue_);
}
}
private Object executeGeneric_generic1(VirtualFrame frameValue, int state) {
Object leftNodeValue_ = this.leftNode_.executeGeneric(frameValue);
Object rightNodeValue_ = this.rightNode_.executeGeneric(frameValue);
if ((state & 0b1) != 0 /* is-active div(long, long) */ && leftNodeValue_ instanceof Long) {
long leftNodeValue__ = (long) leftNodeValue_;
if (rightNodeValue_ instanceof Long) {
long rightNodeValue__ = (long) rightNodeValue_;
try {
return div(leftNodeValue__, rightNodeValue__);
} catch (ArithmeticException ex) {
// implicit transferToInterpreterAndInvalidate()
Lock lock = getLock();
lock.lock();
try {
this.exclude_ = this.exclude_ | 0b1 /* add-excluded div(long, long) */;
this.state_ = this.state_ & 0xfffffffe /* remove-active div(long, long) */;
} finally {
lock.unlock();
}
return executeAndSpecialize(leftNodeValue__, rightNodeValue__);
}
}
}
if ((state & 0b10) != 0 /* is-active div(SLBigNumber, SLBigNumber) */ && SLTypesGen.isImplicitSLBigNumber((state & 0b11000) >>> 3 /* extract-implicit-active 0:SLBigNumber */, leftNodeValue_)) {
SLBigNumber leftNodeValue__ = SLTypesGen.asImplicitSLBigNumber((state & 0b11000) >>> 3 /* extract-implicit-active 0:SLBigNumber */, leftNodeValue_);
if (SLTypesGen.isImplicitSLBigNumber((state & 0b1100000) >>> 5 /* extract-implicit-active 1:SLBigNumber */, rightNodeValue_)) {
SLBigNumber rightNodeValue__ = SLTypesGen.asImplicitSLBigNumber((state & 0b1100000) >>> 5 /* extract-implicit-active 1:SLBigNumber */, rightNodeValue_);
return div(leftNodeValue__, rightNodeValue__);
}
}
if ((state & 0b100) != 0 /* is-active typeError(Object, Object) */) {
if (fallbackGuard_(leftNodeValue_, rightNodeValue_)) {
return typeError(leftNodeValue_, rightNodeValue_);
}
}
CompilerDirectives.transferToInterpreterAndInvalidate();
return executeAndSpecialize(leftNodeValue_, rightNodeValue_);
}
@Override
public long executeLong(VirtualFrame frameValue) throws UnexpectedResultException {
int state = state_;
if ((state & 0b100) != 0 /* is-active typeError(Object, Object) */) {
return SLTypesGen.expectLong(executeGeneric(frameValue));
}
long leftNodeValue_;
try {
leftNodeValue_ = this.leftNode_.executeLong(frameValue);
} catch (UnexpectedResultException ex) {
Object rightNodeValue = this.rightNode_.executeGeneric(frameValue);
return SLTypesGen.expectLong(executeAndSpecialize(ex.getResult(), rightNodeValue));
}
long rightNodeValue_;
try {
rightNodeValue_ = this.rightNode_.executeLong(frameValue);
} catch (UnexpectedResultException ex) {
return SLTypesGen.expectLong(executeAndSpecialize(leftNodeValue_, ex.getResult()));
}
if ((state & 0b1) != 0 /* is-active div(long, long) */) {
try {
return div(leftNodeValue_, rightNodeValue_);
} catch (ArithmeticException ex) {
// implicit transferToInterpreterAndInvalidate()
Lock lock = getLock();
lock.lock();
try {
this.exclude_ = this.exclude_ | 0b1 /* add-excluded div(long, long) */;
this.state_ = this.state_ & 0xfffffffe /* remove-active div(long, long) */;
} finally {
lock.unlock();
}
return SLTypesGen.expectLong(executeAndSpecialize(leftNodeValue_, rightNodeValue_));
}
}
CompilerDirectives.transferToInterpreterAndInvalidate();
return SLTypesGen.expectLong(executeAndSpecialize(leftNodeValue_, rightNodeValue_));
}
@Override
public void executeVoid(VirtualFrame frameValue) {
int state = state_;
try {
if ((state & 0b110) == 0 /* only-active div(long, long) */ && (state & 0b111) != 0 /* is-not div(long, long) && div(SLBigNumber, SLBigNumber) && typeError(Object, Object) */) {
executeLong(frameValue);
return;
}
executeGeneric(frameValue);
return;
} catch (UnexpectedResultException ex) {
return;
}
}
private Object executeAndSpecialize(Object leftNodeValue, Object rightNodeValue) {
Lock lock = getLock();
boolean hasLock = true;
lock.lock();
int state = state_;
int exclude = exclude_;
int oldState = (state & 0b111);
int oldExclude = exclude;
try {
if ((exclude) == 0 /* is-not-excluded div(long, long) */ && leftNodeValue instanceof Long) {
long leftNodeValue_ = (long) leftNodeValue;
if (rightNodeValue instanceof Long) {
long rightNodeValue_ = (long) rightNodeValue;
this.state_ = state = state | 0b1 /* add-active div(long, long) */;
try {
lock.unlock();
hasLock = false;
return div(leftNodeValue_, rightNodeValue_);
} catch (ArithmeticException ex) {
// implicit transferToInterpreterAndInvalidate()
lock.lock();
try {
this.exclude_ = this.exclude_ | 0b1 /* add-excluded div(long, long) */;
this.state_ = this.state_ & 0xfffffffe /* remove-active div(long, long) */;
} finally {
lock.unlock();
}
return executeAndSpecialize(leftNodeValue_, rightNodeValue_);
}
}
}
{
int sLBigNumberCast0;
if ((sLBigNumberCast0 = SLTypesGen.specializeImplicitSLBigNumber(leftNodeValue)) != 0) {
SLBigNumber leftNodeValue_ = SLTypesGen.asImplicitSLBigNumber(sLBigNumberCast0, leftNodeValue);
int sLBigNumberCast1;
if ((sLBigNumberCast1 = SLTypesGen.specializeImplicitSLBigNumber(rightNodeValue)) != 0) {
SLBigNumber rightNodeValue_ = SLTypesGen.asImplicitSLBigNumber(sLBigNumberCast1, rightNodeValue);
state = (state | (sLBigNumberCast0 << 3) /* set-implicit-active 0:SLBigNumber */);
state = (state | (sLBigNumberCast1 << 5) /* set-implicit-active 1:SLBigNumber */);
this.state_ = state = state | 0b10 /* add-active div(SLBigNumber, SLBigNumber) */;
lock.unlock();
hasLock = false;
return div(leftNodeValue_, rightNodeValue_);
}
}
}
this.state_ = state = state | 0b100 /* add-active typeError(Object, Object) */;
lock.unlock();
hasLock = false;
return typeError(leftNodeValue, rightNodeValue);
} finally {
if (oldState != 0 || oldExclude != 0) {
checkForPolymorphicSpecialize(oldState, oldExclude);
}
if (hasLock) {
lock.unlock();
}
}
}
private void checkForPolymorphicSpecialize(int oldState, int oldExclude) {
int newState = (this.state_ & 0b111);
int newExclude = this.exclude_;
if ((oldState ^ newState) != 0 || (oldExclude ^ newExclude) != 0) {
this.reportPolymorphicSpecialize();
}
}
@Override
public NodeCost getCost() {
int state = state_;
if ((state & 0b111) == 0b0) {
return NodeCost.UNINITIALIZED;
} else if (((state & 0b111) & ((state & 0b111) - 1)) == 0 /* is-single-active */) {
return NodeCost.MONOMORPHIC;
}
return NodeCost.POLYMORPHIC;
}
private static boolean fallbackGuard_(Object leftNodeValue, Object rightNodeValue) {
if (SLTypesGen.isImplicitSLBigNumber(leftNodeValue) && SLTypesGen.isImplicitSLBigNumber(rightNodeValue)) {
return false;
}
return true;
}
public static SLDivNode create(SLExpressionNode leftNode, SLExpressionNode rightNode) {
return new SLDivNodeGen(leftNode, rightNode);
}
}