// Copyright 2016 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // Flags: --allow-natives-syntax var a = new Float64Array(4); a[2] *= -1; a[3] *= -1; assertEquals(0, a[0]); assertEquals(0, a[1]); assertEquals(-0, a[2]); assertEquals(-0, a[3]); function f1() { var z = a[0]; // Same register. assertEquals(0, Math.min(z, z)); }; %PrepareFunctionForOptimization(f1); function f2() { // Different registers. assertEquals(0, Math.min(a[0], a[1])); }; %PrepareFunctionForOptimization(f2); function f3() { // Zero and minus zero. assertEquals(-0, Math.min(a[1], a[2])); }; %PrepareFunctionForOptimization(f3); function f4() { // Zero and minus zero, reversed order. assertEquals(-0, Math.min(a[2], a[1])); }; %PrepareFunctionForOptimization(f4); function f5() { // Minus zero, same register. var m_z = a[2]; assertEquals(-0, Math.min(m_z, m_z)); }; %PrepareFunctionForOptimization(f5); function f6() { // Minus zero, different registers. assertEquals(-0, Math.min(a[2], a[3])); }; %PrepareFunctionForOptimization(f6); for (var i = 0; i < 3; i++) { f1(); f2(); f3(); f4(); f5(); f6(); } %OptimizeFunctionOnNextCall(f1); %OptimizeFunctionOnNextCall(f2); %OptimizeFunctionOnNextCall(f3); %OptimizeFunctionOnNextCall(f4); %OptimizeFunctionOnNextCall(f5); %OptimizeFunctionOnNextCall(f6); f1(); f2(); f3(); f4(); f5(); f6();