1. 06 Jun, 2016 1 commit
    • zhengxing.li's avatar
      X87: [builtins] Migrate Math.log to TurboFan. · 973823e4
      zhengxing.li authored
        port f2da19fe (r36703)
      
        original commit message:
        Introduce a dedicated Float64Log machine operator, that is either
        implemented by a direct C call or by platform specific code, i.e.
        using the FPU on x64 and ia32.
      
        This operator is used to implement Math.log as a proper TurboFan
        builtin on top of the CodeStubAssembler.
      
        Also introduce a NumberLog simplified operator on top of Float64Log
        and use that for the fast inline path of Math.log inside TurboFan
        optimized code.
      
      BUG=
      
      Review-Url: https://codereview.chromium.org/2034393002
      Cr-Commit-Position: refs/heads/master@{#36727}
      973823e4
  2. 04 Jun, 2016 3 commits
    • oth's avatar
      [interpreter] Faster and fewer flushes in register optimizer. · ecd4086c
      oth authored
      This change requires a single pass over the register set during
      bytecode pipeline flushes.
      
      A few bytecode tests are updated too because the order of register
      flushes is different.
      
      BUG=v8:4280
      LOG=N
      
      Review-Url: https://codereview.chromium.org/2033013002
      Cr-Commit-Position: refs/heads/master@{#36726}
      ecd4086c
    • brucedawson's avatar
      Add standard Windows manifest to five v8 executables · ac03c63c
      brucedawson authored
      Many executables are missing embedded manifest files when built with gn.
      This causes OS compatibility information to be omitted which can lead
      to strange behavior. This change adds a manifest to:
      
        v8_simple_json_fuzzer.exe
        v8_simple_parser_fuzzer.exe
        v8_simple_regexp_fuzzer.exe
        v8_simple_wasm_asmjs_fuzzer.exe
        v8_simple_wasm_fuzzer.exe
      
      BUG=chromium:602505
      
      Review-Url: https://codereview.chromium.org/2040623003
      Cr-Commit-Position: refs/heads/master@{#36725}
      ac03c63c
    • jyan's avatar
      S390: [builtins] Migrate Math.log to TurboFan. · 00c158a6
      jyan authored
      Port f2da19fe
      
      Original commit message:
      
          Introduce a dedicated Float64Log machine operator, that is either
          implemented by a direct C call or by platform specific code, i.e.
          using the FPU on x64 and ia32.
      
          This operator is used to implement Math.log as a proper TurboFan
          builtin on top of the CodeStubAssembler.
      
          Also introduce a NumberLog simplified operator on top of Float64Log
          and use that for the fast inline path of Math.log inside TurboFan
          optimized code.
      
      R=bmeurer@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com, mbrandy@us.ibm.com, bjaideep@ca.ibm.com
      BUG=
      
      Review-Url: https://codereview.chromium.org/2033353003
      Cr-Commit-Position: refs/heads/master@{#36724}
      00c158a6
  3. 03 Jun, 2016 32 commits
  4. 02 Jun, 2016 4 commits
    • jyan's avatar
      S390: Store Floats as 4 bytes and Double as 8 bytes for codegen · 4d8bcd11
      jyan authored
      R=joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com, mbrandy@us.ibm.com, bjaideep@ca.ibm.com
      BUG=
      
      Review-Url: https://codereview.chromium.org/2036523003
      Cr-Commit-Position: refs/heads/master@{#36691}
      4d8bcd11
    • danno's avatar
      [turbofan] Fix assert caused by bogus merging of out-of-scope CodeAssembler variables · 70e302ee
      danno authored
      Previously, CodeAssembler Variables declared in an explicit C++ scope would
      continue to be merged into future labels beyond that scope, causing
      asserts. This CL ensures that Variables are properly ignored when they go out of
      scope.
      
      Review-Url: https://codereview.chromium.org/2035683002
      Cr-Commit-Position: refs/heads/master@{#36690}
      70e302ee
    • danno's avatar
      [turbofan] Fix phi-hinting problem with deferred blocks · afb0e7a4
      danno authored
      Previously, turbofan selected the gap use from first predecessor block when
      hinting a phi, unless that block was deferred, in which case the gap move from
      the first non-deferred predecessor block was chosen.
      
      This strategy didn't guarantee that an important invariant was maintained: the
      predecessor blocks chosen for hinting phis must preceed the phi's block in the
      rpo ordering. In most cases the strategy worked, since graphs generated by the
      AstGraphBuilder and existing stubs just happened to always generate schedules
      where this rpo ordering property for the first predecessor block, but it is
      quite possible to generate a code stub by hand that doesn't have this property
      (see included test case).
      
      After this CL, the allocator chooses either the the first non-deferred
      "rpo-preceeding" block to be the hinting block, or the first deferred
      "rpo-preceeding" block if that doesn't exist. In all previously-existing code,
      this behavior is the same as the original algorithm, but has the benefit of not
      failing in the register allocator in hand-crafted stubs where all the
      "rpo-preceeding" predecessors are all in deferred code.
      
      Review-Url: https://codereview.chromium.org/2030463003
      Cr-Commit-Position: refs/heads/master@{#36689}
      afb0e7a4
    • gsathya's avatar
      Promises: Make PromiseSet operation monomorphic · df4f8a2b
      gsathya authored
      The PromiseSet operation is called with two types of promises
      1) A newly created promise object with no properties
      2) Promise object with callbacks and other properties
      
      PromiseSet is called with the first type of promise (with no
      properties) from multiple call sites. PromiseSet is called with the
      second type of promise object only from FulfillPromise. Furthermore,
      this call only sets the value and status of the promise, the rest of
      the values are reset to UNDEFINED (which isn't necessary).
      
      This patch inlines the calls to set the value and status of the
      promise in FulfillPromise, instead of calling out to PromiseSet.
      
      This patch also reduces the number of symbol lookups, as we only set
      the value and status of the promise, and don't change the callback or
      deferred symbols.
      
      This patch results in a performance improvement of 2.8% over 5 runs in
      the bluebird benchmark.
      
      BUG=v8:5046
      
      Review-Url: https://codereview.chromium.org/2025073002
      Cr-Commit-Position: refs/heads/master@{#36688}
      df4f8a2b