1. 23 Mar, 2020 8 commits
  2. 22 Mar, 2020 1 commit
  3. 21 Mar, 2020 2 commits
  4. 20 Mar, 2020 15 commits
  5. 19 Mar, 2020 14 commits
    • Ng Zhi An's avatar
      [wasm-simd][arm64] Use unique register for shifts · 1485de17
      Ng Zhi An authored
      The src register needs to be different from the temporary Simd128
      register since in the codegen we modify tmp before using tmp and src.
      
      Bug: chromium:1063006
      Change-Id: I8b4b2d23d8f090ea37041e82cac97470bcf0d833
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2111110Reviewed-by: 's avatarDeepti Gandluri <gdeepti@chromium.org>
      Commit-Queue: Zhi An Ng <zhin@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66799}
      1485de17
    • Iain Ireland's avatar
      Reland "[regexp] Rewrite error handling" · 560f2d8b
      Iain Ireland authored
      This is a reland of e80ca24c
      
      Original change's description:
      > [regexp] Rewrite error handling
      >
      > This patch modifies irregexp's error handling. Instead of representing
      > errors as C strings, they are represented as an enumeration value
      > (RegExpError), and only converted to strings when throwing the error
      > object in regexp.cc. This makes it significantly easier to integrate
      > into SpiderMonkey. A few notes:
      >
      > 1. Depending on whether the stack overflows during parsing or
      >    analysis, the stack overflow message can vary ("Stack overflow" or
      >    "Maximum call stack size exceeded"). I kept that behaviour in this
      >    patch, under the assumption that stack overflow messages are
      >    (sadly) the sorts of things that real world code ends up depending
      >    on.
      >
      > 2. Depending on the point in code where the error was identified,
      >    invalid unicode escapes could be reported as "Invalid Unicode
      >    escape", "Invalid unicode escape", or "Invalid Unicode escape
      >    sequence". I fervently hope that nobody depends on the specific
      >    wording of a syntax error, so I standardized on the first one. (It
      >    was both the most common, and the most consistent with other
      >    "Invalid X escape" messages.)
      >
      > 3. In addition to changing the representation, this patch also adds an
      >    error_pos field to RegExpParser and RegExpCompileData, which stores
      >    the position at which an error occurred. This is used by
      >    SpiderMonkey to provide more helpful messages about where a syntax
      >    error occurred in large regular expressions.
      >
      > 4. This model is closer to V8's existing MessageTemplate
      >    infrastructure. I considered trying to integrate it more closely
      >    with MessageTemplate, but since one of our stated goals for this
      >    project was to make it easier to use irregexp outside of V8, I
      >    decided to hold off.
      >
      > R=jgruber@chromium.org
      >
      > Bug: v8:10303
      > Change-Id: I62605fd2def2fc539f38a7e0eefa04d36e14bbde
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2091863
      > Commit-Queue: Jakob Gruber <jgruber@chromium.org>
      > Reviewed-by: Jakob Gruber <jgruber@chromium.org>
      > Cr-Commit-Position: refs/heads/master@{#66784}
      
      R=jgruber@chromium.org
      
      Bug: v8:10303
      Change-Id: Iad1f11a0e0b9e525d7499aacb56c27eff9e7c7b5
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2109952Reviewed-by: 's avatarJakob Gruber <jgruber@chromium.org>
      Commit-Queue: Jakob Gruber <jgruber@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66798}
      560f2d8b
    • Andreas Haas's avatar
      [wasm] Introduce a TableCopy builtin · 1e1d4d82
      Andreas Haas authored
      This CL introduces a CSA builtin for the TableCopy instruction. This
      builtin allows to generate smaller code for both TurboFan and Liftoff,
      and easier code generation from Liftoff.
      
      The smaller code size comes from:
      * Parameters are passed through registers, not the stack.
      * Lower number of parameters: the call target, number of parameters, and
      context are not passed as parameters.
      * No int to smi conversion in generated code.
      
      R=clemensb@chromium.org
      
      Bug: v8:10281
      Change-Id: I4734b94c8a2aff08a5938504e3e36d0d2424f8ca
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2110010
      Commit-Queue: Andreas Haas <ahaas@chromium.org>
      Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66797}
      1e1d4d82
    • Peter Marshall's avatar
      [unwinder] Advance deprecation of the old unwinder API · d1253ae9
      Peter Marshall authored
      Chrome uses the new version now.
      
      Bug: v8:8116
      Change-Id: I59af8d2c6a897a852acd6de3a7938a4b8d3943e4
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2110015Reviewed-by: 's avatarYang Guo <yangguo@chromium.org>
      Commit-Queue: Peter Marshall <petermarshall@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66796}
      d1253ae9
    • Ng Zhi An's avatar
      [wasm-simd][liftoff][arm][arm64] Implement sub for Liftoff · 4ac48b60
      Ng Zhi An authored
      Bug: v8:9909
      Change-Id: Ica1cb36e7e071e5755009d57a0f03080b74bbf8e
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2108743Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
      Commit-Queue: Zhi An Ng <zhin@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66795}
      4ac48b60
    • David Manouchehri's avatar
      [Intl] Correct RelativeTimeFormat behaviour on ICU error. · 765053dc
      David Manouchehri authored
      Bug: chromium:1062763
      Change-Id: I70d44f2db06b5ec1d84ab6678582dfc559d47e7e
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2108729
      Commit-Queue: Jakob Kummerow <jkummerow@chromium.org>
      Reviewed-by: 's avatarJakob Kummerow <jkummerow@chromium.org>
      Auto-Submit: David Manouchehri <david@davidmanouchehri.com>
      Cr-Commit-Position: refs/heads/master@{#66794}
      765053dc
    • Ng Zhi An's avatar
      [wasm-simd][arm64] Bitmask instructions · 3406cba8
      Ng Zhi An authored
      Implement i8x16.bitmask, i16x8.bitmask, i32x4.bitmask on interpreter and
      arm64.
      
      These operations are behind wasm_simd_post_mvp flag, as we are only
      prototyping to evaluate performance. The codegen is based on guidance at
      https://github.com/WebAssembly/simd/pull/201.
      
      Bug: v8:10308
      Change-Id: I835aa8a23e677a00ee7897c1c31a028850e238a9
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2099451Reviewed-by: 's avatarTobias Tebbi <tebbi@chromium.org>
      Reviewed-by: 's avatarDeepti Gandluri <gdeepti@chromium.org>
      Commit-Queue: Zhi An Ng <zhin@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66793}
      3406cba8
    • Andreas Haas's avatar
      [wasm] Introduce a WasmTableInit CSA builtin · ca5ee9d6
      Andreas Haas authored
      This CL introduces a CSA builtin for the TableInit instruction. This
      builtin allows to generate smaller code for both TurboFan and Liftoff,
      and easier code generation from Liftoff.
      
      The smaller code size comes from:
      * Parameters are passed through registers, not the stack.
      * Lower number of parameters: the call target, number of parameters, and
      context are not passed as parameters.
      * No int to smi conversion in generated code.
      
      The CL also introduces a small CSA function which takes an uint32 value
      and a max value as parameters and returns a Smi of the minimum of these
      two.
      
      R=clemensb@chromium.org, ishell@chromium.org
      
      Bug: v8:10281
      Change-Id: I40f248c20ec76e6ae9483a5e2907a68f42f2cb04
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2106201
      Commit-Queue: Andreas Haas <ahaas@chromium.org>
      Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
      Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66792}
      ca5ee9d6
    • Clemens Backes's avatar
      [liftoff] Add some more code comments · 599a6e0a
      Clemens Backes authored
      Add some more code comments for code snippets that are not obvious,
      especially if debug code is enabled.
      The comments help when looking at Liftoff code for debugging code
      generation issues.
      
      R=thibaudm@chromium.org
      
      Change-Id: I566bf2b05a454fb8addc030359969d36cb2cb707
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2108557Reviewed-by: 's avatarThibaud Michaud <thibaudm@chromium.org>
      Commit-Queue: Clemens Backes <clemensb@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66791}
      599a6e0a
    • Clemens Backes's avatar
      [liftoff][debug] Minor cleanup · a1439d41
      Clemens Backes authored
      1) Replace a condition by a DCHECK.
      2) Remove dead argument.
      
      R=thibaudm@chromium.org
      
      Bug: v8:10321
      Change-Id: I546d18e7e5520630ab32b4f73f9fe12b0441cb95
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2108556Reviewed-by: 's avatarThibaud Michaud <thibaudm@chromium.org>
      Commit-Queue: Clemens Backes <clemensb@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66790}
      a1439d41
    • Clemens Backes's avatar
      [liftoff][debug] Implement StepIn · da647667
      Clemens Backes authored
      Update the "hook on function call" flag also in the wasm case, and
      slightly change the {IsStepping} logic to stop in any frame if the last
      step action was anything other than StepNext.
      In future CLs, this has to be extended further for StepOut and for
      StepOver at a return location.
      When that is done, we can also reenable more stepping in the test.
      
      R=thibaudm@chromium.org
      
      Bug: v8:10321
      Change-Id: Ib3aa8c2c2e137690140e5879a33e2bcc340821e3
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2108035
      Commit-Queue: Clemens Backes <clemensb@chromium.org>
      Reviewed-by: 's avatarSimon Zünd <szuend@chromium.org>
      Reviewed-by: 's avatarThibaud Michaud <thibaudm@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66789}
      da647667
    • Daniel Bevenius's avatar
      [torque] Use char newline character instead of string · 32b22fe9
      Daniel Bevenius authored
      Currently, when GeneratePrintDefinitionsForClass generates its Print
      functions it uses a string literal as the newline character for all the
      last lines. For example:
      
      void TorqueGeneratedStruct<Struct, HeapObject>::StructPrint(
          std::ostream& os) {
        this->PrintHeader(os, "TorqueGeneratedStruct");
        os << "\n";
      }
      
      The last line could use a single character instead of a string,
      for example:
      
      void TorqueGeneratedStruct<Struct, HeapObject>::StructPrint(
          std::ostream& os) {
        this->PrintHeader(os, "TorqueGeneratedStruct");
        os << '\n';
      }
      
      The commit suggests changing this into a char.
      
      Change-Id: Id7a2f5fb17108fcbb543109d18b6b474ac1c5d2d
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2108546Reviewed-by: 's avatarTobias Tebbi <tebbi@chromium.org>
      Commit-Queue: Tobias Tebbi <tebbi@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66788}
      32b22fe9
    • Philip Pfaffe's avatar
      [wasm-debug-evaluate] Implement the foundation for wasm debug evaluate · 96966950
      Philip Pfaffe authored
      This implements the first part of WebAssembly debug evaluate. The patch
      includes the foundation required to execute evaluator modules. It only
      implements the first of the APIs of the evaluator module spec.
      
      Bug: chromium:1020120
      Change-Id: I06ec98a63d0a0ec8d81c2eac4319c4b85d3e16c1
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2089936
      Commit-Queue: Philip Pfaffe <pfaffe@chromium.org>
      Reviewed-by: 's avatarJakob Kummerow <jkummerow@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66787}
      96966950
    • Leszek Swirski's avatar
      Revert "[regexp] Rewrite error handling" · 2193f691
      Leszek Swirski authored
      This reverts commit e80ca24c.
      
      Reason for revert: Causes failures in the fast/regex/non-pattern-characters.html Blink web test (https://ci.chromium.org/p/v8/builders/ci/V8%20Blink%20Linux/3679)
      
      Original change's description:
      > [regexp] Rewrite error handling
      > 
      > This patch modifies irregexp's error handling. Instead of representing
      > errors as C strings, they are represented as an enumeration value
      > (RegExpError), and only converted to strings when throwing the error
      > object in regexp.cc. This makes it significantly easier to integrate
      > into SpiderMonkey. A few notes:
      > 
      > 1. Depending on whether the stack overflows during parsing or
      >    analysis, the stack overflow message can vary ("Stack overflow" or
      >    "Maximum call stack size exceeded"). I kept that behaviour in this
      >    patch, under the assumption that stack overflow messages are
      >    (sadly) the sorts of things that real world code ends up depending
      >    on.
      > 
      > 2. Depending on the point in code where the error was identified,
      >    invalid unicode escapes could be reported as "Invalid Unicode
      >    escape", "Invalid unicode escape", or "Invalid Unicode escape
      >    sequence". I fervently hope that nobody depends on the specific
      >    wording of a syntax error, so I standardized on the first one. (It
      >    was both the most common, and the most consistent with other
      >    "Invalid X escape" messages.)
      > 
      > 3. In addition to changing the representation, this patch also adds an
      >    error_pos field to RegExpParser and RegExpCompileData, which stores
      >    the position at which an error occurred. This is used by
      >    SpiderMonkey to provide more helpful messages about where a syntax
      >    error occurred in large regular expressions.
      > 
      > 4. This model is closer to V8's existing MessageTemplate
      >    infrastructure. I considered trying to integrate it more closely
      >    with MessageTemplate, but since one of our stated goals for this
      >    project was to make it easier to use irregexp outside of V8, I
      >    decided to hold off.
      > 
      > R=​jgruber@chromium.org
      > 
      > Bug: v8:10303
      > Change-Id: I62605fd2def2fc539f38a7e0eefa04d36e14bbde
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2091863
      > Commit-Queue: Jakob Gruber <jgruber@chromium.org>
      > Reviewed-by: Jakob Gruber <jgruber@chromium.org>
      > Cr-Commit-Position: refs/heads/master@{#66784}
      
      TBR=jgruber@chromium.org,iireland@mozilla.com
      
      Change-Id: I9247635f3c5b17c943b9c4abaf82ebe7b2de165e
      No-Presubmit: true
      No-Tree-Checks: true
      No-Try: true
      Bug: v8:10303
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2108550Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
      Commit-Queue: Leszek Swirski <leszeks@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#66786}
      2193f691