Commit 305d42c0 authored by bjaideep's avatar bjaideep Committed by Commit bot

PPC/s390: [builtins] Unify most of the remaining Math builtins.

Port 0a0fe8fb

Original commit message:

Import fdlibm versions of acos, acosh, asin and asinh, which are more
    precise and produce the same result across platforms (we were using
    libm versions for asin and acos so far, where both speed and precision
    depended on the operating system so far). Introduce appropriate TurboFan
    operators for these functions and use them both for inlining and for the
    generic builtin.

    Also migrate the Math.imul and Math.fround builtins to TurboFan builtins
    to ensure that their behavior is always exactly the same as the inlined
    TurboFan version (i.e. C++ truncation semantics for double to float
    don't necessarily meet the JavaScript semantics).

    For completeness, also migrate Math.sign, which can even get some nice
    love in TurboFan.

    Drive-by-fix: Some alpha-sorting on the Math related functions, and
    cleanup the list of Math intrinsics that we have to export via the
    native context currently.

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

BUG=v8:3266,v8:3496,v8:3509,v8:3952,v8:5169,v8:5170,v8:5171,v8:5172
LOG=N

Review-Url: https://codereview.chromium.org/2125723002
Cr-Commit-Position: refs/heads/master@{#37539}
parent 9a4132aa
...@@ -1262,15 +1262,33 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -1262,15 +1262,33 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
// and generate a CallAddress instruction instead. // and generate a CallAddress instruction instead.
ASSEMBLE_FLOAT_MODULO(); ASSEMBLE_FLOAT_MODULO();
break; break;
case kIeee754Float64Acos:
ASSEMBLE_IEEE754_UNOP(acos);
break;
case kIeee754Float64Acosh:
ASSEMBLE_IEEE754_UNOP(acosh);
break;
case kIeee754Float64Asin:
ASSEMBLE_IEEE754_UNOP(asin);
break;
case kIeee754Float64Asinh:
ASSEMBLE_IEEE754_UNOP(asinh);
break;
case kIeee754Float64Atan: case kIeee754Float64Atan:
ASSEMBLE_IEEE754_UNOP(atan); ASSEMBLE_IEEE754_UNOP(atan);
break; break;
case kIeee754Float64Atan2: case kIeee754Float64Atan2:
ASSEMBLE_IEEE754_BINOP(atan2); ASSEMBLE_IEEE754_BINOP(atan2);
break; break;
case kIeee754Float64Atanh:
ASSEMBLE_IEEE754_UNOP(atanh);
break;
case kIeee754Float64Tan: case kIeee754Float64Tan:
ASSEMBLE_IEEE754_UNOP(tan); ASSEMBLE_IEEE754_UNOP(tan);
break; break;
case kIeee754Float64Tanh:
ASSEMBLE_IEEE754_UNOP(tanh);
break;
case kIeee754Float64Cbrt: case kIeee754Float64Cbrt:
ASSEMBLE_IEEE754_UNOP(cbrt); ASSEMBLE_IEEE754_UNOP(cbrt);
break; break;
...@@ -1292,12 +1310,6 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -1292,12 +1310,6 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
case kIeee754Float64Expm1: case kIeee754Float64Expm1:
ASSEMBLE_IEEE754_UNOP(expm1); ASSEMBLE_IEEE754_UNOP(expm1);
break; break;
case kIeee754Float64Atanh:
ASSEMBLE_IEEE754_UNOP(atanh);
break;
case kIeee754Float64Tanh:
ASSEMBLE_IEEE754_UNOP(tanh);
break;
case kIeee754Float64Log: case kIeee754Float64Log:
ASSEMBLE_IEEE754_UNOP(log); ASSEMBLE_IEEE754_UNOP(log);
break; break;
......
...@@ -1246,6 +1246,21 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -1246,6 +1246,21 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
case kS390_ModDouble: case kS390_ModDouble:
ASSEMBLE_FLOAT_MODULO(); ASSEMBLE_FLOAT_MODULO();
break; break;
case kIeee754Float64Acos:
ASSEMBLE_IEEE754_UNOP(acos);
break;
case kIeee754Float64Acosh:
ASSEMBLE_IEEE754_UNOP(acosh);
break;
case kIeee754Float64Asin:
ASSEMBLE_IEEE754_UNOP(asin);
break;
case kIeee754Float64Asinh:
ASSEMBLE_IEEE754_UNOP(asinh);
break;
case kIeee754Float64Atanh:
ASSEMBLE_IEEE754_UNOP(atanh);
break;
case kIeee754Float64Atan: case kIeee754Float64Atan:
ASSEMBLE_IEEE754_UNOP(atan); ASSEMBLE_IEEE754_UNOP(atan);
break; break;
...@@ -1255,6 +1270,9 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -1255,6 +1270,9 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
case kIeee754Float64Tan: case kIeee754Float64Tan:
ASSEMBLE_IEEE754_UNOP(tan); ASSEMBLE_IEEE754_UNOP(tan);
break; break;
case kIeee754Float64Tanh:
ASSEMBLE_IEEE754_UNOP(tanh);
break;
case kIeee754Float64Cbrt: case kIeee754Float64Cbrt:
ASSEMBLE_IEEE754_UNOP(cbrt); ASSEMBLE_IEEE754_UNOP(cbrt);
break; break;
...@@ -1276,12 +1294,6 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -1276,12 +1294,6 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
case kIeee754Float64Expm1: case kIeee754Float64Expm1:
ASSEMBLE_IEEE754_UNOP(expm1); ASSEMBLE_IEEE754_UNOP(expm1);
break; break;
case kIeee754Float64Atanh:
ASSEMBLE_IEEE754_UNOP(atanh);
break;
case kIeee754Float64Tanh:
ASSEMBLE_IEEE754_UNOP(tanh);
break;
case kIeee754Float64Log: case kIeee754Float64Log:
ASSEMBLE_IEEE754_UNOP(log); ASSEMBLE_IEEE754_UNOP(log);
break; break;
......
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