Commit 92903d0a authored by jarin's avatar jarin Committed by Commit bot

[turbofan] Get rid of type lower bounds.

Review URL: https://codereview.chromium.org/1348073002

Cr-Commit-Position: refs/heads/master@{#30764}
parent 1025d34a
......@@ -157,7 +157,7 @@ Reduction ChangeLowering::ChangeFloat64ToTagged(Node* value, Node* control) {
Reduction ChangeLowering::ChangeInt32ToTagged(Node* value, Node* control) {
if (machine()->Is64() ||
NodeProperties::GetBounds(value).upper->Is(Type::SignedSmall())) {
NodeProperties::GetType(value)->Is(Type::SignedSmall())) {
return Replace(ChangeInt32ToSmi(value));
}
......@@ -184,7 +184,7 @@ Reduction ChangeLowering::ChangeInt32ToTagged(Node* value, Node* control) {
Reduction ChangeLowering::ChangeTaggedToUI32(Node* value, Node* control,
Signedness signedness) {
if (NodeProperties::GetBounds(value).upper->Is(Type::TaggedSigned())) {
if (NodeProperties::GetType(value)->Is(Type::TaggedSigned())) {
return Replace(ChangeSmiToInt32(value));
}
......@@ -193,7 +193,7 @@ Reduction ChangeLowering::ChangeTaggedToUI32(Node* value, Node* control,
? machine()->ChangeFloat64ToInt32()
: machine()->ChangeFloat64ToUint32();
if (NodeProperties::GetBounds(value).upper->Is(Type::TaggedPointer())) {
if (NodeProperties::GetType(value)->Is(Type::TaggedPointer())) {
return Replace(graph()->NewNode(op, LoadHeapNumberValue(value, control)));
}
......@@ -312,7 +312,7 @@ Reduction ChangeLowering::ChangeTaggedToFloat64(Node* value, Node* control) {
Reduction ChangeLowering::ChangeUint32ToTagged(Node* value, Node* control) {
if (NodeProperties::GetBounds(value).upper->Is(Type::UnsignedSmall())) {
if (NodeProperties::GetType(value)->Is(Type::UnsignedSmall())) {
return Replace(ChangeUint32ToSmi(value));
}
......
......@@ -127,13 +127,10 @@ class JSONGraphNodeWriter {
os_ << ",\"control\":" << (NodeProperties::IsControl(node) ? "true"
: "false");
if (NodeProperties::IsTyped(node)) {
Bounds bounds = NodeProperties::GetBounds(node);
std::ostringstream upper;
bounds.upper->PrintTo(upper);
std::ostringstream lower;
bounds.lower->PrintTo(lower);
os_ << ",\"upper_type\":\"" << Escaped(upper, "\"") << "\"";
os_ << ",\"lower_type\":\"" << Escaped(lower, "\"") << "\"";
Type* type = NodeProperties::GetType(node);
std::ostringstream type_out;
type->PrintTo(type_out);
os_ << ",\"type\":\"" << Escaped(type_out, "\"") << "\"";
}
os_ << "}";
}
......@@ -302,12 +299,10 @@ void GraphVisualizer::PrintNode(Node* node, bool gray) {
os_ << "}";
if (FLAG_trace_turbo_types && NodeProperties::IsTyped(node)) {
Bounds bounds = NodeProperties::GetBounds(node);
std::ostringstream upper;
bounds.upper->PrintTo(upper);
std::ostringstream lower;
bounds.lower->PrintTo(lower);
os_ << "|" << Escaped(upper) << "|" << Escaped(lower);
Type* type = NodeProperties::GetType(node);
std::ostringstream type_out;
type->PrintTo(type_out);
os_ << "|" << Escaped(type_out);
}
os_ << "}\"\n";
......@@ -545,11 +540,9 @@ void GraphC1Visualizer::PrintInputs(Node* node) {
void GraphC1Visualizer::PrintType(Node* node) {
if (NodeProperties::IsTyped(node)) {
Bounds bounds = NodeProperties::GetBounds(node);
Type* type = NodeProperties::GetType(node);
os_ << " type:";
bounds.upper->PrintTo(os_);
os_ << "..";
bounds.lower->PrintTo(os_);
type->PrintTo(os_);
}
}
......
......@@ -45,20 +45,20 @@ class JSCallReduction {
// Determines whether the call takes one input of the given type.
bool InputsMatchOne(Type* t1) {
return GetJSCallArity() == 1 &&
NodeProperties::GetBounds(GetJSCallInput(0)).upper->Is(t1);
NodeProperties::GetType(GetJSCallInput(0))->Is(t1);
}
// Determines whether the call takes two inputs of the given types.
bool InputsMatchTwo(Type* t1, Type* t2) {
return GetJSCallArity() == 2 &&
NodeProperties::GetBounds(GetJSCallInput(0)).upper->Is(t1) &&
NodeProperties::GetBounds(GetJSCallInput(1)).upper->Is(t2);
NodeProperties::GetType(GetJSCallInput(0))->Is(t1) &&
NodeProperties::GetType(GetJSCallInput(1))->Is(t2);
}
// Determines whether the call takes inputs all of the given type.
bool InputsMatchAll(Type* t) {
for (int i = 0; i < GetJSCallArity(); i++) {
if (!NodeProperties::GetBounds(GetJSCallInput(i)).upper->Is(t)) {
if (!NodeProperties::GetType(GetJSCallInput(i))->Is(t)) {
return false;
}
}
......
......@@ -309,7 +309,7 @@ Reduction JSIntrinsicLowering::ReduceSeqStringSetChar(
node->ReplaceInput(3, effect);
node->ReplaceInput(4, control);
node->TrimInputCount(5);
NodeProperties::RemoveBounds(node);
NodeProperties::RemoveType(node);
ReplaceWithValue(node, string, node);
return Changed(node);
}
......
......@@ -36,7 +36,7 @@ Reduction JSTypeFeedbackLowering::Reduce(Node* node) {
Reduction JSTypeFeedbackLowering::ReduceJSLoadNamed(Node* node) {
DCHECK_EQ(IrOpcode::kJSLoadNamed, node->opcode());
Node* receiver = NodeProperties::GetValueInput(node, 0);
Type* receiver_type = NodeProperties::GetBounds(receiver).upper;
Type* receiver_type = NodeProperties::GetType(receiver);
Node* frame_state = NodeProperties::GetFrameStateInput(node, 1);
Node* effect = NodeProperties::GetEffectInput(node);
Node* control = NodeProperties::GetControlInput(node);
......
......@@ -167,8 +167,8 @@ class JSBinopReduction final {
// TODO(jarin): Replace the explicit typing hack with a call to some method
// that encapsulates changing the operator and re-typing.
Bounds const bounds = NodeProperties::GetBounds(node_);
NodeProperties::SetBounds(node_, Bounds::NarrowUpper(bounds, type, zone()));
Type* node_type = NodeProperties::GetType(node_);
NodeProperties::SetType(node_, Type::Intersect(node_type, type, zone()));
if (invert) {
// Insert an boolean not to invert the value.
......@@ -206,12 +206,8 @@ class JSBinopReduction final {
Node* context() { return NodeProperties::GetContextInput(node_); }
Node* left() { return NodeProperties::GetValueInput(node_, 0); }
Node* right() { return NodeProperties::GetValueInput(node_, 1); }
Type* left_type() {
return NodeProperties::GetBounds(node_->InputAt(0)).upper;
}
Type* right_type() {
return NodeProperties::GetBounds(node_->InputAt(1)).upper;
}
Type* left_type() { return NodeProperties::GetType(node_->InputAt(0)); }
Type* right_type() { return NodeProperties::GetType(node_->InputAt(1)); }
SimplifiedOperatorBuilder* simplified() { return lowering_->simplified(); }
Graph* graph() const { return lowering_->graph(); }
......@@ -305,7 +301,7 @@ class JSBinopReduction final {
}
Node* ConvertPlainPrimitiveToNumber(Node* node) {
DCHECK(NodeProperties::GetBounds(node).upper->Is(Type::PlainPrimitive()));
DCHECK(NodeProperties::GetType(node)->Is(Type::PlainPrimitive()));
// Avoid inserting too many eager ToNumber() operations.
Reduction const reduction = lowering_->ReduceJSToNumberInput(node);
if (reduction.Changed()) return reduction.replacement();
......@@ -316,7 +312,7 @@ class JSBinopReduction final {
}
Node* ConvertSingleInputToNumber(Node* node, Node* frame_state) {
DCHECK(!NodeProperties::GetBounds(node).upper->Is(Type::PlainPrimitive()));
DCHECK(!NodeProperties::GetType(node)->Is(Type::PlainPrimitive()));
Node* const n = graph()->NewNode(javascript()->ToNumber(), node, context(),
frame_state, effect(), control());
NodeProperties::ReplaceUses(node_, node_, node_, n, n);
......@@ -363,7 +359,7 @@ class JSBinopReduction final {
if (NodeProperties::IsEffectEdge(edge)) edge.UpdateTo(exception_effect);
if (NodeProperties::IsValueEdge(edge)) edge.UpdateTo(exception_value);
}
NodeProperties::RemoveBounds(exception_merge);
NodeProperties::RemoveType(exception_merge);
exception_merge->ReplaceInput(0, left_exception);
exception_merge->ReplaceInput(1, right_exception);
exception_merge->set_op(common()->Merge(2));
......@@ -374,7 +370,7 @@ class JSBinopReduction final {
Node* ConvertToUI32(Node* node, Signedness signedness) {
// Avoid introducing too many eager NumberToXXnt32() operations.
Type* type = NodeProperties::GetBounds(node).upper;
Type* type = NodeProperties::GetType(node);
if (signedness == kSigned) {
if (!type->Is(Type::Signed32())) {
node = graph()->NewNode(simplified()->NumberToInt32(), node);
......@@ -630,7 +626,7 @@ Reduction JSTypedLowering::ReduceJSStrictEqual(Node* node, bool invert) {
Reduction JSTypedLowering::ReduceJSUnaryNot(Node* node) {
Node* const input = node->InputAt(0);
Type* const input_type = NodeProperties::GetBounds(input).upper;
Type* const input_type = NodeProperties::GetType(input);
if (input_type->Is(Type::Boolean())) {
// JSUnaryNot(x:boolean) => BooleanNot(x)
node->set_op(simplified()->BooleanNot());
......@@ -662,7 +658,7 @@ Reduction JSTypedLowering::ReduceJSUnaryNot(Node* node) {
Reduction JSTypedLowering::ReduceJSToBoolean(Node* node) {
Node* const input = node->InputAt(0);
Type* const input_type = NodeProperties::GetBounds(input).upper;
Type* const input_type = NodeProperties::GetType(input);
if (input_type->Is(Type::Boolean())) {
// JSToBoolean(x:boolean) => x
return Replace(input);
......@@ -698,7 +694,7 @@ Reduction JSTypedLowering::ReduceJSToNumberInput(Node* input) {
return Changed(input); // JSToNumber(JSToNumber(x)) => JSToNumber(x)
}
// Check if we have a cached conversion.
Type* input_type = NodeProperties::GetBounds(input).upper;
Type* input_type = NodeProperties::GetType(input);
if (input_type->Is(Type::Number())) {
// JSToNumber(x:number) => x
return Changed(input);
......@@ -728,7 +724,7 @@ Reduction JSTypedLowering::ReduceJSToNumber(Node* node) {
ReplaceWithValue(node, reduction.replacement());
return reduction;
}
Type* const input_type = NodeProperties::GetBounds(input).upper;
Type* const input_type = NodeProperties::GetType(input);
if (input_type->Is(Type::PlainPrimitive())) {
if (NodeProperties::GetContextInput(node) !=
jsgraph()->NoContextConstant() ||
......@@ -757,7 +753,7 @@ Reduction JSTypedLowering::ReduceJSToStringInput(Node* input) {
if (result.Changed()) return result;
return Changed(input); // JSToString(JSToString(x)) => JSToString(x)
}
Type* input_type = NodeProperties::GetBounds(input).upper;
Type* input_type = NodeProperties::GetType(input);
if (input_type->Is(Type::String())) {
return Changed(input); // JSToString(x:string) => x
}
......@@ -801,7 +797,7 @@ Reduction JSTypedLowering::ReduceJSLoadGlobal(Node* node) {
Reduction JSTypedLowering::ReduceJSLoadNamed(Node* node) {
DCHECK_EQ(IrOpcode::kJSLoadNamed, node->opcode());
Node* receiver = NodeProperties::GetValueInput(node, 0);
Type* receiver_type = NodeProperties::GetBounds(receiver).upper;
Type* receiver_type = NodeProperties::GetType(receiver);
Node* effect = NodeProperties::GetEffectInput(node);
Node* control = NodeProperties::GetControlInput(node);
Handle<Name> name = LoadNamedParametersOf(node->op()).name();
......@@ -822,7 +818,7 @@ Reduction JSTypedLowering::ReduceJSLoadNamed(Node* node) {
Reduction JSTypedLowering::ReduceJSLoadProperty(Node* node) {
Node* key = NodeProperties::GetValueInput(node, 1);
Node* base = NodeProperties::GetValueInput(node, 0);
Type* key_type = NodeProperties::GetBounds(key).upper;
Type* key_type = NodeProperties::GetType(key);
HeapObjectMatcher mbase(base);
if (mbase.HasValue() && mbase.Value()->IsJSTypedArray()) {
Handle<JSTypedArray> const array =
......@@ -867,8 +863,8 @@ Reduction JSTypedLowering::ReduceJSStoreProperty(Node* node) {
Node* key = NodeProperties::GetValueInput(node, 1);
Node* base = NodeProperties::GetValueInput(node, 0);
Node* value = NodeProperties::GetValueInput(node, 2);
Type* key_type = NodeProperties::GetBounds(key).upper;
Type* value_type = NodeProperties::GetBounds(value).upper;
Type* key_type = NodeProperties::GetType(key);
Type* value_type = NodeProperties::GetType(value);
HeapObjectMatcher mbase(base);
if (mbase.HasValue() && mbase.Value()->IsJSTypedArray()) {
Handle<JSTypedArray> const array =
......@@ -1190,7 +1186,7 @@ Reduction JSTypedLowering::ReduceJSCreateLiteralObject(Node* node) {
Reduction JSTypedLowering::ReduceJSCreateWithContext(Node* node) {
DCHECK_EQ(IrOpcode::kJSCreateWithContext, node->opcode());
Node* const input = NodeProperties::GetValueInput(node, 0);
Type* input_type = NodeProperties::GetBounds(input).upper;
Type* input_type = NodeProperties::GetType(input);
if (FLAG_turbo_allocate && input_type->Is(Type::Receiver())) {
// JSCreateWithContext(o:receiver, f)
Node* const effect = NodeProperties::GetEffectInput(node);
......@@ -1209,7 +1205,7 @@ Reduction JSTypedLowering::ReduceJSCreateWithContext(Node* node) {
a.Store(AccessBuilder::ForContextSlot(Context::EXTENSION_INDEX), input);
a.Store(AccessBuilder::ForContextSlot(Context::GLOBAL_OBJECT_INDEX), load);
// TODO(mstarzinger): We could mutate {node} into the allocation instead.
NodeProperties::SetBounds(a.allocation(), NodeProperties::GetBounds(node));
NodeProperties::SetType(a.allocation(), NodeProperties::GetType(node));
ReplaceWithValue(node, node, a.effect());
node->ReplaceInput(0, a.allocation());
node->ReplaceInput(1, a.effect());
......@@ -1248,7 +1244,7 @@ Reduction JSTypedLowering::ReduceJSCreateBlockContext(Node* node) {
a.Store(AccessBuilder::ForContextSlot(i), jsgraph()->TheHoleConstant());
}
// TODO(mstarzinger): We could mutate {node} into the allocation instead.
NodeProperties::SetBounds(a.allocation(), NodeProperties::GetBounds(node));
NodeProperties::SetType(a.allocation(), NodeProperties::GetType(node));
ReplaceWithValue(node, node, a.effect());
node->ReplaceInput(0, a.allocation());
node->ReplaceInput(1, a.effect());
......@@ -1265,9 +1261,9 @@ Reduction JSTypedLowering::ReduceJSCallFunction(Node* node) {
CallFunctionParameters const& p = CallFunctionParametersOf(node->op());
int const arity = static_cast<int>(p.arity() - 2);
Node* const function = NodeProperties::GetValueInput(node, 0);
Type* const function_type = NodeProperties::GetBounds(function).upper;
Type* const function_type = NodeProperties::GetType(function);
Node* const receiver = NodeProperties::GetValueInput(node, 1);
Type* const receiver_type = NodeProperties::GetBounds(receiver).upper;
Type* const receiver_type = NodeProperties::GetType(receiver);
Node* const effect = NodeProperties::GetEffectInput(node);
Node* const control = NodeProperties::GetControlInput(node);
......@@ -1567,7 +1563,7 @@ Reduction JSTypedLowering::Reduce(Node* node) {
// result value and can simply replace the node if it's eliminable.
if (!NodeProperties::IsConstant(node) && NodeProperties::IsTyped(node) &&
node->op()->HasProperty(Operator::kEliminatable)) {
Type* upper = NodeProperties::GetBounds(node).upper;
Type* upper = NodeProperties::GetType(node);
if (upper->IsConstant()) {
Node* replacement = jsgraph()->Constant(upper->AsConstant()->Value());
ReplaceWithValue(node, replacement);
......
......@@ -108,23 +108,18 @@ class NodeProperties final {
// ---------------------------------------------------------------------------
// Type Bounds.
// Type.
static bool IsTyped(Node* node) {
Bounds const bounds = node->bounds();
DCHECK(!bounds.lower == !bounds.upper);
return bounds.upper;
}
static Bounds GetBounds(Node* node) {
static bool IsTyped(Node* node) { return node->type() != nullptr; }
static Type* GetType(Node* node) {
DCHECK(IsTyped(node));
return node->bounds();
return node->type();
}
static void SetBounds(Node* node, Bounds bounds) {
DCHECK_NOT_NULL(bounds.lower);
DCHECK_NOT_NULL(bounds.upper);
node->set_bounds(bounds);
static void SetType(Node* node, Type* type) {
DCHECK_NOT_NULL(type);
node->set_type(type);
}
static void RemoveBounds(Node* node) { node->set_bounds(Bounds()); }
static void RemoveType(Node* node) { node->set_type(nullptr); }
static bool AllValueInputsAreTyped(Node* node);
private:
......
......@@ -112,7 +112,7 @@ Node* Node::Clone(Zone* zone, NodeId id, const Node* node) {
? node->inputs_.inline_
: node->inputs_.outline_->inputs_;
Node* const clone = New(zone, id, node->op(), input_count, inputs, false);
clone->set_bounds(node->bounds());
clone->set_type(node->type());
return clone;
}
......@@ -273,6 +273,7 @@ bool Node::OwnedBy(Node const* owner1, Node const* owner2) const {
Node::Node(NodeId id, const Operator* op, int inline_count, int inline_capacity)
: op_(op),
type_(nullptr),
mark_(0),
bit_field_(IdField::encode(id) | InlineCountField::encode(inline_count) |
InlineCapacityField::encode(inline_capacity)),
......
......@@ -284,9 +284,9 @@ class Node final {
void* operator new(size_t, void* location) { return location; }
// Only NodeProperties should manipulate the bounds.
Bounds bounds() const { return bounds_; }
void set_bounds(Bounds b) { bounds_ = b; }
// Only NodeProperties should manipulate the type.
Type* type() const { return type_; }
void set_type(Type* type) { type_ = type; }
// Only NodeMarkers should manipulate the marks on nodes.
Mark mark() { return mark_; }
......@@ -306,7 +306,7 @@ class Node final {
static const int kMaxInlineCapacity = InlineCapacityField::kMax - 1;
const Operator* op_;
Bounds bounds_;
Type* type_;
Mark mark_;
uint32_t bit_field_;
Use* first_use_;
......
......@@ -99,7 +99,7 @@ static void PeelOuterLoopsForOsr(Graph* graph, CommonOperatorBuilder* common,
}
copy = graph->NewNode(orig->op(), orig->InputCount(), &tmp_inputs[0]);
if (NodeProperties::IsTyped(orig)) {
NodeProperties::SetBounds(copy, NodeProperties::GetBounds(orig));
NodeProperties::SetType(copy, NodeProperties::GetType(orig));
}
mapping->at(orig->id()) = copy;
TRACE(" copy #%d:%s -> #%d\n", orig->id(), orig->op()->mnemonic(),
......
......@@ -30,7 +30,9 @@ class RepresentationChanger {
type_error_(false) {}
// TODO(titzer): should Word64 also be implicitly convertable to others?
static const MachineTypeUnion rWord = kRepWord8 | kRepWord16 | kRepWord32;
static bool IsWord(MachineTypeUnion type) {
return (type & (kRepWord8 | kRepWord16 | kRepWord32)) != 0;
}
Node* GetRepresentationFor(Node* node, MachineTypeUnion output_type,
MachineTypeUnion use_type) {
......@@ -42,7 +44,7 @@ class RepresentationChanger {
// Representations are the same. That's a no-op.
return node;
}
if ((use_type & rWord) && (output_type & rWord)) {
if (IsWord(use_type) && IsWord(output_type)) {
// Both are words less than or equal to 32-bits.
// Since loads of integers from memory implicitly sign or zero extend the
// value to the full machine word size and stores implicitly truncate,
......@@ -57,7 +59,7 @@ class RepresentationChanger {
return GetFloat64RepresentationFor(node, output_type);
} else if (use_type & kRepBit) {
return GetBitRepresentationFor(node, output_type);
} else if (use_type & rWord) {
} else if (IsWord(use_type)) {
return GetWord32RepresentationFor(node, output_type,
use_type & kTypeUint32);
} else if (use_type & kRepWord64) {
......@@ -97,7 +99,7 @@ class RepresentationChanger {
const Operator* op;
if (output_type & kRepBit) {
op = simplified()->ChangeBitToBool();
} else if (output_type & rWord) {
} else if (IsWord(output_type)) {
if (output_type & kTypeUint32) {
op = simplified()->ChangeUint32ToTagged();
} else if (output_type & kTypeInt32) {
......@@ -140,7 +142,7 @@ class RepresentationChanger {
const Operator* op;
if (output_type & kRepBit) {
return TypeError(node, output_type, kRepFloat32);
} else if (output_type & rWord) {
} else if (IsWord(output_type)) {
if (output_type & kTypeUint32) {
op = machine()->ChangeUint32ToFloat64();
} else {
......@@ -186,7 +188,7 @@ class RepresentationChanger {
const Operator* op;
if (output_type & kRepBit) {
return TypeError(node, output_type, kRepFloat64);
} else if (output_type & rWord) {
} else if (IsWord(output_type)) {
if (output_type & kTypeUint32) {
op = machine()->ChangeUint32ToFloat64();
} else {
......
......@@ -345,13 +345,9 @@ std::ostream& operator<<(std::ostream& os, const Schedule& s) {
for (Node* node : *block) {
os << " " << *node;
if (NodeProperties::IsTyped(node)) {
Bounds bounds = NodeProperties::GetBounds(node);
Type* type = NodeProperties::GetType(node);
os << " : ";
bounds.lower->PrintTo(os);
if (!bounds.upper->Is(bounds.lower)) {
os << "..";
bounds.upper->PrintTo(os);
}
type->PrintTo(os);
}
os << "\n";
}
......
......@@ -178,8 +178,8 @@ class RepresentationSelector {
bool BothInputsAre(Node* node, Type* type) {
DCHECK_EQ(2, node->InputCount());
return NodeProperties::GetBounds(node->InputAt(0)).upper->Is(type) &&
NodeProperties::GetBounds(node->InputAt(1)).upper->Is(type);
return NodeProperties::GetType(node->InputAt(0))->Is(type) &&
NodeProperties::GetType(node->InputAt(1))->Is(type);
}
void ProcessTruncateWord32Input(Node* node, int index, MachineTypeUnion use) {
......@@ -313,7 +313,7 @@ class RepresentationSelector {
// Infer representation for phi-like nodes.
MachineType GetRepresentationForPhi(Node* node, MachineTypeUnion use) {
// Phis adapt to the output representation their uses demand.
Type* upper = NodeProperties::GetBounds(node).upper;
Type* upper = NodeProperties::GetType(node);
if ((use & kRepMask) == kRepFloat32) {
// only float32 uses.
return kRepFloat32;
......@@ -355,7 +355,7 @@ class RepresentationSelector {
ProcessInput(node, 0, kRepBit);
MachineType output = GetRepresentationForPhi(node, use);
Type* upper = NodeProperties::GetBounds(node).upper;
Type* upper = NodeProperties::GetType(node);
MachineType output_type =
static_cast<MachineType>(changer_->TypeFromUpperBound(upper) | output);
SetOutput(node, output_type);
......@@ -385,7 +385,7 @@ class RepresentationSelector {
SimplifiedLowering* lowering) {
MachineType output = GetRepresentationForPhi(node, use);
Type* upper = NodeProperties::GetBounds(node).upper;
Type* upper = NodeProperties::GetType(node);
MachineType output_type =
static_cast<MachineType>(changer_->TypeFromUpperBound(upper) | output);
SetOutput(node, output_type);
......@@ -470,7 +470,7 @@ class RepresentationSelector {
bool CanLowerToInt32Binop(Node* node, MachineTypeUnion use) {
return BothInputsAre(node, Type::Signed32()) &&
(!CanObserveNonInt32(use) ||
NodeProperties::GetBounds(node).upper->Is(Type::Signed32()));
NodeProperties::GetType(node)->Is(Type::Signed32()));
}
bool CanLowerToInt32AdditiveBinop(Node* node, MachineTypeUnion use) {
......@@ -481,7 +481,7 @@ class RepresentationSelector {
bool CanLowerToUint32Binop(Node* node, MachineTypeUnion use) {
return BothInputsAre(node, Type::Unsigned32()) &&
(!CanObserveNonUint32(use) ||
NodeProperties::GetBounds(node).upper->Is(Type::Unsigned32()));
NodeProperties::GetType(node)->Is(Type::Unsigned32()));
}
bool CanLowerToUint32AdditiveBinop(Node* node, MachineTypeUnion use) {
......@@ -523,7 +523,7 @@ class RepresentationSelector {
return VisitLeaf(node, 0);
case IrOpcode::kParameter: {
// TODO(titzer): use representation from linkage.
Type* upper = NodeProperties::GetBounds(node).upper;
Type* upper = NodeProperties::GetType(node);
ProcessInput(node, 0, 0);
SetOutput(node, kRepTagged | changer_->TypeFromUpperBound(upper));
return;
......@@ -731,7 +731,7 @@ class RepresentationSelector {
case IrOpcode::kNumberToInt32: {
MachineTypeUnion use_rep = use & kRepMask;
Node* input = node->InputAt(0);
Type* in_upper = NodeProperties::GetBounds(input).upper;
Type* in_upper = NodeProperties::GetType(input);
MachineTypeUnion in = GetInfo(input)->output;
if (in_upper->Is(Type::Signed32())) {
// If the input has type int32, pass through representation.
......@@ -761,7 +761,7 @@ class RepresentationSelector {
case IrOpcode::kNumberToUint32: {
MachineTypeUnion use_rep = use & kRepMask;
Node* input = node->InputAt(0);
Type* in_upper = NodeProperties::GetBounds(input).upper;
Type* in_upper = NodeProperties::GetType(input);
MachineTypeUnion in = GetInfo(input)->output;
if (in_upper->Is(Type::Unsigned32())) {
// If the input has type uint32, pass through representation.
......@@ -1228,7 +1228,7 @@ void SimplifiedLowering::DoLoadField(Node* node) {
void SimplifiedLowering::DoStoreField(Node* node) {
const FieldAccess& access = FieldAccessOf(node->op());
Type* type = NodeProperties::GetBounds(node->InputAt(1)).upper;
Type* type = NodeProperties::GetType(node->InputAt(1));
WriteBarrierKind kind =
ComputeWriteBarrierKind(access.base_is_tagged, access.machine_type, type);
node->set_op(
......@@ -1335,7 +1335,7 @@ void SimplifiedLowering::DoLoadElement(Node* node) {
void SimplifiedLowering::DoStoreElement(Node* node) {
const ElementAccess& access = ElementAccessOf(node->op());
Type* type = NodeProperties::GetBounds(node->InputAt(2)).upper;
Type* type = NodeProperties::GetType(node->InputAt(2));
node->set_op(machine()->Store(
StoreRepresentation(access.machine_type,
ComputeWriteBarrierKind(access.base_is_tagged,
......@@ -1614,7 +1614,7 @@ Node* SimplifiedLowering::Uint32Mod(Node* const node) {
void SimplifiedLowering::DoShift(Node* node, Operator const* op) {
node->set_op(op);
Node* const rhs = NodeProperties::GetValueInput(node, 1);
Type* const rhs_type = NodeProperties::GetBounds(rhs).upper;
Type* const rhs_type = NodeProperties::GetType(rhs);
if (!rhs_type->Is(zero_thirtyone_range_)) {
node->ReplaceInput(1, graph()->NewNode(machine()->Word32And(), rhs,
jsgraph()->Int32Constant(0x1f)));
......
......@@ -87,13 +87,13 @@ class Typer::Visitor : public Reducer {
switch (node->opcode()) {
#define DECLARE_CASE(x) \
case IrOpcode::k##x: \
return UpdateBounds(node, TypeBinaryOp(node, x##Typer));
return UpdateType(node, TypeBinaryOp(node, x##Typer));
JS_SIMPLE_BINOP_LIST(DECLARE_CASE)
#undef DECLARE_CASE
#define DECLARE_CASE(x) \
case IrOpcode::k##x: \
return UpdateBounds(node, Type##x(node));
return UpdateType(node, Type##x(node));
DECLARE_CASE(Start)
DECLARE_CASE(IfException)
// VALUE_OP_LIST without JS_SIMPLE_BINOP_LIST:
......@@ -130,7 +130,7 @@ class Typer::Visitor : public Reducer {
return NoChange();
}
Bounds TypeNode(Node* node) {
Type* TypeNode(Node* node) {
switch (node->opcode()) {
#define DECLARE_CASE(x) \
case IrOpcode::k##x: return TypeBinaryOp(node, x##Typer);
......@@ -172,7 +172,7 @@ class Typer::Visitor : public Reducer {
break;
}
UNREACHABLE();
return Bounds();
return nullptr;
}
Type* TypeConstant(Handle<Object> value);
......@@ -181,23 +181,23 @@ class Typer::Visitor : public Reducer {
Typer* typer_;
ZoneSet<NodeId> weakened_nodes_;
#define DECLARE_METHOD(x) inline Bounds Type##x(Node* node);
#define DECLARE_METHOD(x) inline Type* Type##x(Node* node);
DECLARE_METHOD(Start)
DECLARE_METHOD(IfException)
VALUE_OP_LIST(DECLARE_METHOD)
#undef DECLARE_METHOD
Bounds BoundsOrNone(Node* node) {
return NodeProperties::IsTyped(node) ? NodeProperties::GetBounds(node)
: Bounds(Type::None());
Type* TypeOrNone(Node* node) {
return NodeProperties::IsTyped(node) ? NodeProperties::GetType(node)
: Type::None();
}
Bounds Operand(Node* node, int i) {
Type* Operand(Node* node, int i) {
Node* operand_node = NodeProperties::GetValueInput(node, i);
return BoundsOrNone(operand_node);
return TypeOrNone(operand_node);
}
Bounds WrapContextBoundsForInput(Node* node);
Type* WrapContextTypeForInput(Node* node);
Type* Weaken(Node* node, Type* current_type, Type* previous_type);
Zone* zone() { return typer_->zone(); }
......@@ -212,8 +212,8 @@ class Typer::Visitor : public Reducer {
typedef Type* (*UnaryTyperFun)(Type*, Typer* t);
typedef Type* (*BinaryTyperFun)(Type*, Type*, Typer* t);
Bounds TypeUnaryOp(Node* node, UnaryTyperFun);
Bounds TypeBinaryOp(Node* node, BinaryTyperFun);
Type* TypeUnaryOp(Node* node, UnaryTyperFun);
Type* TypeBinaryOp(Node* node, BinaryTyperFun);
enum ComparisonOutcomeFlags {
kComparisonTrue = 1,
......@@ -251,28 +251,26 @@ class Typer::Visitor : public Reducer {
static Type* JSLoadPropertyTyper(Type*, Type*, Typer*);
static Type* JSCallFunctionTyper(Type*, Typer*);
Reduction UpdateBounds(Node* node, Bounds current) {
Reduction UpdateType(Node* node, Type* current) {
if (NodeProperties::IsTyped(node)) {
// Widen the bounds of a previously typed node.
Bounds previous = NodeProperties::GetBounds(node);
// Widen the type of a previously typed node.
Type* previous = NodeProperties::GetType(node);
if (node->opcode() == IrOpcode::kPhi) {
// Speed up termination in the presence of range types:
current.upper = Weaken(node, current.upper, previous.upper);
current.lower = Weaken(node, current.lower, previous.lower);
current = Weaken(node, current, previous);
}
DCHECK(previous.lower->Is(current.lower));
DCHECK(previous.upper->Is(current.upper));
DCHECK(previous->Is(current));
NodeProperties::SetBounds(node, current);
if (!(previous.Narrows(current) && current.Narrows(previous))) {
NodeProperties::SetType(node, current);
if (!(previous->Is(current) && current->Is(previous))) {
// If something changed, revisit all uses.
return Changed(node);
}
return NoChange();
} else {
// No previous type, simply update the bounds.
NodeProperties::SetBounds(node, current);
// No previous type, simply update the type.
NodeProperties::SetType(node, current);
return Changed(node);
}
}
......@@ -298,12 +296,12 @@ void Typer::Decorator::Decorate(Node* node) {
bool is_typed = NodeProperties::IsTyped(node);
if (is_typed || NodeProperties::AllValueInputsAreTyped(node)) {
Visitor typing(typer_);
Bounds bounds = typing.TypeNode(node);
Type* type = typing.TypeNode(node);
if (is_typed) {
bounds =
Bounds::Both(bounds, NodeProperties::GetBounds(node), typer_->zone());
type = Type::Intersect(type, NodeProperties::GetType(node),
typer_->zone());
}
NodeProperties::SetBounds(node, bounds);
NodeProperties::SetType(node, type);
}
}
}
......@@ -316,36 +314,17 @@ void Typer::Decorator::Decorate(Node* node) {
// as an argument.
Bounds Typer::Visitor::TypeUnaryOp(Node* node, UnaryTyperFun f) {
Bounds input = Operand(node, 0);
Type* upper =
input.upper->IsInhabited() ? f(input.upper, typer_) : Type::None();
Type* lower = input.lower->IsInhabited()
? ((input.lower == input.upper || upper->IsConstant())
? upper // TODO(neis): Extend this to Range(x,x),
// NaN, MinusZero, ...?
: f(input.lower, typer_))
: Type::None();
// TODO(neis): Figure out what to do with lower bound.
return Bounds(lower, upper);
Type* Typer::Visitor::TypeUnaryOp(Node* node, UnaryTyperFun f) {
Type* input = Operand(node, 0);
return input->IsInhabited() ? f(input, typer_) : Type::None();
}
Bounds Typer::Visitor::TypeBinaryOp(Node* node, BinaryTyperFun f) {
Bounds left = Operand(node, 0);
Bounds right = Operand(node, 1);
Type* upper = left.upper->IsInhabited() && right.upper->IsInhabited()
? f(left.upper, right.upper, typer_)
: Type::None();
Type* lower =
left.lower->IsInhabited() && right.lower->IsInhabited()
? (((left.lower == left.upper && right.lower == right.upper) ||
upper->IsConstant())
? upper
: f(left.lower, right.lower, typer_))
Type* Typer::Visitor::TypeBinaryOp(Node* node, BinaryTyperFun f) {
Type* left = Operand(node, 0);
Type* right = Operand(node, 1);
return left->IsInhabited() && right->IsInhabited() ? f(left, right, typer_)
: Type::None();
// TODO(neis): Figure out what to do with lower bound.
return Bounds(lower, upper);
}
......@@ -479,150 +458,136 @@ Type* Typer::Visitor::NumberToUint32(Type* type, Typer* t) {
// Control operators.
Bounds Typer::Visitor::TypeStart(Node* node) {
return Bounds(Type::None(zone()), Type::Internal(zone()));
}
Type* Typer::Visitor::TypeStart(Node* node) { return Type::Internal(zone()); }
Bounds Typer::Visitor::TypeIfException(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeIfException(Node* node) { return Type::Any(); }
// Common operators.
Bounds Typer::Visitor::TypeParameter(Node* node) {
Type* Typer::Visitor::TypeParameter(Node* node) {
if (Type::FunctionType* function_type = typer_->function_type()) {
int const index = ParameterIndexOf(node->op());
if (index >= 0 && index < function_type->Arity()) {
return Bounds(Type::None(), function_type->Parameter(index));
return function_type->Parameter(index);
}
}
return Bounds::Unbounded();
return Type::Any();
}
Bounds Typer::Visitor::TypeOsrValue(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeOsrValue(Node* node) { return Type::Any(); }
Bounds Typer::Visitor::TypeInt32Constant(Node* node) {
Type* Typer::Visitor::TypeInt32Constant(Node* node) {
double number = OpParameter<int32_t>(node);
return Bounds(Type::Intersect(
Type::Range(number, number, zone()), Type::UntaggedSigned32(), zone()));
return Type::Intersect(Type::Range(number, number, zone()),
Type::UntaggedSigned32(), zone());
}
Bounds Typer::Visitor::TypeInt64Constant(Node* node) {
Type* Typer::Visitor::TypeInt64Constant(Node* node) {
// TODO(rossberg): This actually seems to be a PointerConstant so far...
return Bounds(Type::Internal()); // TODO(rossberg): Add int64 bitset type?
return Type::Internal(); // TODO(rossberg): Add int64 bitset type?
}
Bounds Typer::Visitor::TypeFloat32Constant(Node* node) {
return Bounds(Type::Intersect(
Type::Of(OpParameter<float>(node), zone()),
Type::UntaggedFloat32(), zone()));
Type* Typer::Visitor::TypeFloat32Constant(Node* node) {
return Type::Intersect(Type::Of(OpParameter<float>(node), zone()),
Type::UntaggedFloat32(), zone());
}
Bounds Typer::Visitor::TypeFloat64Constant(Node* node) {
return Bounds(Type::Intersect(
Type::Of(OpParameter<double>(node), zone()),
Type::UntaggedFloat64(), zone()));
Type* Typer::Visitor::TypeFloat64Constant(Node* node) {
return Type::Intersect(Type::Of(OpParameter<double>(node), zone()),
Type::UntaggedFloat64(), zone());
}
Bounds Typer::Visitor::TypeNumberConstant(Node* node) {
Type* Typer::Visitor::TypeNumberConstant(Node* node) {
Factory* f = isolate()->factory();
double number = OpParameter<double>(node);
if (Type::IsInteger(number)) {
return Bounds(Type::Range(number, number, zone()));
return Type::Range(number, number, zone());
}
return Bounds(Type::Constant(f->NewNumber(number), zone()));
return Type::Constant(f->NewNumber(number), zone());
}
Bounds Typer::Visitor::TypeHeapConstant(Node* node) {
return Bounds(TypeConstant(OpParameter<Handle<HeapObject>>(node)));
Type* Typer::Visitor::TypeHeapConstant(Node* node) {
return TypeConstant(OpParameter<Handle<HeapObject>>(node));
}
Bounds Typer::Visitor::TypeExternalConstant(Node* node) {
return Bounds(Type::None(zone()), Type::Internal(zone()));
Type* Typer::Visitor::TypeExternalConstant(Node* node) {
return Type::Internal(zone());
}
Bounds Typer::Visitor::TypeSelect(Node* node) {
return Bounds::Either(Operand(node, 1), Operand(node, 2), zone());
Type* Typer::Visitor::TypeSelect(Node* node) {
return Type::Union(Operand(node, 1), Operand(node, 2), zone());
}
Bounds Typer::Visitor::TypePhi(Node* node) {
Type* Typer::Visitor::TypePhi(Node* node) {
int arity = node->op()->ValueInputCount();
Bounds bounds = Operand(node, 0);
Type* type = Operand(node, 0);
for (int i = 1; i < arity; ++i) {
bounds = Bounds::Either(bounds, Operand(node, i), zone());
type = Type::Union(type, Operand(node, i), zone());
}
return bounds;
return type;
}
Bounds Typer::Visitor::TypeEffectPhi(Node* node) {
Type* Typer::Visitor::TypeEffectPhi(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeEffectSet(Node* node) {
Type* Typer::Visitor::TypeEffectSet(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeValueEffect(Node* node) {
Type* Typer::Visitor::TypeValueEffect(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeFinish(Node* node) {
return Operand(node, 0);
}
Type* Typer::Visitor::TypeFinish(Node* node) { return Operand(node, 0); }
Bounds Typer::Visitor::TypeFrameState(Node* node) {
Type* Typer::Visitor::TypeFrameState(Node* node) {
// TODO(rossberg): Ideally FrameState wouldn't have a value output.
return Bounds(Type::None(zone()), Type::Internal(zone()));
return Type::Internal(zone());
}
Bounds Typer::Visitor::TypeStateValues(Node* node) {
return Bounds(Type::None(zone()), Type::Internal(zone()));
Type* Typer::Visitor::TypeStateValues(Node* node) {
return Type::Internal(zone());
}
Bounds Typer::Visitor::TypeTypedStateValues(Node* node) {
return Bounds(Type::None(zone()), Type::Internal(zone()));
Type* Typer::Visitor::TypeTypedStateValues(Node* node) {
return Type::Internal(zone());
}
Bounds Typer::Visitor::TypeCall(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeCall(Node* node) { return Type::Any(); }
Bounds Typer::Visitor::TypeProjection(Node* node) {
Type* Typer::Visitor::TypeProjection(Node* node) {
// TODO(titzer): use the output type of the input to determine the bounds.
return Bounds::Unbounded();
return Type::Any();
}
Bounds Typer::Visitor::TypeDead(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeDead(Node* node) { return Type::Any(); }
// JS comparison operators.
......@@ -1115,7 +1080,7 @@ Type* Typer::Visitor::JSUnaryNotTyper(Type* type, Typer* t) {
}
Bounds Typer::Visitor::TypeJSUnaryNot(Node* node) {
Type* Typer::Visitor::TypeJSUnaryNot(Node* node) {
return TypeUnaryOp(node, JSUnaryNotTyper);
}
......@@ -1138,7 +1103,7 @@ Type* Typer::Visitor::JSTypeOfTyper(Type* type, Typer* t) {
}
Bounds Typer::Visitor::TypeJSTypeOf(Node* node) {
Type* Typer::Visitor::TypeJSTypeOf(Node* node) {
return TypeUnaryOp(node, JSTypeOfTyper);
}
......@@ -1146,56 +1111,50 @@ Bounds Typer::Visitor::TypeJSTypeOf(Node* node) {
// JS conversion operators.
Bounds Typer::Visitor::TypeJSToBoolean(Node* node) {
Type* Typer::Visitor::TypeJSToBoolean(Node* node) {
return TypeUnaryOp(node, ToBoolean);
}
Bounds Typer::Visitor::TypeJSToNumber(Node* node) {
Type* Typer::Visitor::TypeJSToNumber(Node* node) {
return TypeUnaryOp(node, ToNumber);
}
Bounds Typer::Visitor::TypeJSToString(Node* node) {
Type* Typer::Visitor::TypeJSToString(Node* node) {
return TypeUnaryOp(node, ToString);
}
Bounds Typer::Visitor::TypeJSToName(Node* node) {
return Bounds(Type::None(), Type::Name());
}
Type* Typer::Visitor::TypeJSToName(Node* node) { return Type::Name(); }
Bounds Typer::Visitor::TypeJSToObject(Node* node) {
return Bounds(Type::None(), Type::Receiver());
}
Type* Typer::Visitor::TypeJSToObject(Node* node) { return Type::Receiver(); }
// JS object operators.
Bounds Typer::Visitor::TypeJSCreate(Node* node) {
return Bounds(Type::None(), Type::Object());
}
Type* Typer::Visitor::TypeJSCreate(Node* node) { return Type::Object(); }
Bounds Typer::Visitor::TypeJSCreateArguments(Node* node) {
return Bounds(Type::None(), Type::OtherObject());
Type* Typer::Visitor::TypeJSCreateArguments(Node* node) {
return Type::OtherObject();
}
Bounds Typer::Visitor::TypeJSCreateClosure(Node* node) {
return Bounds(Type::None(), Type::OtherObject());
Type* Typer::Visitor::TypeJSCreateClosure(Node* node) {
return Type::OtherObject();
}
Bounds Typer::Visitor::TypeJSCreateLiteralArray(Node* node) {
return Bounds(Type::None(), Type::OtherObject());
Type* Typer::Visitor::TypeJSCreateLiteralArray(Node* node) {
return Type::None(), Type::OtherObject();
}
Bounds Typer::Visitor::TypeJSCreateLiteralObject(Node* node) {
return Bounds(Type::None(), Type::OtherObject());
Type* Typer::Visitor::TypeJSCreateLiteralObject(Node* node) {
return Type::OtherObject();
}
......@@ -1209,19 +1168,15 @@ Type* Typer::Visitor::JSLoadPropertyTyper(Type* object, Type* name, Typer* t) {
}
Bounds Typer::Visitor::TypeJSLoadProperty(Node* node) {
Type* Typer::Visitor::TypeJSLoadProperty(Node* node) {
return TypeBinaryOp(node, JSLoadPropertyTyper);
}
Bounds Typer::Visitor::TypeJSLoadNamed(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeJSLoadNamed(Node* node) { return Type::Any(); }
Bounds Typer::Visitor::TypeJSLoadGlobal(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeJSLoadGlobal(Node* node) { return Type::Any(); }
// Returns a somewhat larger range if we previously assigned
......@@ -1305,150 +1260,114 @@ Type* Typer::Visitor::Weaken(Node* node, Type* current_type,
}
Bounds Typer::Visitor::TypeJSStoreProperty(Node* node) {
Type* Typer::Visitor::TypeJSStoreProperty(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeJSStoreNamed(Node* node) {
Type* Typer::Visitor::TypeJSStoreNamed(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeJSStoreGlobal(Node* node) {
Type* Typer::Visitor::TypeJSStoreGlobal(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeJSDeleteProperty(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeJSDeleteProperty(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeJSHasProperty(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeJSHasProperty(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeJSInstanceOf(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeJSInstanceOf(Node* node) {
return Type::Boolean(zone());
}
// JS context operators.
Bounds Typer::Visitor::TypeJSLoadContext(Node* node) {
ContextAccess access = OpParameter<ContextAccess>(node);
Bounds outer = Operand(node, 0);
Type* context_type = outer.upper;
if (context_type->Is(Type::None())) {
// Upper bound of context is not yet known.
return Bounds(Type::None(), Type::Any());
}
DCHECK(context_type->Maybe(Type::Internal()));
// TODO(rossberg): More precisely, instead of the above assertion, we should
// back-propagate the constraint that it has to be a subtype of Internal.
MaybeHandle<Context> context;
if (context_type->IsConstant()) {
context = Handle<Context>::cast(context_type->AsConstant()->Value());
}
// Walk context chain (as far as known), mirroring dynamic lookup.
// Since contexts are mutable, the information is only useful as a lower
// bound.
for (size_t i = access.depth(); i > 0; --i) {
if (context_type->IsContext()) {
context_type = context_type->AsContext()->Outer();
if (context_type->IsConstant()) {
context = Handle<Context>::cast(context_type->AsConstant()->Value());
}
} else if (!context.is_null()) {
context = handle(context.ToHandleChecked()->previous(), isolate());
}
}
Type* lower = Type::None();
if (!context.is_null()) {
lower = TypeConstant(
handle(context.ToHandleChecked()->get(static_cast<int>(access.index())),
isolate()));
}
return Bounds(lower, Type::Any());
Type* Typer::Visitor::TypeJSLoadContext(Node* node) {
// Since contexts are mutable, we just return the top.
return Type::Any();
}
Bounds Typer::Visitor::TypeJSStoreContext(Node* node) {
Type* Typer::Visitor::TypeJSStoreContext(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeJSLoadDynamicGlobal(Node* node) {
return Bounds::Unbounded();
Type* Typer::Visitor::TypeJSLoadDynamicGlobal(Node* node) {
return Type::Any();
}
Bounds Typer::Visitor::TypeJSLoadDynamicContext(Node* node) {
return Bounds::Unbounded();
Type* Typer::Visitor::TypeJSLoadDynamicContext(Node* node) {
return Type::Any();
}
Bounds Typer::Visitor::WrapContextBoundsForInput(Node* node) {
Bounds outer = BoundsOrNone(NodeProperties::GetContextInput(node));
if (outer.upper->Is(Type::None())) {
return Bounds(Type::None());
Type* Typer::Visitor::WrapContextTypeForInput(Node* node) {
Type* outer = TypeOrNone(NodeProperties::GetContextInput(node));
if (outer->Is(Type::None())) {
return Type::None();
} else {
DCHECK(outer.upper->Maybe(Type::Internal()));
return Bounds(Type::Context(outer.upper, zone()));
DCHECK(outer->Maybe(Type::Internal()));
return Type::Context(outer, zone());
}
}
Bounds Typer::Visitor::TypeJSCreateFunctionContext(Node* node) {
return WrapContextBoundsForInput(node);
Type* Typer::Visitor::TypeJSCreateFunctionContext(Node* node) {
return WrapContextTypeForInput(node);
}
Bounds Typer::Visitor::TypeJSCreateCatchContext(Node* node) {
return WrapContextBoundsForInput(node);
Type* Typer::Visitor::TypeJSCreateCatchContext(Node* node) {
return WrapContextTypeForInput(node);
}
Bounds Typer::Visitor::TypeJSCreateWithContext(Node* node) {
return WrapContextBoundsForInput(node);
Type* Typer::Visitor::TypeJSCreateWithContext(Node* node) {
return WrapContextTypeForInput(node);
}
Bounds Typer::Visitor::TypeJSCreateBlockContext(Node* node) {
return WrapContextBoundsForInput(node);
Type* Typer::Visitor::TypeJSCreateBlockContext(Node* node) {
return WrapContextTypeForInput(node);
}
Bounds Typer::Visitor::TypeJSCreateModuleContext(Node* node) {
Type* Typer::Visitor::TypeJSCreateModuleContext(Node* node) {
// TODO(rossberg): this is probably incorrect
return WrapContextBoundsForInput(node);
return WrapContextTypeForInput(node);
}
Bounds Typer::Visitor::TypeJSCreateScriptContext(Node* node) {
return WrapContextBoundsForInput(node);
Type* Typer::Visitor::TypeJSCreateScriptContext(Node* node) {
return WrapContextTypeForInput(node);
}
// JS other operators.
Bounds Typer::Visitor::TypeJSYield(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeJSYield(Node* node) { return Type::Any(); }
Bounds Typer::Visitor::TypeJSCallConstruct(Node* node) {
return Bounds(Type::None(), Type::Receiver());
Type* Typer::Visitor::TypeJSCallConstruct(Node* node) {
return Type::Receiver();
}
......@@ -1457,12 +1376,12 @@ Type* Typer::Visitor::JSCallFunctionTyper(Type* fun, Typer* t) {
}
Bounds Typer::Visitor::TypeJSCallFunction(Node* node) {
Type* Typer::Visitor::TypeJSCallFunction(Node* node) {
return TypeUnaryOp(node, JSCallFunctionTyper); // We ignore argument types.
}
Bounds Typer::Visitor::TypeJSCallRuntime(Node* node) {
Type* Typer::Visitor::TypeJSCallRuntime(Node* node) {
switch (CallRuntimeParametersOf(node->op()).id()) {
case Runtime::kInlineIsSmi:
case Runtime::kInlineIsArray:
......@@ -1471,10 +1390,10 @@ Bounds Typer::Visitor::TypeJSCallRuntime(Node* node) {
case Runtime::kInlineIsMinusZero:
case Runtime::kInlineIsFunction:
case Runtime::kInlineIsRegExp:
return Bounds(Type::None(zone()), Type::Boolean(zone()));
return Type::Boolean(zone());
case Runtime::kInlineDoubleLo:
case Runtime::kInlineDoubleHi:
return Bounds(Type::None(zone()), Type::Signed32());
return Type::Signed32();
case Runtime::kInlineConstructDouble:
case Runtime::kInlineDateField:
case Runtime::kInlineMathFloor:
......@@ -1483,149 +1402,143 @@ Bounds Typer::Visitor::TypeJSCallRuntime(Node* node) {
case Runtime::kInlineMathAsin:
case Runtime::kInlineMathAtan:
case Runtime::kInlineMathAtan2:
return Bounds(Type::None(zone()), Type::Number());
return Type::Number();
case Runtime::kInlineMathClz32:
return Bounds(Type::None(), Type::Range(0, 32, zone()));
return Type::Range(0, 32, zone());
case Runtime::kInlineStringGetLength:
return Bounds(Type::None(), Type::Range(0, String::kMaxLength, zone()));
return Type::Range(0, String::kMaxLength, zone());
case Runtime::kInlineToObject:
return Bounds(Type::None(), Type::Receiver());
return Type::Receiver();
default:
break;
}
return Bounds::Unbounded();
return Type::Any();
}
Bounds Typer::Visitor::TypeJSForInNext(Node* node) {
return Bounds(Type::None(zone()),
Type::Union(Type::Name(), Type::Undefined(), zone()));
Type* Typer::Visitor::TypeJSForInNext(Node* node) {
return Type::Union(Type::Name(), Type::Undefined(), zone());
}
Bounds Typer::Visitor::TypeJSForInPrepare(Node* node) {
Type* Typer::Visitor::TypeJSForInPrepare(Node* node) {
// TODO(bmeurer): Return a tuple type here.
return Bounds::Unbounded();
return Type::Any();
}
Bounds Typer::Visitor::TypeJSForInDone(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeJSForInDone(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeJSForInStep(Node* node) {
Type* Typer::Visitor::TypeJSForInStep(Node* node) {
STATIC_ASSERT(Map::EnumLengthBits::kMax <= FixedArray::kMaxLength);
return Bounds(Type::None(zone()),
Type::Range(1, FixedArray::kMaxLength + 1, zone()));
return Type::Range(1, FixedArray::kMaxLength + 1, zone());
}
Bounds Typer::Visitor::TypeJSStackCheck(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeJSStackCheck(Node* node) { return Type::Any(); }
// Simplified operators.
Bounds Typer::Visitor::TypeBooleanNot(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeBooleanNot(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeBooleanToNumber(Node* node) {
Type* Typer::Visitor::TypeBooleanToNumber(Node* node) {
return TypeUnaryOp(node, ToNumber);
}
Bounds Typer::Visitor::TypeNumberEqual(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeNumberEqual(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeNumberLessThan(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeNumberLessThan(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeNumberLessThanOrEqual(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeNumberLessThanOrEqual(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeNumberAdd(Node* node) {
return Bounds(Type::None(zone()), Type::Number(zone()));
}
Type* Typer::Visitor::TypeNumberAdd(Node* node) { return Type::Number(zone()); }
Bounds Typer::Visitor::TypeNumberSubtract(Node* node) {
return Bounds(Type::None(zone()), Type::Number(zone()));
Type* Typer::Visitor::TypeNumberSubtract(Node* node) {
return Type::Number(zone());
}
Bounds Typer::Visitor::TypeNumberMultiply(Node* node) {
return Bounds(Type::None(zone()), Type::Number(zone()));
Type* Typer::Visitor::TypeNumberMultiply(Node* node) {
return Type::Number(zone());
}
Bounds Typer::Visitor::TypeNumberDivide(Node* node) {
return Bounds(Type::None(zone()), Type::Number(zone()));
Type* Typer::Visitor::TypeNumberDivide(Node* node) {
return Type::Number(zone());
}
Bounds Typer::Visitor::TypeNumberModulus(Node* node) {
return Bounds(Type::None(zone()), Type::Number(zone()));
Type* Typer::Visitor::TypeNumberModulus(Node* node) {
return Type::Number(zone());
}
Bounds Typer::Visitor::TypeNumberShiftLeft(Node* node) {
return Bounds(Type::None(zone()), Type::Signed32(zone()));
Type* Typer::Visitor::TypeNumberShiftLeft(Node* node) {
return Type::Signed32(zone());
}
Bounds Typer::Visitor::TypeNumberShiftRight(Node* node) {
return Bounds(Type::None(zone()), Type::Signed32(zone()));
Type* Typer::Visitor::TypeNumberShiftRight(Node* node) {
return Type::Signed32(zone());
}
Bounds Typer::Visitor::TypeNumberShiftRightLogical(Node* node) {
return Bounds(Type::None(zone()), Type::Unsigned32(zone()));
Type* Typer::Visitor::TypeNumberShiftRightLogical(Node* node) {
return Type::Unsigned32(zone());
}
Bounds Typer::Visitor::TypeNumberToInt32(Node* node) {
Type* Typer::Visitor::TypeNumberToInt32(Node* node) {
return TypeUnaryOp(node, NumberToInt32);
}
Bounds Typer::Visitor::TypeNumberToUint32(Node* node) {
Type* Typer::Visitor::TypeNumberToUint32(Node* node) {
return TypeUnaryOp(node, NumberToUint32);
}
Bounds Typer::Visitor::TypePlainPrimitiveToNumber(Node* node) {
Type* Typer::Visitor::TypePlainPrimitiveToNumber(Node* node) {
return TypeUnaryOp(node, ToNumber);
}
Bounds Typer::Visitor::TypeReferenceEqual(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeReferenceEqual(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeStringEqual(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeStringEqual(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeStringLessThan(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeStringLessThan(Node* node) {
return Type::Boolean(zone());
}
Bounds Typer::Visitor::TypeStringLessThanOrEqual(Node* node) {
return Bounds(Type::None(zone()), Type::Boolean(zone()));
Type* Typer::Visitor::TypeStringLessThanOrEqual(Node* node) {
return Type::Boolean(zone());
}
......@@ -1639,592 +1552,455 @@ Type* ChangeRepresentation(Type* type, Type* rep, Zone* zone) {
} // namespace
Bounds Typer::Visitor::TypeChangeTaggedToInt32(Node* node) {
Bounds arg = Operand(node, 0);
// TODO(neis): DCHECK(arg.upper->Is(Type::Signed32()));
return Bounds(
ChangeRepresentation(arg.lower, Type::UntaggedSigned32(), zone()),
ChangeRepresentation(arg.upper, Type::UntaggedSigned32(), zone()));
Type* Typer::Visitor::TypeChangeTaggedToInt32(Node* node) {
Type* arg = Operand(node, 0);
// TODO(neis): DCHECK(arg->Is(Type::Signed32()));
return ChangeRepresentation(arg, Type::UntaggedSigned32(), zone());
}
Bounds Typer::Visitor::TypeChangeTaggedToUint32(Node* node) {
Bounds arg = Operand(node, 0);
// TODO(neis): DCHECK(arg.upper->Is(Type::Unsigned32()));
return Bounds(
ChangeRepresentation(arg.lower, Type::UntaggedUnsigned32(), zone()),
ChangeRepresentation(arg.upper, Type::UntaggedUnsigned32(), zone()));
Type* Typer::Visitor::TypeChangeTaggedToUint32(Node* node) {
Type* arg = Operand(node, 0);
// TODO(neis): DCHECK(arg->Is(Type::Unsigned32()));
return ChangeRepresentation(arg, Type::UntaggedUnsigned32(), zone());
}
Bounds Typer::Visitor::TypeChangeTaggedToFloat64(Node* node) {
Bounds arg = Operand(node, 0);
// TODO(neis): DCHECK(arg.upper->Is(Type::Number()));
return Bounds(
ChangeRepresentation(arg.lower, Type::UntaggedFloat64(), zone()),
ChangeRepresentation(arg.upper, Type::UntaggedFloat64(), zone()));
Type* Typer::Visitor::TypeChangeTaggedToFloat64(Node* node) {
Type* arg = Operand(node, 0);
// TODO(neis): DCHECK(arg->Is(Type::Number()));
return ChangeRepresentation(arg, Type::UntaggedFloat64(), zone());
}
Bounds Typer::Visitor::TypeChangeInt32ToTagged(Node* node) {
Bounds arg = Operand(node, 0);
// TODO(neis): DCHECK(arg.upper->Is(Type::Signed32()));
Type* lower_rep = arg.lower->Is(Type::SignedSmall()) ? Type::TaggedSigned()
: Type::Tagged();
Type* upper_rep = arg.upper->Is(Type::SignedSmall()) ? Type::TaggedSigned()
: Type::Tagged();
return Bounds(ChangeRepresentation(arg.lower, lower_rep, zone()),
ChangeRepresentation(arg.upper, upper_rep, zone()));
Type* Typer::Visitor::TypeChangeInt32ToTagged(Node* node) {
Type* arg = Operand(node, 0);
// TODO(neis): DCHECK(arg->Is(Type::Signed32()));
Type* rep =
arg->Is(Type::SignedSmall()) ? Type::TaggedSigned() : Type::Tagged();
return ChangeRepresentation(arg, rep, zone());
}
Bounds Typer::Visitor::TypeChangeUint32ToTagged(Node* node) {
Bounds arg = Operand(node, 0);
// TODO(neis): DCHECK(arg.upper->Is(Type::Unsigned32()));
return Bounds(
ChangeRepresentation(arg.lower, Type::Tagged(), zone()),
ChangeRepresentation(arg.upper, Type::Tagged(), zone()));
Type* Typer::Visitor::TypeChangeUint32ToTagged(Node* node) {
Type* arg = Operand(node, 0);
// TODO(neis): DCHECK(arg->Is(Type::Unsigned32()));
return ChangeRepresentation(arg, Type::Tagged(), zone());
}
Bounds Typer::Visitor::TypeChangeFloat64ToTagged(Node* node) {
Bounds arg = Operand(node, 0);
Type* Typer::Visitor::TypeChangeFloat64ToTagged(Node* node) {
Type* arg = Operand(node, 0);
// TODO(neis): CHECK(arg.upper->Is(Type::Number()));
return Bounds(
ChangeRepresentation(arg.lower, Type::Tagged(), zone()),
ChangeRepresentation(arg.upper, Type::Tagged(), zone()));
return ChangeRepresentation(arg, Type::Tagged(), zone());
}
Bounds Typer::Visitor::TypeChangeBoolToBit(Node* node) {
Bounds arg = Operand(node, 0);
Type* Typer::Visitor::TypeChangeBoolToBit(Node* node) {
Type* arg = Operand(node, 0);
// TODO(neis): DCHECK(arg.upper->Is(Type::Boolean()));
return Bounds(
ChangeRepresentation(arg.lower, Type::UntaggedBit(), zone()),
ChangeRepresentation(arg.upper, Type::UntaggedBit(), zone()));
return ChangeRepresentation(arg, Type::UntaggedBit(), zone());
}
Bounds Typer::Visitor::TypeChangeBitToBool(Node* node) {
Bounds arg = Operand(node, 0);
Type* Typer::Visitor::TypeChangeBitToBool(Node* node) {
Type* arg = Operand(node, 0);
// TODO(neis): DCHECK(arg.upper->Is(Type::Boolean()));
return Bounds(ChangeRepresentation(arg.lower, Type::TaggedPointer(), zone()),
ChangeRepresentation(arg.upper, Type::TaggedPointer(), zone()));
return ChangeRepresentation(arg, Type::TaggedPointer(), zone());
}
Bounds Typer::Visitor::TypeAllocate(Node* node) {
return Bounds(Type::TaggedPointer());
}
Type* Typer::Visitor::TypeAllocate(Node* node) { return Type::TaggedPointer(); }
Bounds Typer::Visitor::TypeLoadField(Node* node) {
return Bounds(FieldAccessOf(node->op()).type);
Type* Typer::Visitor::TypeLoadField(Node* node) {
return FieldAccessOf(node->op()).type;
}
Bounds Typer::Visitor::TypeLoadBuffer(Node* node) {
Type* Typer::Visitor::TypeLoadBuffer(Node* node) {
// TODO(bmeurer): This typing is not yet correct. Since we can still access
// out of bounds, the type in the general case has to include Undefined.
switch (BufferAccessOf(node->op()).external_array_type()) {
#define TYPED_ARRAY_CASE(Type, type, TYPE, ctype, size) \
case kExternal##Type##Array: \
return Bounds(typer_->cache_.k##Type);
return typer_->cache_.k##Type;
TYPED_ARRAYS(TYPED_ARRAY_CASE)
#undef TYPED_ARRAY_CASE
}
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeLoadElement(Node* node) {
return Bounds(ElementAccessOf(node->op()).type);
Type* Typer::Visitor::TypeLoadElement(Node* node) {
return ElementAccessOf(node->op()).type;
}
Bounds Typer::Visitor::TypeStoreField(Node* node) {
Type* Typer::Visitor::TypeStoreField(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeStoreBuffer(Node* node) {
Type* Typer::Visitor::TypeStoreBuffer(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeStoreElement(Node* node) {
Type* Typer::Visitor::TypeStoreElement(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeObjectIsSmi(Node* node) {
return Bounds(Type::Boolean());
}
Type* Typer::Visitor::TypeObjectIsSmi(Node* node) { return Type::Boolean(); }
// Machine operators.
Bounds Typer::Visitor::TypeLoad(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeLoad(Node* node) { return Type::Any(); }
Bounds Typer::Visitor::TypeStore(Node* node) {
Type* Typer::Visitor::TypeStore(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
Bounds Typer::Visitor::TypeWord32And(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeWord32And(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeWord32Or(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeWord32Or(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeWord32Xor(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeWord32Xor(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeWord32Shl(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeWord32Shl(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeWord32Shr(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeWord32Shr(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeWord32Sar(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeWord32Sar(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeWord32Ror(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeWord32Ror(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeWord32Equal(Node* node) {
return Bounds(Type::Boolean());
}
Type* Typer::Visitor::TypeWord32Equal(Node* node) { return Type::Boolean(); }
Bounds Typer::Visitor::TypeWord32Clz(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeWord32Clz(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeWord64And(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeWord64And(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeWord64Or(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeWord64Or(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeWord64Xor(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeWord64Xor(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeWord64Shl(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeWord64Shl(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeWord64Shr(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeWord64Shr(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeWord64Sar(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeWord64Sar(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeWord64Ror(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeWord64Ror(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeWord64Equal(Node* node) {
return Bounds(Type::Boolean());
}
Type* Typer::Visitor::TypeWord64Equal(Node* node) { return Type::Boolean(); }
Bounds Typer::Visitor::TypeInt32Add(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeInt32Add(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeInt32AddWithOverflow(Node* node) {
return Bounds(Type::Internal());
Type* Typer::Visitor::TypeInt32AddWithOverflow(Node* node) {
return Type::Internal();
}
Bounds Typer::Visitor::TypeInt32Sub(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeInt32Sub(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeInt32SubWithOverflow(Node* node) {
return Bounds(Type::Internal());
Type* Typer::Visitor::TypeInt32SubWithOverflow(Node* node) {
return Type::Internal();
}
Bounds Typer::Visitor::TypeInt32Mul(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeInt32Mul(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeInt32MulHigh(Node* node) {
return Bounds(Type::Signed32());
}
Type* Typer::Visitor::TypeInt32MulHigh(Node* node) { return Type::Signed32(); }
Bounds Typer::Visitor::TypeInt32Div(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeInt32Div(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeInt32Mod(Node* node) {
return Bounds(Type::Integral32());
}
Type* Typer::Visitor::TypeInt32Mod(Node* node) { return Type::Integral32(); }
Bounds Typer::Visitor::TypeInt32LessThan(Node* node) {
return Bounds(Type::Boolean());
}
Type* Typer::Visitor::TypeInt32LessThan(Node* node) { return Type::Boolean(); }
Bounds Typer::Visitor::TypeInt32LessThanOrEqual(Node* node) {
return Bounds(Type::Boolean());
Type* Typer::Visitor::TypeInt32LessThanOrEqual(Node* node) {
return Type::Boolean();
}
Bounds Typer::Visitor::TypeUint32Div(Node* node) {
return Bounds(Type::Unsigned32());
}
Type* Typer::Visitor::TypeUint32Div(Node* node) { return Type::Unsigned32(); }
Bounds Typer::Visitor::TypeUint32LessThan(Node* node) {
return Bounds(Type::Boolean());
}
Type* Typer::Visitor::TypeUint32LessThan(Node* node) { return Type::Boolean(); }
Bounds Typer::Visitor::TypeUint32LessThanOrEqual(Node* node) {
return Bounds(Type::Boolean());
Type* Typer::Visitor::TypeUint32LessThanOrEqual(Node* node) {
return Type::Boolean();
}
Bounds Typer::Visitor::TypeUint32Mod(Node* node) {
return Bounds(Type::Unsigned32());
}
Type* Typer::Visitor::TypeUint32Mod(Node* node) { return Type::Unsigned32(); }
Bounds Typer::Visitor::TypeUint32MulHigh(Node* node) {
return Bounds(Type::Unsigned32());
Type* Typer::Visitor::TypeUint32MulHigh(Node* node) {
return Type::Unsigned32();
}
Bounds Typer::Visitor::TypeInt64Add(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeInt64Add(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeInt64Sub(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeInt64Sub(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeInt64Mul(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeInt64Mul(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeInt64Div(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeInt64Div(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeInt64Mod(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeInt64Mod(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeInt64LessThan(Node* node) {
return Bounds(Type::Boolean());
}
Type* Typer::Visitor::TypeInt64LessThan(Node* node) { return Type::Boolean(); }
Bounds Typer::Visitor::TypeInt64LessThanOrEqual(Node* node) {
return Bounds(Type::Boolean());
Type* Typer::Visitor::TypeInt64LessThanOrEqual(Node* node) {
return Type::Boolean();
}
Bounds Typer::Visitor::TypeUint64Div(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeUint64Div(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeUint64LessThan(Node* node) {
return Bounds(Type::Boolean());
}
Type* Typer::Visitor::TypeUint64LessThan(Node* node) { return Type::Boolean(); }
Bounds Typer::Visitor::TypeUint64LessThanOrEqual(Node* node) {
return Bounds(Type::Boolean());
Type* Typer::Visitor::TypeUint64LessThanOrEqual(Node* node) {
return Type::Boolean();
}
Bounds Typer::Visitor::TypeUint64Mod(Node* node) {
return Bounds(Type::Internal());
}
Type* Typer::Visitor::TypeUint64Mod(Node* node) { return Type::Internal(); }
Bounds Typer::Visitor::TypeChangeFloat32ToFloat64(Node* node) {
return Bounds(Type::Intersect(
Type::Number(), Type::UntaggedFloat64(), zone()));
Type* Typer::Visitor::TypeChangeFloat32ToFloat64(Node* node) {
return Type::Intersect(Type::Number(), Type::UntaggedFloat64(), zone());
}
Bounds Typer::Visitor::TypeChangeFloat64ToInt32(Node* node) {
return Bounds(Type::Intersect(
Type::Signed32(), Type::UntaggedSigned32(), zone()));
Type* Typer::Visitor::TypeChangeFloat64ToInt32(Node* node) {
return Type::Intersect(Type::Signed32(), Type::UntaggedSigned32(), zone());
}
Bounds Typer::Visitor::TypeChangeFloat64ToUint32(Node* node) {
return Bounds(Type::Intersect(
Type::Unsigned32(), Type::UntaggedUnsigned32(), zone()));
Type* Typer::Visitor::TypeChangeFloat64ToUint32(Node* node) {
return Type::Intersect(Type::Unsigned32(), Type::UntaggedUnsigned32(),
zone());
}
Bounds Typer::Visitor::TypeChangeInt32ToFloat64(Node* node) {
return Bounds(Type::Intersect(
Type::Signed32(), Type::UntaggedFloat64(), zone()));
Type* Typer::Visitor::TypeChangeInt32ToFloat64(Node* node) {
return Type::Intersect(Type::Signed32(), Type::UntaggedFloat64(), zone());
}
Bounds Typer::Visitor::TypeChangeInt32ToInt64(Node* node) {
return Bounds(Type::Internal());
Type* Typer::Visitor::TypeChangeInt32ToInt64(Node* node) {
return Type::Internal();
}
Bounds Typer::Visitor::TypeChangeUint32ToFloat64(Node* node) {
return Bounds(Type::Intersect(
Type::Unsigned32(), Type::UntaggedFloat64(), zone()));
Type* Typer::Visitor::TypeChangeUint32ToFloat64(Node* node) {
return Type::Intersect(Type::Unsigned32(), Type::UntaggedFloat64(), zone());
}
Bounds Typer::Visitor::TypeChangeUint32ToUint64(Node* node) {
return Bounds(Type::Internal());
Type* Typer::Visitor::TypeChangeUint32ToUint64(Node* node) {
return Type::Internal();
}
Bounds Typer::Visitor::TypeTruncateFloat64ToFloat32(Node* node) {
return Bounds(Type::Intersect(
Type::Number(), Type::UntaggedFloat32(), zone()));
Type* Typer::Visitor::TypeTruncateFloat64ToFloat32(Node* node) {
return Type::Intersect(Type::Number(), Type::UntaggedFloat32(), zone());
}
Bounds Typer::Visitor::TypeTruncateFloat64ToInt32(Node* node) {
return Bounds(Type::Intersect(
Type::Signed32(), Type::UntaggedSigned32(), zone()));
Type* Typer::Visitor::TypeTruncateFloat64ToInt32(Node* node) {
return Type::Intersect(Type::Signed32(), Type::UntaggedSigned32(), zone());
}
Bounds Typer::Visitor::TypeTruncateInt64ToInt32(Node* node) {
return Bounds(Type::Intersect(
Type::Signed32(), Type::UntaggedSigned32(), zone()));
Type* Typer::Visitor::TypeTruncateInt64ToInt32(Node* node) {
return Type::Intersect(Type::Signed32(), Type::UntaggedSigned32(), zone());
}
Bounds Typer::Visitor::TypeFloat32Add(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat32Add(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat32Sub(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat32Sub(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat32Mul(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat32Mul(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat32Div(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat32Div(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat32Max(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat32Max(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat32Min(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat32Min(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat32Abs(Node* node) {
Type* Typer::Visitor::TypeFloat32Abs(Node* node) {
// TODO(turbofan): We should be able to infer a better type here.
return Bounds(Type::Number());
return Type::Number();
}
Bounds Typer::Visitor::TypeFloat32Sqrt(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat32Sqrt(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat32Equal(Node* node) {
return Bounds(Type::Boolean());
}
Type* Typer::Visitor::TypeFloat32Equal(Node* node) { return Type::Boolean(); }
Bounds Typer::Visitor::TypeFloat32LessThan(Node* node) {
return Bounds(Type::Boolean());
Type* Typer::Visitor::TypeFloat32LessThan(Node* node) {
return Type::Boolean();
}
Bounds Typer::Visitor::TypeFloat32LessThanOrEqual(Node* node) {
return Bounds(Type::Boolean());
Type* Typer::Visitor::TypeFloat32LessThanOrEqual(Node* node) {
return Type::Boolean();
}
Bounds Typer::Visitor::TypeFloat64Add(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat64Add(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat64Sub(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat64Sub(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat64Mul(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat64Mul(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat64Div(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat64Div(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat64Mod(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat64Mod(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat64Max(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat64Max(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat64Min(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat64Min(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat64Abs(Node* node) {
Type* Typer::Visitor::TypeFloat64Abs(Node* node) {
// TODO(turbofan): We should be able to infer a better type here.
return Bounds(Type::Number());
return Type::Number();
}
Bounds Typer::Visitor::TypeFloat64Sqrt(Node* node) {
return Bounds(Type::Number());
}
Type* Typer::Visitor::TypeFloat64Sqrt(Node* node) { return Type::Number(); }
Bounds Typer::Visitor::TypeFloat64Equal(Node* node) {
return Bounds(Type::Boolean());
}
Type* Typer::Visitor::TypeFloat64Equal(Node* node) { return Type::Boolean(); }
Bounds Typer::Visitor::TypeFloat64LessThan(Node* node) {
return Bounds(Type::Boolean());
Type* Typer::Visitor::TypeFloat64LessThan(Node* node) {
return Type::Boolean();
}
Bounds Typer::Visitor::TypeFloat64LessThanOrEqual(Node* node) {
return Bounds(Type::Boolean());
Type* Typer::Visitor::TypeFloat64LessThanOrEqual(Node* node) {
return Type::Boolean();
}
Bounds Typer::Visitor::TypeFloat64RoundDown(Node* node) {
Type* Typer::Visitor::TypeFloat64RoundDown(Node* node) {
// TODO(sigurds): We could have a tighter bound here.
return Bounds(Type::Number());
return Type::Number();
}
Bounds Typer::Visitor::TypeFloat64RoundTruncate(Node* node) {
Type* Typer::Visitor::TypeFloat64RoundTruncate(Node* node) {
// TODO(sigurds): We could have a tighter bound here.
return Bounds(Type::Number());
return Type::Number();
}
Bounds Typer::Visitor::TypeFloat64RoundTiesAway(Node* node) {
Type* Typer::Visitor::TypeFloat64RoundTiesAway(Node* node) {
// TODO(sigurds): We could have a tighter bound here.
return Bounds(Type::Number());
return Type::Number();
}
Bounds Typer::Visitor::TypeFloat64ExtractLowWord32(Node* node) {
return Bounds(Type::Signed32());
Type* Typer::Visitor::TypeFloat64ExtractLowWord32(Node* node) {
return Type::Signed32();
}
Bounds Typer::Visitor::TypeFloat64ExtractHighWord32(Node* node) {
return Bounds(Type::Signed32());
Type* Typer::Visitor::TypeFloat64ExtractHighWord32(Node* node) {
return Type::Signed32();
}
Bounds Typer::Visitor::TypeFloat64InsertLowWord32(Node* node) {
return Bounds(Type::Number());
Type* Typer::Visitor::TypeFloat64InsertLowWord32(Node* node) {
return Type::Number();
}
Bounds Typer::Visitor::TypeFloat64InsertHighWord32(Node* node) {
return Bounds(Type::Number());
Type* Typer::Visitor::TypeFloat64InsertHighWord32(Node* node) {
return Type::Number();
}
Bounds Typer::Visitor::TypeLoadStackPointer(Node* node) {
return Bounds(Type::Internal());
Type* Typer::Visitor::TypeLoadStackPointer(Node* node) {
return Type::Internal();
}
Bounds Typer::Visitor::TypeLoadFramePointer(Node* node) {
return Bounds(Type::Internal());
Type* Typer::Visitor::TypeLoadFramePointer(Node* node) {
return Type::Internal();
}
Bounds Typer::Visitor::TypeCheckedLoad(Node* node) {
return Bounds::Unbounded();
}
Type* Typer::Visitor::TypeCheckedLoad(Node* node) { return Type::Any(); }
Bounds Typer::Visitor::TypeCheckedStore(Node* node) {
Type* Typer::Visitor::TypeCheckedStore(Node* node) {
UNREACHABLE();
return Bounds();
return nullptr;
}
......
......@@ -52,7 +52,7 @@ class Verifier::Visitor {
private:
// TODO(rossberg): Get rid of these once we got rid of NodeProperties.
Bounds bounds(Node* node) { return NodeProperties::GetBounds(node); }
Type* type_of(Node* node) { return NodeProperties::GetType(node); }
Node* ValueInput(Node* node, int i = 0) {
return NodeProperties::GetValueInput(node, i);
}
......@@ -65,22 +65,22 @@ class Verifier::Visitor {
}
}
void CheckUpperIs(Node* node, Type* type) {
if (typing == TYPED && !bounds(node).upper->Is(type)) {
if (typing == TYPED && !type_of(node)->Is(type)) {
std::ostringstream str;
str << "TypeError: node #" << node->id() << ":" << *node->op()
<< " upper bound ";
bounds(node).upper->PrintTo(str);
<< " type ";
type_of(node)->PrintTo(str);
str << " is not ";
type->PrintTo(str);
FATAL(str.str().c_str());
}
}
void CheckUpperMaybe(Node* node, Type* type) {
if (typing == TYPED && !bounds(node).upper->Maybe(type)) {
if (typing == TYPED && !type_of(node)->Maybe(type)) {
std::ostringstream str;
str << "TypeError: node #" << node->id() << ":" << *node->op()
<< " upper bound ";
bounds(node).upper->PrintTo(str);
<< " type ";
type_of(node)->PrintTo(str);
str << " must intersect ";
type->PrintTo(str);
FATAL(str.str().c_str());
......@@ -88,12 +88,12 @@ class Verifier::Visitor {
}
void CheckValueInputIs(Node* node, int i, Type* type) {
Node* input = ValueInput(node, i);
if (typing == TYPED && !bounds(input).upper->Is(type)) {
if (typing == TYPED && !type_of(input)->Is(type)) {
std::ostringstream str;
str << "TypeError: node #" << node->id() << ":" << *node->op()
<< "(input @" << i << " = " << input->opcode() << ":"
<< input->op()->mnemonic() << ") upper bound ";
bounds(input).upper->PrintTo(str);
<< input->op()->mnemonic() << ") type ";
type_of(input)->PrintTo(str);
str << " is not ";
type->PrintTo(str);
FATAL(str.str().c_str());
......@@ -398,9 +398,7 @@ void Verifier::Visitor::Check(Node* node) {
// TODO(rossberg): for now at least, narrowing does not really hold.
/*
for (int i = 0; i < value_count; ++i) {
// TODO(rossberg, jarin): Figure out what to do about lower bounds.
// CHECK(bounds(node).lower->Is(bounds(ValueInput(node, i)).lower));
CHECK(bounds(ValueInput(node, i)).upper->Is(bounds(node).upper));
CHECK(type_of(ValueInput(node, i))->Is(type_of(node)));
}
*/
break;
......@@ -427,8 +425,7 @@ void Verifier::Visitor::Check(Node* node) {
// TODO(rossberg): what are the constraints on these?
// Type must be subsumed by input type.
if (typing == TYPED) {
CHECK(bounds(ValueInput(node)).lower->Is(bounds(node).lower));
CHECK(bounds(ValueInput(node)).upper->Is(bounds(node).upper));
CHECK(type_of(ValueInput(node))->Is(type_of(node)));
}
break;
}
......@@ -568,7 +565,7 @@ void Verifier::Visitor::Check(Node* node) {
// TODO(rossberg): This should really be Is(Internal), but the typer
// currently can't do backwards propagation.
CheckUpperMaybe(context, Type::Internal());
if (typing == TYPED) CHECK(bounds(node).upper->IsContext());
if (typing == TYPED) CHECK(type_of(node)->IsContext());
break;
}
......
......@@ -45,7 +45,7 @@ class JSConstantCacheTester : public HandleAndZoneScope,
main_typer_.Run();
}
Type* upper(Node* node) { return NodeProperties::GetBounds(node).upper; }
Type* TypeOf(Node* node) { return NodeProperties::GetType(node); }
Handle<HeapObject> handle(Node* node) {
CHECK_EQ(IrOpcode::kHeapConstant, node->opcode());
......@@ -69,7 +69,7 @@ TEST(ZeroConstant1) {
CHECK_NE(zero, T.Float64Constant(0));
CHECK_NE(zero, T.Int32Constant(0));
Type* t = T.upper(zero);
Type* t = T.TypeOf(zero);
CHECK(t->Is(Type::Number()));
CHECK(t->Is(Type::Integral32()));
......@@ -90,7 +90,7 @@ TEST(MinusZeroConstant) {
CHECK_EQ(minus_zero, T.Constant(-0.0));
CHECK_NE(zero, minus_zero);
Type* t = T.upper(minus_zero);
Type* t = T.TypeOf(minus_zero);
CHECK(t->Is(Type::Number()));
CHECK(t->Is(Type::MinusZero()));
......@@ -123,7 +123,7 @@ TEST(ZeroConstant2) {
CHECK_NE(zero, T.Float64Constant(0));
CHECK_NE(zero, T.Int32Constant(0));
Type* t = T.upper(zero);
Type* t = T.TypeOf(zero);
CHECK(t->Is(Type::Number()));
CHECK(t->Is(Type::Integral32()));
......@@ -148,7 +148,7 @@ TEST(OneConstant1) {
CHECK_NE(one, T.Float64Constant(1.0));
CHECK_NE(one, T.Int32Constant(1));
Type* t = T.upper(one);
Type* t = T.TypeOf(one);
CHECK(t->Is(Type::Number()));
CHECK(t->Is(Type::Integral32()));
......@@ -173,7 +173,7 @@ TEST(OneConstant2) {
CHECK_NE(one, T.Float64Constant(1.0));
CHECK_NE(one, T.Int32Constant(1));
Type* t = T.upper(one);
Type* t = T.TypeOf(one);
CHECK(t->Is(Type::Number()));
CHECK(t->Is(Type::Integral32()));
......@@ -233,7 +233,7 @@ TEST(NumberTypes) {
FOR_FLOAT64_INPUTS(i) {
double value = *i;
Node* node = T.Constant(value);
CHECK(T.upper(node)->Is(Type::Of(value, T.main_zone())));
CHECK(T.TypeOf(node)->Is(Type::Of(value, T.main_zone())));
}
}
......@@ -280,15 +280,15 @@ TEST(OddballValues) {
TEST(OddballTypes) {
JSConstantCacheTester T;
CHECK(T.upper(T.UndefinedConstant())->Is(Type::Undefined()));
CHECK(T.TypeOf(T.UndefinedConstant())->Is(Type::Undefined()));
// TODO(dcarney): figure this out.
// CHECK(T.upper(T.TheHoleConstant())->Is(Type::Internal()));
CHECK(T.upper(T.TrueConstant())->Is(Type::Boolean()));
CHECK(T.upper(T.FalseConstant())->Is(Type::Boolean()));
CHECK(T.upper(T.NullConstant())->Is(Type::Null()));
CHECK(T.upper(T.ZeroConstant())->Is(Type::Number()));
CHECK(T.upper(T.OneConstant())->Is(Type::Number()));
CHECK(T.upper(T.NaNConstant())->Is(Type::NaN()));
// CHECK(T.TypeOf(T.TheHoleConstant())->Is(Type::Internal()));
CHECK(T.TypeOf(T.TrueConstant())->Is(Type::Boolean()));
CHECK(T.TypeOf(T.FalseConstant())->Is(Type::Boolean()));
CHECK(T.TypeOf(T.NullConstant())->Is(Type::Null()));
CHECK(T.TypeOf(T.ZeroConstant())->Is(Type::Number()));
CHECK(T.TypeOf(T.OneConstant())->Is(Type::Number()));
CHECK(T.TypeOf(T.NaNConstant())->Is(Type::NaN()));
}
......
......@@ -58,7 +58,7 @@ class JSTypedLoweringTester : public HandleAndZoneScope {
Node* Parameter(Type* t, int32_t index = 0) {
Node* n = graph.NewNode(common.Parameter(index), graph.start());
NodeProperties::SetBounds(n, Bounds(Type::None(), t));
NodeProperties::SetType(n, t);
return n;
}
......@@ -296,8 +296,8 @@ TEST_WITH_STRONG(NumberBinops) {
static void CheckToI32(Node* old_input, Node* new_input, bool is_signed) {
Type* old_type = NodeProperties::GetBounds(old_input).upper;
Type* new_type = NodeProperties::GetBounds(new_input).upper;
Type* old_type = NodeProperties::GetType(old_input);
Type* new_type = NodeProperties::GetType(new_input);
Type* expected_type = I32Type(is_signed);
CHECK(new_type->Is(expected_type));
if (old_type->Is(expected_type)) {
......@@ -489,7 +489,7 @@ TEST(JSToNumberOfConstant) {
// Note that either outcome below is correct. It only depends on whether
// the types of constants are eagerly computed or only computed by the
// typing pass.
if (NodeProperties::GetBounds(n).upper->Is(Type::Number())) {
if (NodeProperties::GetType(n)->Is(Type::Number())) {
// If number constants are eagerly typed, then reduction should
// remove the ToNumber.
CHECK_EQ(n, r);
......@@ -624,9 +624,9 @@ TEST_WITH_STRONG(StringComparison) {
static void CheckIsConvertedToNumber(Node* val, Node* converted) {
if (NodeProperties::GetBounds(val).upper->Is(Type::Number())) {
if (NodeProperties::GetType(val)->Is(Type::Number())) {
CHECK_EQ(val, converted);
} else if (NodeProperties::GetBounds(val).upper->Is(Type::Boolean())) {
} else if (NodeProperties::GetType(val)->Is(Type::Boolean())) {
CHECK_EQ(IrOpcode::kBooleanToNumber, converted->opcode());
CHECK_EQ(val, converted->InputAt(0));
} else {
......
......@@ -101,7 +101,7 @@ TEST(RunNumberToInt32_float64) {
FieldAccess load = {kUntaggedBase, 0, Handle<Name>(), Type::Number(),
kMachFloat64};
Node* loaded = t.LoadField(load, t.PointerConstant(&input));
NodeProperties::SetBounds(loaded, Bounds(Type::Number()));
NodeProperties::SetType(loaded, Type::Number());
Node* convert = t.NumberToInt32(loaded);
FieldAccess store = {kUntaggedBase, 0, Handle<Name>(), Type::Signed32(),
kMachInt32};
......@@ -128,7 +128,7 @@ TEST(RunNumberToUint32_float64) {
FieldAccess load = {kUntaggedBase, 0, Handle<Name>(), Type::Number(),
kMachFloat64};
Node* loaded = t.LoadField(load, t.PointerConstant(&input));
NodeProperties::SetBounds(loaded, Bounds(Type::Number()));
NodeProperties::SetType(loaded, Type::Number());
Node* convert = t.NumberToUint32(loaded);
FieldAccess store = {kUntaggedBase, 0, Handle<Name>(), Type::Unsigned32(),
kMachUint32};
......@@ -687,9 +687,9 @@ class TestingGraph : public HandleAndZoneScope, public GraphAndBuilders {
p1 = graph()->NewNode(common()->Parameter(1), start);
p2 = graph()->NewNode(common()->Parameter(2), start);
typer.Run();
NodeProperties::SetBounds(p0, Bounds(p0_type));
NodeProperties::SetBounds(p1, Bounds(p1_type));
NodeProperties::SetBounds(p2, Bounds(p2_type));
NodeProperties::SetType(p0, p0_type);
NodeProperties::SetType(p1, p1_type);
NodeProperties::SetType(p2, p2_type);
}
void CheckLoweringBinop(IrOpcode::Value expected, const Operator* op) {
......@@ -1120,7 +1120,7 @@ TEST(LowerNumberToUint32_to_TruncateFloat64ToInt32) {
TestingGraph t(Type::Number());
Node* p0 = t.ExampleWithOutput(kMachFloat64);
// TODO(titzer): run the typer here, or attach machine type to param.
NodeProperties::SetBounds(p0, Bounds(Type::Number()));
NodeProperties::SetType(p0, Type::Number());
Node* trunc = t.graph()->NewNode(t.simplified()->NumberToUint32(), p0);
Node* use = t.Use(trunc, kMachUint32);
t.Return(use);
......@@ -1981,8 +1981,8 @@ TEST(PhiRepresentation) {
Node* phi =
t.graph()->NewNode(t.common()->Phi(kMachAnyTagged, 2), t.p0, t.p1, m);
Bounds phi_bounds = Bounds::Either(Bounds(d.arg1), Bounds(d.arg2), z);
NodeProperties::SetBounds(phi, phi_bounds);
Type* phi_type = Type::Union(d.arg1, d.arg2, z);
NodeProperties::SetType(phi, phi_type);
Node* use = t.Use(phi, d.use);
t.Return(use);
......
......@@ -55,7 +55,7 @@ Node* GraphTest::NumberConstant(volatile double value) {
Node* GraphTest::HeapConstant(const Handle<HeapObject>& value) {
Node* node = graph()->NewNode(common()->HeapConstant(value));
Type* type = Type::Constant(value, zone());
NodeProperties::SetBounds(node, Bounds(type));
NodeProperties::SetType(node, type);
return node;
}
......@@ -109,7 +109,7 @@ TypedGraphTest::~TypedGraphTest() {}
Node* TypedGraphTest::Parameter(Type* type, int32_t index) {
Node* node = GraphTest::Parameter(index);
NodeProperties::SetBounds(node, Bounds(type));
NodeProperties::SetType(node, type);
return node;
}
......
......@@ -58,11 +58,11 @@ class TyperTest : public TypedGraphTest {
Type* TypeBinaryOp(const Operator* op, Type* lhs, Type* rhs) {
Node* p0 = Parameter(0);
Node* p1 = Parameter(1);
NodeProperties::SetBounds(p0, Bounds(lhs));
NodeProperties::SetBounds(p1, Bounds(rhs));
NodeProperties::SetType(p0, lhs);
NodeProperties::SetType(p1, rhs);
Node* n = graph()->NewNode(op, p0, p1, context_node_, graph()->start(),
graph()->start());
return NodeProperties::GetBounds(n).upper;
return NodeProperties::GetType(n);
}
Type* RandomRange(bool int32 = false) {
......@@ -399,7 +399,7 @@ TEST_F(TyperTest, TypeRegressInt32Constant) {
int values[] = {-5, 10};
for (auto i : values) {
Node* c = graph()->NewNode(common()->Int32Constant(i));
Type* type = NodeProperties::GetBounds(c).upper;
Type* type = NodeProperties::GetType(c);
EXPECT_TRUE(type->Is(NewRange(i, i)));
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment