Commit 1decc266 authored by jyan's avatar jyan Committed by Commit bot

S390: [turbofan] Introduce TruncateTaggedToWord32 simplified operator.

Port 0231a7ef

Original commit message:

    This allows us to get rid of the "push TruncateFloat64ToInt32 into Phi"
    trick that was used in the MachineOperatorReducer to combine the
    ChangeTaggedToFloat64 and TruncateFloat64ToInt32 operations. Instead of
    doing that later, we can just introduce the proper operator during the
    representation selection directly.

    Also separate the TruncateFloat64ToInt32 machine operator, which had two
    different meanings depending on a flag (either JavaScript truncation or
    C++ style round to zero). Now there's a TruncateFloat64ToWord32 which
    represents the JavaScript truncation (implemented via TruncateDoubleToI
    macro + code stub) and the RoundFloat64ToInt32, which implements the C++
    round towards zero operation (in the same style as the other WebAssembly
    driven Round* machine operators).

R=bmeurer@chromium.org, joransiu@ca.ibm.com, bjaideep@ca.ibm.com, michael_dawson@ca.ibm.com, mbrandy@us.ibm.com

BUG=
LOG=N

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

Cr-Commit-Position: refs/heads/master@{#35802}
parent 5e28bf7b
...@@ -1039,13 +1039,11 @@ void InstructionSelector::VisitTruncateFloat64ToFloat32(Node* node) { ...@@ -1039,13 +1039,11 @@ void InstructionSelector::VisitTruncateFloat64ToFloat32(Node* node) {
} }
void InstructionSelector::VisitTruncateFloat64ToWord32(Node* node) { void InstructionSelector::VisitTruncateFloat64ToWord32(Node* node) {
switch (TruncationModeOf(node->op())) { VisitRR(this, kArchTruncateDoubleToI, node);
case TruncationMode::kJavaScript: }
return VisitRR(this, kArchTruncateDoubleToI, node);
case TruncationMode::kRoundToZero: void InstructionSelector::VisitRoundFloat64ToInt32(Node* node) {
return VisitRR(this, kS390_DoubleToInt32, node); VisitRR(this, kS390_DoubleToInt32, node);
}
UNREACHABLE();
} }
void InstructionSelector::VisitTruncateFloat32ToInt32(Node* node) { void InstructionSelector::VisitTruncateFloat32ToInt32(Node* node) {
......
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