1. 01 Apr, 2016 2 commits
  2. 31 Mar, 2016 3 commits
  3. 30 Mar, 2016 1 commit
  4. 29 Mar, 2016 1 commit
  5. 22 Mar, 2016 4 commits
  6. 21 Mar, 2016 3 commits
  7. 17 Mar, 2016 2 commits
  8. 16 Mar, 2016 4 commits
  9. 15 Mar, 2016 2 commits
  10. 10 Mar, 2016 3 commits
  11. 09 Mar, 2016 7 commits
    • mbrandy's avatar
      PPC: [undetectable] Really get comparisons of document.all right now. · eaa38ad1
      mbrandy authored
      Port 679d9503
      
      Original commit message:
          According to https://www.w3.org/TR/html5/obsolete.html#dom-document-all,
          comparisons of document.all to other values such as strings or objects,
          are unaffected. In fact document.all only gets special treatment in
          comparisons with null or undefined according to HTML. Especially setting
          the undetectable doesn't make two distinct JSReceivers equal.
      
      R=bmeurer@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
      BUG=
      
      Review URL: https://codereview.chromium.org/1785503002
      
      Cr-Commit-Position: refs/heads/master@{#34645}
      eaa38ad1
    • mbrandy's avatar
      PPC: [turbofan] [deoptimizer] Support inlining of ES6 tail calls. · 209c2152
      mbrandy authored
      Port c29a4560
      
      Original commit message:
          In case when F was called with incompatible number of arguments (and therefore
          the arguments adator frame was created), F inlines a tail call of G which then
          deopts the deoptimizer should also remove the arguments adaptor frame for F.
      
          This CL adds required machinery to the deoptimizer.
      
      R=ishell@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
      BUG=v8:4698
      LOG=N
      
      Review URL: https://codereview.chromium.org/1775393004
      
      Cr-Commit-Position: refs/heads/master@{#34644}
      209c2152
    • mbrandy's avatar
      PPC: [runtime] Unify and simplify how frames are marked · 4445c095
      mbrandy authored
      Port 9dcd0857
      
      Original commit message:
          Before this CL, various code stubs used different techniques
          for marking their frames to enable stack-crawling and other
          access to data in the frame. All of them were based on a abuse
          of the "standard" frame representation, e.g. storing the a
          context pointer immediately below the frame's fp, and a
          function pointer after that. Although functional, this approach
          tends to make stubs and builtins do an awkward, unnecessary
          dance to appear like standard frames, even if they have
          nothing to do with JavaScript execution.
      
          This CL attempts to improve this by:
      
          * Ensuring that there are only two fundamentally different
            types of frames, a "standard" frame and a "typed" frame.
            Standard frames, as before, contain both a context and
            function pointer. Typed frames contain only a minimum
            of a smi marker in the position immediately below the fp
            where the context is in standard frames.
          * Only interpreted, full codegen, and optimized Crankshaft and
            TurboFan JavaScript frames use the "standard" format. All
            other frames use the type frame format with an explicit
            marker.
          * Typed frames can contain one or more values below the
            type marker. There is new magic macro machinery in
            frames.h that simplifies defining the offsets of these fields
            in typed frames.
          * A new flag in the CallDescriptor enables specifying whether
            a frame is a standard frame or a typed frame. Secondary
            register location spilling is now only enabled for standard
            frames.
          * A zillion places in the code have been updated to deal with
            the fact that most code stubs and internal frames use the
            typed frame format. This includes changes in the
            deoptimizer, debugger, and liveedit.
          * StandardFrameConstants::kMarkerOffset is deprecated,
            (CommonFrameConstants::kContextOrFrameTypeOffset
            and StandardFrameConstants::kFrameOffset are now used
            in its stead).
      
      R=danno@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
      BUG=
      
      Review URL: https://codereview.chromium.org/1778713002
      
      Cr-Commit-Position: refs/heads/master@{#34643}
      4445c095
    • mbrandy's avatar
      PPC: Fix "Rework CallApi*Stubs". · 50e43bc3
      mbrandy authored
      R=joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
      BUG=
      
      Review URL: https://codereview.chromium.org/1779803004
      
      Cr-Commit-Position: refs/heads/master@{#34642}
      50e43bc3
    • vogelheim's avatar
      Rework CallApi*Stubs. · 5096492f
      vogelheim authored
      - Eliminate stubs with a variable number of arguments.
        (That only worked due to their very limited use. These
         stubs' interface descriptors were basically lying
         about their number of args, which will fail when used
         generically.)
      - Fix all CallApi*Stubs' interface descriptors to no
        longer lie about their arguments.
      - Unify CallApi*Stub, for * in Function, Accessor,
        FunctionWithFixedArgs.
        (Since these are now all doing the same thing.)
      - Rename the unified stub (and interface descriptors) to
        *ApiCallback*, since that's really what they're doing.
      - Refuse inlining an API callback if its number of
        parameters exceeds the supported number of args.
      
      BUG=
      
      Committed: https://crrev.com/d238b953a474272c0e3ea22ef6a9b63fa9729340
      Cr-Commit-Position: refs/heads/master@{#34614}
      
      Review URL: https://codereview.chromium.org/1748123003
      
      Cr-Commit-Position: refs/heads/master@{#34627}
      5096492f
    • vogelheim's avatar
      Revert of Rework CallApi*Stubs. (patchset #5 id:100001 of... · 52a741d1
      vogelheim authored
      Revert of Rework CallApi*Stubs. (patchset #5 id:100001 of https://codereview.chromium.org/1748123003/ )
      
      Reason for revert:
      Breaks Chromium.
      
      Original issue's description:
      > Rework CallApi*Stubs.
      >
      > - Eliminate stubs with a variable number of arguments.
      >   (That only worked due to their very limited use. These
      >    stubs' interface descriptors were basically lying
      >    about their number of args, which will fail when used
      >    generically.)
      > - Fix all CallApi*Stubs' interface descriptors to no
      >   longer lie about their arguments.
      > - Unify CallApi*Stub, for * in Function, Accessor,
      >   FunctionWithFixedArgs.
      >   (Since these are now all doing the same thing.)
      > - Rename the unified stub (and interface descriptors) to
      >   *ApiCallback*, since that's really what they're doing.
      > - Refuse inlining an API callback if its number of
      >   parameters exceeds the supported number of args.
      >
      > BUG=
      >
      > Committed: https://crrev.com/d238b953a474272c0e3ea22ef6a9b63fa9729340
      > Cr-Commit-Position: refs/heads/master@{#34614}
      
      TBR=danno@chromium.org,jkummerow@chromium.org,mstarzinger@chromium.org
      # Skipping CQ checks because original CL landed less than 1 days ago.
      NOPRESUBMIT=true
      NOTREECHECKS=true
      NOTRY=true
      BUG=
      
      Review URL: https://codereview.chromium.org/1775933005
      
      Cr-Commit-Position: refs/heads/master@{#34624}
      52a741d1
    • vogelheim's avatar
      Rework CallApi*Stubs. · d238b953
      vogelheim authored
      - Eliminate stubs with a variable number of arguments.
        (That only worked due to their very limited use. These
         stubs' interface descriptors were basically lying
         about their number of args, which will fail when used
         generically.)
      - Fix all CallApi*Stubs' interface descriptors to no
        longer lie about their arguments.
      - Unify CallApi*Stub, for * in Function, Accessor,
        FunctionWithFixedArgs.
        (Since these are now all doing the same thing.)
      - Rename the unified stub (and interface descriptors) to
        *ApiCallback*, since that's really what they're doing.
      - Refuse inlining an API callback if its number of
        parameters exceeds the supported number of args.
      
      BUG=
      
      Review URL: https://codereview.chromium.org/1748123003
      
      Cr-Commit-Position: refs/heads/master@{#34614}
      d238b953
  12. 08 Mar, 2016 2 commits
  13. 07 Mar, 2016 1 commit
    • mbrandy's avatar
      PPC: [crankshaft] Support ES6 tail call elimination. · 826f67be
      mbrandy authored
      Port 22938040
      
      Original commit message:
          HInvokeFunction and HApplyArguments instructions now support tail calling.
      
          Inlining of calls at tail position is not supported yet and therefore still disabled.
      
          The tail-call-megatest was modified so that the usages of "arguments" object do not disable Crankshaft.
      
      R=ishell@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
      BUG=v8:4698
      LOG=N
      
      Review URL: https://codereview.chromium.org/1767173002
      
      Cr-Commit-Position: refs/heads/master@{#34563}
      826f67be
  14. 04 Mar, 2016 1 commit
    • mbrandy's avatar
      PPC: [compiler] Introduce code stubs for string relational comparisons. · 35bce027
      mbrandy authored
      Port 5912e0f0
      
      Original commit message:
          Add StringLessThanStub, StringLessThanOrEqualStub, StringGreaterThanStub
          and StringGreaterThanOrEqualStub, based on the CodeStubAssembler, and
          hook them up with TurboFan (and Ignition). The stubs are currently
          essentially comparable with the StringCompareStub, which is now
          obsolete. We can later extend these stubs to cover more interesting
          cases (i.e. two byte sequential string comparisons, etc.).
      
      R=bmeurer@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
      BUG=
      
      Review URL: https://codereview.chromium.org/1761403002
      
      Cr-Commit-Position: refs/heads/master@{#34508}
      35bce027
  15. 03 Mar, 2016 2 commits
  16. 02 Mar, 2016 2 commits