integral32-add-sub.js 3.5 KB
Newer Older
1 2 3 4
// 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.

5
// Flags: --allow-natives-syntax --opt
6 7 8 9 10 11 12 13

(function() {
  function foo(x) {
    x = x >>> 0;
    var y = 0 - 2147483648;
    return x + y;
  }

14
  %PrepareFunctionForOptimization(foo);
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
  assertEquals(-2147483648, foo(0));
  assertEquals(0, foo(2147483648));
  assertEquals(2147483647, foo(4294967295));
  assertEquals(-2147483648, foo(0));
  assertEquals(0, foo(2147483648));
  assertEquals(2147483647, foo(4294967295));
  %OptimizeFunctionOnNextCall(foo);
  assertEquals(-2147483648, foo(0));
  assertEquals(0, foo(2147483648));
  assertEquals(2147483647, foo(4294967295));
  assertOptimized(foo);
})();

(function() {
  function foo(x) {
    x = x >>> 0;
    var y = 2147483648;
    return x - y;
  }

35
  %PrepareFunctionForOptimization(foo);
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
  assertEquals(-2147483648, foo(0));
  assertEquals(0, foo(2147483648));
  assertEquals(2147483647, foo(4294967295));
  assertEquals(-2147483648, foo(0));
  assertEquals(0, foo(2147483648));
  assertEquals(2147483647, foo(4294967295));
  %OptimizeFunctionOnNextCall(foo);
  assertEquals(-2147483648, foo(0));
  assertEquals(0, foo(2147483648));
  assertEquals(2147483647, foo(4294967295));
  assertOptimized(foo);
})();

(function() {
  function foo(x) {
    x = x | 0;
    var y = 2147483648;
    return x + y;
  }

56
  %PrepareFunctionForOptimization(foo);
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
  assertEquals(2147483648, foo(0));
  assertEquals(0, foo(-2147483648));
  assertEquals(4294967295, foo(2147483647));
  assertEquals(2147483648, foo(0));
  assertEquals(0, foo(-2147483648));
  assertEquals(4294967295, foo(2147483647));
  %OptimizeFunctionOnNextCall(foo);
  assertEquals(2147483648, foo(0));
  assertEquals(0, foo(-2147483648));
  assertEquals(4294967295, foo(2147483647));
  assertOptimized(foo);
})();

(function() {
  function foo(x) {
    x = x | 0;
    var y = 0 - 2147483648;
    return x - y;
  }

77
  %PrepareFunctionForOptimization(foo);
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
  assertEquals(2147483648, foo(0));
  assertEquals(0, foo(-2147483648));
  assertEquals(4294967295, foo(2147483647));
  assertEquals(2147483648, foo(0));
  assertEquals(0, foo(-2147483648));
  assertEquals(4294967295, foo(2147483647));
  %OptimizeFunctionOnNextCall(foo);
  assertEquals(2147483648, foo(0));
  assertEquals(0, foo(-2147483648));
  assertEquals(4294967295, foo(2147483647));
  assertOptimized(foo);
})();

(function() {
  function foo(x) {
    x = x | 0;
    var y = -0;
    return x + y;
  }

98
  %PrepareFunctionForOptimization(foo);
99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118
  assertEquals(2147483647, foo(2147483647));
  assertEquals(-2147483648, foo(-2147483648));
  assertEquals(0, foo(0));
  assertEquals(2147483647, foo(2147483647));
  assertEquals(-2147483648, foo(-2147483648));
  assertEquals(0, foo(0));
  %OptimizeFunctionOnNextCall(foo);
  assertEquals(2147483647, foo(2147483647));
  assertEquals(-2147483648, foo(-2147483648));
  assertEquals(0, foo(0));
  assertOptimized(foo);
})();

(function() {
  function foo(x) {
    var y = (x < 0) ? 4294967295 : 4294967296;
    var z = (x > 0) ? 2147483647 : 2147483648;
    return y - z;
  }

119
  %PrepareFunctionForOptimization(foo);
120 121 122 123 124 125 126 127 128 129 130 131
  assertEquals(2147483647, foo(-1));
  assertEquals(2147483648, foo(0));
  assertEquals(2147483649, foo(1));
  assertEquals(2147483647, foo(-1));
  assertEquals(2147483648, foo(0));
  assertEquals(2147483649, foo(1));
  %OptimizeFunctionOnNextCall(foo);
  assertEquals(2147483647, foo(-1));
  assertEquals(2147483648, foo(0));
  assertEquals(2147483649, foo(1));
  assertOptimized(foo);
})();