public final class AMD64MathIntrinsicNode extends UnaryNode implements ArithmeticLIRLowerable
Modifier and Type | Class and Description |
---|---|
static class |
AMD64MathIntrinsicNode.Operation |
Node.ConstantNodeParameter, Node.InjectedNodeParameter, Node.Input, Node.NodeIntrinsic, Node.OptionalInput, Node.Successor, Node.ValueNumberable
Canonicalizable.Binary<T extends Node>, Canonicalizable.BinaryCommutative<T extends Node>, Canonicalizable.Unary<T extends Node>
Modifier and Type | Field and Description |
---|---|
protected AMD64MathIntrinsicNode.Operation |
operation |
static NodeClass<AMD64MathIntrinsicNode> |
TYPE |
NODE_LIST, NOT_ITERABLE, USE_UNSAFE_TO_CLONE, WithAllEdges, WithNoEdges, WithOnlyInputEdges, WithOnlySucessorEdges
Modifier | Constructor and Description |
---|---|
protected |
AMD64MathIntrinsicNode(ValueNode value,
AMD64MathIntrinsicNode.Operation op) |
Modifier and Type | Method and Description |
---|---|
ValueNode |
canonical(CanonicalizerTool tool,
ValueNode forValue)
Similar to
Canonicalizable.canonical(CanonicalizerTool) , except that
implementations should act as if the current input of the node was the given one, i.e.,
they should never look at the inputs via the this pointer. |
static double |
compute(double value,
AMD64MathIntrinsicNode.Operation op) |
static ValueNode |
create(ValueNode value,
AMD64MathIntrinsicNode.Operation op) |
private static double |
doCompute(double value,
AMD64MathIntrinsicNode.Operation op) |
void |
generate(NodeValueMap nodeValueMap,
ArithmeticLIRGenerator lirGen) |
AMD64MathIntrinsicNode.Operation |
operation() |
protected static ValueNode |
tryConstantFold(ValueNode value,
AMD64MathIntrinsicNode.Operation op) |
asNode
asConstant, asJavaConstant, getKind, graph, inferStamp, isAllowedUsageType, isConstant, isConstantPredicate, isNullConstant, setStamp, stamp, updateStamp
acceptInputs, acceptSuccessors, afterClone, assertFalse, assertTrue, cfgPredecessors, cfgSuccessors, clearInputs, clearSuccessors, copyWithInputs, copyWithInputs, equals, fail, formatTo, getDebugProperties, getDebugProperties, getId, getNodeClass, getUsageAt, getUsageCount, hashCode, hasNoUsages, hasUsages, inputs, isAlive, isDeleted, markDeleted, modCount, newIdentityMap, newIdentityMap, newIdentityMap, newMap, newMap, newMap, newSet, newSet, predecessor, pushInputs, removeUsage, replaceAndDelete, replaceAtMatchingUsages, replaceAtPredecessor, replaceAtUsages, replaceAtUsages, replaceAtUsages, replaceFirstInput, replaceFirstSuccessor, safeDelete, simplify, successors, toString, toString, updatePredecessor, updateUsages, updateUsagesInterface, usages, valueEquals, verify, verifyEdges, verifyInputs
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
canonical
public static final NodeClass<AMD64MathIntrinsicNode> TYPE
protected final AMD64MathIntrinsicNode.Operation operation
protected AMD64MathIntrinsicNode(ValueNode value, AMD64MathIntrinsicNode.Operation op)
public AMD64MathIntrinsicNode.Operation operation()
public static ValueNode create(ValueNode value, AMD64MathIntrinsicNode.Operation op)
protected static ValueNode tryConstantFold(ValueNode value, AMD64MathIntrinsicNode.Operation op)
public void generate(NodeValueMap nodeValueMap, ArithmeticLIRGenerator lirGen)
generate
in interface ArithmeticLIRLowerable
public ValueNode canonical(CanonicalizerTool tool, ValueNode forValue)
Canonicalizable.Unary
Canonicalizable.canonical(CanonicalizerTool)
, except that
implementations should act as if the current input of the node was the given one, i.e.,
they should never look at the inputs via the this pointer.canonical
in interface Canonicalizable.Unary<ValueNode>
public static double compute(double value, AMD64MathIntrinsicNode.Operation op)
private static double doCompute(double value, AMD64MathIntrinsicNode.Operation op)