Commit 66e96fc9 authored by bmeurer's avatar bmeurer Committed by Commit bot

[turbofan] Unify number operation typing rules.

Move all the typing rules for unary and binary number operations to the
OperationTyper and use them for both the regular Typer as well as the
retyper that runs as part of SimplifiedLowering.

R=epertoso@chromium.org

Review-Url: https://codereview.chromium.org/2202883005
Cr-Commit-Position: refs/heads/master@{#38283}
parent cc1e84b9
...@@ -200,24 +200,15 @@ ...@@ -200,24 +200,15 @@
V(NumberEqual) \ V(NumberEqual) \
V(NumberLessThan) \ V(NumberLessThan) \
V(NumberLessThanOrEqual) \ V(NumberLessThanOrEqual) \
V(SpeculativeNumberEqual) \
V(SpeculativeNumberLessThan) \
V(SpeculativeNumberLessThanOrEqual) \
V(ReferenceEqual) \ V(ReferenceEqual) \
V(StringEqual) \ V(StringEqual) \
V(StringLessThan) \ V(StringLessThan) \
V(StringLessThanOrEqual) V(StringLessThanOrEqual)
#define SIMPLIFIED_OTHER_OP_LIST(V) \ #define SIMPLIFIED_NUMBER_BINOP_LIST(V) \
V(PlainPrimitiveToNumber) \
V(PlainPrimitiveToWord32) \
V(PlainPrimitiveToFloat64) \
V(BooleanNot) \
V(SpeculativeNumberAdd) \
V(SpeculativeNumberSubtract) \
V(SpeculativeNumberMultiply) \
V(SpeculativeNumberDivide) \
V(SpeculativeNumberModulus) \
V(SpeculativeNumberEqual) \
V(SpeculativeNumberLessThan) \
V(SpeculativeNumberLessThanOrEqual) \
V(NumberAdd) \ V(NumberAdd) \
V(NumberSubtract) \ V(NumberSubtract) \
V(NumberMultiply) \ V(NumberMultiply) \
...@@ -229,80 +220,98 @@ ...@@ -229,80 +220,98 @@
V(NumberShiftLeft) \ V(NumberShiftLeft) \
V(NumberShiftRight) \ V(NumberShiftRight) \
V(NumberShiftRightLogical) \ V(NumberShiftRightLogical) \
V(SpeculativeNumberBitwiseAnd) \
V(SpeculativeNumberBitwiseOr) \
V(SpeculativeNumberBitwiseXor) \
V(SpeculativeNumberShiftLeft) \
V(SpeculativeNumberShiftRight) \
V(SpeculativeNumberShiftRightLogical) \
V(NumberImul) \
V(NumberAbs) \
V(NumberClz32) \
V(NumberCeil) \
V(NumberCos) \
V(NumberCosh) \
V(NumberFloor) \
V(NumberFround) \
V(NumberAcos) \
V(NumberAcosh) \
V(NumberAsin) \
V(NumberAsinh) \
V(NumberAtan) \
V(NumberAtanh) \
V(NumberAtan2) \ V(NumberAtan2) \
V(NumberExp) \ V(NumberImul) \
V(NumberExpm1) \
V(NumberLog) \
V(NumberLog1p) \
V(NumberLog2) \
V(NumberLog10) \
V(NumberMax) \ V(NumberMax) \
V(NumberMin) \ V(NumberMin) \
V(NumberCbrt) \ V(NumberPow)
V(NumberPow) \
V(NumberRound) \ #define SIMPLIFIED_SPECULATIVE_NUMBER_BINOP_LIST(V) \
V(NumberSign) \ V(SpeculativeNumberAdd) \
V(NumberSin) \ V(SpeculativeNumberSubtract) \
V(NumberSinh) \ V(SpeculativeNumberMultiply) \
V(NumberSqrt) \ V(SpeculativeNumberDivide) \
V(NumberTan) \ V(SpeculativeNumberModulus) \
V(NumberTanh) \ V(SpeculativeNumberBitwiseAnd) \
V(NumberTrunc) \ V(SpeculativeNumberBitwiseOr) \
V(NumberToInt32) \ V(SpeculativeNumberBitwiseXor) \
V(NumberToUint32) \ V(SpeculativeNumberShiftLeft) \
V(NumberSilenceNaN) \ V(SpeculativeNumberShiftRight) \
V(StringCharCodeAt) \ V(SpeculativeNumberShiftRightLogical)
V(StringFromCharCode) \
V(CheckBounds) \ #define SIMPLIFIED_NUMBER_UNOP_LIST(V) \
V(CheckIf) \ V(NumberAbs) \
V(CheckMaps) \ V(NumberAcos) \
V(CheckNumber) \ V(NumberAcosh) \
V(CheckString) \ V(NumberAsin) \
V(CheckTaggedPointer) \ V(NumberAsinh) \
V(CheckTaggedSigned) \ V(NumberAtan) \
V(CheckFloat64Hole) \ V(NumberAtanh) \
V(CheckTaggedHole) \ V(NumberCbrt) \
V(Allocate) \ V(NumberCeil) \
V(LoadField) \ V(NumberClz32) \
V(LoadBuffer) \ V(NumberCos) \
V(LoadElement) \ V(NumberCosh) \
V(LoadTypedElement) \ V(NumberExp) \
V(StoreField) \ V(NumberExpm1) \
V(StoreBuffer) \ V(NumberFloor) \
V(StoreElement) \ V(NumberFround) \
V(StoreTypedElement) \ V(NumberLog) \
V(ObjectIsCallable) \ V(NumberLog1p) \
V(ObjectIsNumber) \ V(NumberLog2) \
V(ObjectIsReceiver) \ V(NumberLog10) \
V(ObjectIsSmi) \ V(NumberRound) \
V(ObjectIsString) \ V(NumberSign) \
V(ObjectIsUndetectable) \ V(NumberSin) \
V(NumberSinh) \
V(NumberSqrt) \
V(NumberTan) \
V(NumberTanh) \
V(NumberTrunc) \
V(NumberToInt32) \
V(NumberToUint32) \
V(NumberSilenceNaN)
#define SIMPLIFIED_OTHER_OP_LIST(V) \
V(PlainPrimitiveToNumber) \
V(PlainPrimitiveToWord32) \
V(PlainPrimitiveToFloat64) \
V(BooleanNot) \
V(StringCharCodeAt) \
V(StringFromCharCode) \
V(CheckBounds) \
V(CheckIf) \
V(CheckMaps) \
V(CheckNumber) \
V(CheckString) \
V(CheckTaggedPointer) \
V(CheckTaggedSigned) \
V(CheckFloat64Hole) \
V(CheckTaggedHole) \
V(Allocate) \
V(LoadField) \
V(LoadBuffer) \
V(LoadElement) \
V(LoadTypedElement) \
V(StoreField) \
V(StoreBuffer) \
V(StoreElement) \
V(StoreTypedElement) \
V(ObjectIsCallable) \
V(ObjectIsNumber) \
V(ObjectIsReceiver) \
V(ObjectIsSmi) \
V(ObjectIsString) \
V(ObjectIsUndetectable) \
V(TransitionElementsKind) V(TransitionElementsKind)
#define SIMPLIFIED_OP_LIST(V) \ #define SIMPLIFIED_OP_LIST(V) \
SIMPLIFIED_CHANGE_OP_LIST(V) \ SIMPLIFIED_CHANGE_OP_LIST(V) \
SIMPLIFIED_CHECKED_OP_LIST(V) \ SIMPLIFIED_CHECKED_OP_LIST(V) \
SIMPLIFIED_COMPARE_BINOP_LIST(V) \ SIMPLIFIED_COMPARE_BINOP_LIST(V) \
SIMPLIFIED_NUMBER_BINOP_LIST(V) \
SIMPLIFIED_SPECULATIVE_NUMBER_BINOP_LIST(V) \
SIMPLIFIED_NUMBER_UNOP_LIST(V) \
SIMPLIFIED_OTHER_OP_LIST(V) SIMPLIFIED_OTHER_OP_LIST(V)
// Opcodes for Machine-level operators. // Opcodes for Machine-level operators.
......
This diff is collapsed.
...@@ -32,13 +32,16 @@ class OperationTyper { ...@@ -32,13 +32,16 @@ class OperationTyper {
Type* ToNumber(Type* type); Type* ToNumber(Type* type);
Type* WeakenRange(Type* current_range, Type* previous_range); Type* WeakenRange(Type* current_range, Type* previous_range);
Type* NumberAdd(Type* lhs, Type* rhs); // Number unary operators.
Type* NumberSubtract(Type* lhs, Type* rhs); #define DECLARE_METHOD(Name) Type* Name(Type* type);
Type* NumberMultiply(Type* lhs, Type* rhs); SIMPLIFIED_NUMBER_UNOP_LIST(DECLARE_METHOD)
Type* NumberDivide(Type* lhs, Type* rhs); #undef DECLARE_METHOD
Type* NumberModulus(Type* lhs, Type* rhs);
Type* NumberAbs(Type* type); // Number binary operators.
#define DECLARE_METHOD(Name) Type* Name(Type* lhs, Type* rhs);
SIMPLIFIED_NUMBER_BINOP_LIST(DECLARE_METHOD)
SIMPLIFIED_SPECULATIVE_NUMBER_BINOP_LIST(DECLARE_METHOD)
#undef DECLARE_METHOD
enum ComparisonOutcomeFlags { enum ComparisonOutcomeFlags {
kComparisonTrue = 1, kComparisonTrue = 1,
...@@ -46,14 +49,9 @@ class OperationTyper { ...@@ -46,14 +49,9 @@ class OperationTyper {
kComparisonUndefined = 4 kComparisonUndefined = 4
}; };
// Javascript binop typers. Type* singleton_false() const { return singleton_false_; }
#define DECLARE_CASE(x) Type* Type##x(Type* lhs, Type* rhs); Type* singleton_true() const { return singleton_true_; }
JS_SIMPLE_BINOP_LIST(DECLARE_CASE) Type* singleton_the_hole() const { return singleton_the_hole_; }
#undef DECLARE_CASE
Type* singleton_false() { return singleton_false_; }
Type* singleton_true() { return singleton_true_; }
Type* singleton_the_hole() { return singleton_the_hole_; }
private: private:
typedef base::Flags<ComparisonOutcomeFlags> ComparisonOutcome; typedef base::Flags<ComparisonOutcomeFlags> ComparisonOutcome;
...@@ -68,14 +66,16 @@ class OperationTyper { ...@@ -68,14 +66,16 @@ class OperationTyper {
Type* SubtractRanger(RangeType* lhs, RangeType* rhs); Type* SubtractRanger(RangeType* lhs, RangeType* rhs);
Type* MultiplyRanger(Type* lhs, Type* rhs); Type* MultiplyRanger(Type* lhs, Type* rhs);
Zone* zone() { return zone_; } Zone* zone() const { return zone_; }
Zone* zone_; Zone* const zone_;
TypeCache const& cache_; TypeCache const& cache_;
Type* singleton_false_; Type* singleton_false_;
Type* singleton_true_; Type* singleton_true_;
Type* singleton_the_hole_; Type* singleton_the_hole_;
Type* signed32ish_;
Type* unsigned32ish_;
}; };
} // namespace compiler } // namespace compiler
......
...@@ -358,85 +358,38 @@ class RepresentationSelector { ...@@ -358,85 +358,38 @@ class RepresentationSelector {
} }
switch (node->opcode()) { switch (node->opcode()) {
case IrOpcode::kNumberAdd: #define DECLARE_CASE(Name) \
case IrOpcode::kSpeculativeNumberAdd: { case IrOpcode::k##Name: { \
// TODO(jarin) The ToNumber conversion is too conservative here, new_type = op_typer_.Name(FeedbackTypeOf(node->InputAt(0)), \
// e.g. it will treat true as 1 even though the number check will FeedbackTypeOf(node->InputAt(1))); \
// fail on a boolean. OperationTyper should have a function that break; \
// computes a more precise type. }
Type* lhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(0))); SIMPLIFIED_NUMBER_BINOP_LIST(DECLARE_CASE)
Type* rhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(1))); #undef DECLARE_CASE
Type* computed_type = op_typer_.NumberAdd(lhs, rhs);
new_type = Type::Intersect(computed_type, info->restriction_type(), #define DECLARE_CASE(Name) \
graph_zone()); case IrOpcode::k##Name: { \
break; new_type = \
} Type::Intersect(op_typer_.Name(FeedbackTypeOf(node->InputAt(0)), \
FeedbackTypeOf(node->InputAt(1))), \
case IrOpcode::kNumberSubtract: info->restriction_type(), graph_zone()); \
case IrOpcode::kSpeculativeNumberSubtract: { break; \
// TODO(jarin) The ToNumber conversion is too conservative here, }
// e.g. it will treat true as 1 even though the number check will SIMPLIFIED_SPECULATIVE_NUMBER_BINOP_LIST(DECLARE_CASE)
// fail on a boolean. OperationTyper should have a function that #undef DECLARE_CASE
// computes a more precise type.
Type* lhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(0))); #define DECLARE_CASE(Name) \
Type* rhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(1))); case IrOpcode::k##Name: { \
Type* computed_type = op_typer_.NumberSubtract(lhs, rhs); new_type = op_typer_.Name(FeedbackTypeOf(node->InputAt(0))); \
new_type = Type::Intersect(computed_type, info->restriction_type(), break; \
graph_zone()); }
break; SIMPLIFIED_NUMBER_UNOP_LIST(DECLARE_CASE)
} #undef DECLARE_CASE
case IrOpcode::kNumberMultiply:
case IrOpcode::kSpeculativeNumberMultiply: {
// TODO(jarin) The ToNumber conversion is too conservative here,
// e.g. it will treat true as 1 even though the number check will
// fail on a boolean. OperationTyper should have a function that
// computes a more precise type.
Type* lhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(0)));
Type* rhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(1)));
Type* computed_type = op_typer_.NumberMultiply(lhs, rhs);
new_type = Type::Intersect(computed_type, info->restriction_type(),
graph_zone());
break;
}
case IrOpcode::kNumberDivide:
case IrOpcode::kSpeculativeNumberDivide: {
// TODO(jarin) The ToNumber conversion is too conservative here,
// e.g. it will treat true as 1 even though the number check will
// fail on a boolean. OperationTyper should have a function that
// computes a more precise type.
Type* lhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(0)));
Type* rhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(1)));
Type* computed_type = op_typer_.NumberDivide(lhs, rhs);
new_type = Type::Intersect(computed_type, info->restriction_type(),
graph_zone());
break;
}
case IrOpcode::kNumberModulus:
case IrOpcode::kSpeculativeNumberModulus: {
// TODO(jarin) The ToNumber conversion is too conservative here,
// e.g. it will treat true as 1 even though the number check will
// fail on a boolean. OperationTyper should have a function that
// computes a more precise type.
Type* lhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(0)));
Type* rhs = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(1)));
Type* computed_type = op_typer_.NumberModulus(lhs, rhs);
new_type = Type::Intersect(computed_type, info->restriction_type(),
graph_zone());
break;
}
case IrOpcode::kPlainPrimitiveToNumber: case IrOpcode::kPlainPrimitiveToNumber:
new_type = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(0))); new_type = op_typer_.ToNumber(FeedbackTypeOf(node->InputAt(0)));
break; break;
case IrOpcode::kNumberAbs: {
new_type = op_typer_.NumberAbs(FeedbackTypeOf(node->InputAt(0)));
break;
}
case IrOpcode::kPhi: { case IrOpcode::kPhi: {
new_type = TypePhi(node); new_type = TypePhi(node);
if (type != nullptr) { if (type != nullptr) {
......
This diff is collapsed.
...@@ -48,8 +48,6 @@ class Typer { ...@@ -48,8 +48,6 @@ class Typer {
Type* singleton_false_; Type* singleton_false_;
Type* singleton_true_; Type* singleton_true_;
Type* singleton_the_hole_; Type* singleton_the_hole_;
Type* signed32ish_;
Type* unsigned32ish_;
Type* falsish_; Type* falsish_;
Type* truish_; Type* truish_;
......
...@@ -50,6 +50,7 @@ class TypeCache final { ...@@ -50,6 +50,7 @@ class TypeCache final {
Type::Union(kSingletonTen, Type::Undefined(), zone()); Type::Union(kSingletonTen, Type::Undefined(), zone());
Type* const kMinusOneOrZero = CreateRange(-1.0, 0.0); Type* const kMinusOneOrZero = CreateRange(-1.0, 0.0);
Type* const kZeroOrOne = CreateRange(0.0, 1.0); Type* const kZeroOrOne = CreateRange(0.0, 1.0);
Type* const kZeroOrOneOrNaN = Type::Union(kZeroOrOne, Type::NaN(), zone());
Type* const kZeroToThirtyOne = CreateRange(0.0, 31.0); Type* const kZeroToThirtyOne = CreateRange(0.0, 31.0);
Type* const kZeroToThirtyTwo = CreateRange(0.0, 32.0); Type* const kZeroToThirtyTwo = CreateRange(0.0, 32.0);
Type* const kZeroish = Type* const kZeroish =
......
...@@ -220,7 +220,9 @@ namespace internal { ...@@ -220,7 +220,9 @@ namespace internal {
V(UniqueName, kSymbol | kInternalizedString) \ V(UniqueName, kSymbol | kInternalizedString) \
V(Name, kSymbol | kString) \ V(Name, kSymbol | kString) \
V(BooleanOrNumber, kBoolean | kNumber) \ V(BooleanOrNumber, kBoolean | kNumber) \
V(BooleanOrNullOrNumber, kBooleanOrNumber | kNull) \
V(BooleanOrNullOrUndefined, kBoolean | kNull | kUndefined) \ V(BooleanOrNullOrUndefined, kBoolean | kNull | kUndefined) \
V(NullOrNumber, kNull | kNumber) \
V(NullOrUndefined, kNull | kUndefined) \ V(NullOrUndefined, kNull | kUndefined) \
V(Undetectable, kNullOrUndefined | kOtherUndetectable) \ V(Undetectable, kNullOrUndefined | kOtherUndetectable) \
V(NumberOrOddball, kNumber | kNullOrUndefined | kBoolean) \ V(NumberOrOddball, kNumber | kNullOrUndefined | kBoolean) \
......
...@@ -1547,84 +1547,6 @@ TEST(UpdatePhi) { ...@@ -1547,84 +1547,6 @@ TEST(UpdatePhi) {
} }
TEST(RunNumberDivide_minus_1_TruncatingToInt32) {
SimplifiedLoweringTester<Object*> t(MachineType::AnyTagged());
Node* num = t.NumberToInt32(t.Parameter(0));
Node* div = t.NumberDivide(num, t.jsgraph.Constant(-1));
Node* trunc = t.NumberToInt32(div);
t.Return(trunc);
t.LowerAllNodesAndLowerChanges();
t.GenerateCode();
FOR_INT32_INPUTS(i) {
int32_t x = 0 - *i;
t.CheckNumberCall(static_cast<double>(x), static_cast<double>(*i));
}
}
TEST(RunNumberMultiply_TruncatingToInt32) {
int32_t constants[] = {-100, -10, -1, 0, 1, 100, 1000, 3000999};
for (size_t i = 0; i < arraysize(constants); i++) {
double k = static_cast<double>(constants[i]);
SimplifiedLoweringTester<Object*> t(MachineType::AnyTagged());
Node* num = t.NumberToInt32(t.Parameter(0));
Node* mul = t.NumberMultiply(num, t.jsgraph.Constant(k));
Node* trunc = t.NumberToInt32(mul);
t.Return(trunc);
t.LowerAllNodesAndLowerChanges();
t.GenerateCode();
FOR_INT32_INPUTS(i) {
int32_t x = DoubleToInt32(static_cast<double>(*i) * k);
t.CheckNumberCall(static_cast<double>(x), static_cast<double>(*i));
}
}
}
TEST(RunNumberMultiply_TruncatingToUint32) {
uint32_t constants[] = {0, 1, 2, 3, 4, 100, 1000, 1024, 2048, 3000999};
for (size_t i = 0; i < arraysize(constants); i++) {
double k = static_cast<double>(constants[i]);
SimplifiedLoweringTester<Object*> t(MachineType::AnyTagged());
Node* num = t.NumberToUint32(t.Parameter(0));
Node* mul = t.NumberMultiply(num, t.jsgraph.Constant(k));
Node* trunc = t.NumberToUint32(mul);
t.Return(trunc);
t.LowerAllNodesAndLowerChanges();
t.GenerateCode();
FOR_UINT32_INPUTS(i) {
uint32_t x = DoubleToUint32(static_cast<double>(*i) * k);
t.CheckNumberCall(static_cast<double>(x), static_cast<double>(*i));
}
}
}
TEST(RunNumberDivide_2_TruncatingToUint32) {
SimplifiedLoweringTester<Object*> t(MachineType::AnyTagged());
Node* num = t.NumberToUint32(t.Parameter(0));
Node* div = t.NumberDivide(num, t.jsgraph.Constant(2));
Node* trunc = t.NumberToUint32(div);
t.Return(trunc);
t.LowerAllNodesAndLowerChanges();
t.GenerateCode();
FOR_UINT32_INPUTS(i) {
uint32_t x = DoubleToUint32(static_cast<double>(*i / 2.0));
t.CheckNumberCall(static_cast<double>(x), static_cast<double>(*i));
}
}
TEST(NumberMultiply_ConstantOutOfRange) { TEST(NumberMultiply_ConstantOutOfRange) {
TestingGraph t(Type::Signed32()); TestingGraph t(Type::Signed32());
Node* k = t.jsgraph.Constant(1000000023); Node* k = t.jsgraph.Constant(1000000023);
...@@ -1664,29 +1586,6 @@ TEST(NumberDivide_TruncatingToInt32) { ...@@ -1664,29 +1586,6 @@ TEST(NumberDivide_TruncatingToInt32) {
} }
TEST(RunNumberDivide_TruncatingToInt32) {
int32_t constants[] = {-100, -10, -1, 1, 2, 100, 1000, 1024, 2048};
for (size_t i = 0; i < arraysize(constants); i++) {
int32_t k = constants[i];
SimplifiedLoweringTester<Object*> t(MachineType::AnyTagged());
Node* num = t.NumberToInt32(t.Parameter(0));
Node* div = t.NumberDivide(num, t.jsgraph.Constant(k));
Node* trunc = t.NumberToInt32(div);
t.Return(trunc);
t.LowerAllNodesAndLowerChanges();
t.GenerateCode();
FOR_INT32_INPUTS(i) {
if (*i == INT_MAX) continue; // exclude max int.
int32_t x = DoubleToInt32(static_cast<double>(*i) / k);
t.CheckNumberCall(static_cast<double>(x), static_cast<double>(*i));
}
}
}
TEST(NumberDivide_TruncatingToUint32) { TEST(NumberDivide_TruncatingToUint32) {
double constants[] = {1, 3, 100, 1000, 100998348}; double constants[] = {1, 3, 100, 1000, 100998348};
...@@ -1703,28 +1602,6 @@ TEST(NumberDivide_TruncatingToUint32) { ...@@ -1703,28 +1602,6 @@ TEST(NumberDivide_TruncatingToUint32) {
} }
TEST(RunNumberDivide_TruncatingToUint32) {
uint32_t constants[] = {100, 10, 1, 1, 2, 4, 1000, 1024, 2048};
for (size_t i = 0; i < arraysize(constants); i++) {
uint32_t k = constants[i];
SimplifiedLoweringTester<Object*> t(MachineType::AnyTagged());
Node* num = t.NumberToUint32(t.Parameter(0));
Node* div = t.NumberDivide(num, t.jsgraph.Constant(static_cast<double>(k)));
Node* trunc = t.NumberToUint32(div);
t.Return(trunc);
t.LowerAllNodesAndLowerChanges();
t.GenerateCode();
FOR_UINT32_INPUTS(i) {
uint32_t x = *i / k;
t.CheckNumberCall(static_cast<double>(x), static_cast<double>(*i));
}
}
}
TEST(NumberDivide_BadConstants) { TEST(NumberDivide_BadConstants) {
{ {
TestingGraph t(Type::Signed32()); TestingGraph t(Type::Signed32());
...@@ -1779,29 +1656,6 @@ TEST(NumberModulus_TruncatingToInt32) { ...@@ -1779,29 +1656,6 @@ TEST(NumberModulus_TruncatingToInt32) {
} }
TEST(RunNumberModulus_TruncatingToInt32) {
int32_t constants[] = {-100, -10, -1, 1, 2, 100, 1000, 1024, 2048};
for (size_t i = 0; i < arraysize(constants); i++) {
int32_t k = constants[i];
SimplifiedLoweringTester<Object*> t(MachineType::AnyTagged());
Node* num = t.NumberToInt32(t.Parameter(0));
Node* mod = t.NumberModulus(num, t.jsgraph.Constant(k));
Node* trunc = t.NumberToInt32(mod);
t.Return(trunc);
t.LowerAllNodesAndLowerChanges();
t.GenerateCode();
FOR_INT32_INPUTS(i) {
if (*i == INT_MAX) continue; // exclude max int.
int32_t x = DoubleToInt32(std::fmod(static_cast<double>(*i), k));
t.CheckNumberCall(static_cast<double>(x), static_cast<double>(*i));
}
}
}
TEST(NumberModulus_TruncatingToUint32) { TEST(NumberModulus_TruncatingToUint32) {
double constants[] = {1, 3, 100, 1000, 100998348}; double constants[] = {1, 3, 100, 1000, 100998348};
...@@ -1818,29 +1672,6 @@ TEST(NumberModulus_TruncatingToUint32) { ...@@ -1818,29 +1672,6 @@ TEST(NumberModulus_TruncatingToUint32) {
} }
TEST(RunNumberModulus_TruncatingToUint32) {
uint32_t constants[] = {1, 2, 100, 1000, 1024, 2048};
for (size_t i = 0; i < arraysize(constants); i++) {
uint32_t k = constants[i];
SimplifiedLoweringTester<Object*> t(MachineType::AnyTagged());
Node* num = t.NumberToUint32(t.Parameter(0));
Node* mod =
t.NumberModulus(num, t.jsgraph.Constant(static_cast<double>(k)));
Node* trunc = t.NumberToUint32(mod);
t.Return(trunc);
t.LowerAllNodesAndLowerChanges();
t.GenerateCode();
FOR_UINT32_INPUTS(i) {
uint32_t x = *i % k;
t.CheckNumberCall(static_cast<double>(x), static_cast<double>(*i));
}
}
}
TEST(NumberModulus_Int32) { TEST(NumberModulus_Int32) {
int32_t constants[] = {-100, -10, 1, 4, 100, 1000}; int32_t constants[] = {-100, -10, 1, 4, 100, 1000};
......
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