Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1088)

Issue 2666433002: PPC/s390: [wasm] TrapIf and TrapUnless TurboFan operators implemented on arm. (Closed)

Created:
3 years, 10 months ago by JaideepBajwa
Modified:
3 years, 10 months ago
CC:
v8-reviews_googlegroups.com
Target Ref:
refs/pending/heads/master
Project:
v8
Visibility:
Public.

Description

PPC/s390: [wasm] TrapIf and TrapUnless TurboFan operators implemented on arm. Port ca8d3ba7183d2b7a9691b2e732f7dbe8dc719a3e Original Commit Message: Original commit message: [wasm] Introduce the TrapIf and TrapUnless operators to generate trap code. Some instructions in WebAssembly trap for some inputs, which means that the execution is terminated and (at least at the moment) a JavaScript exception is thrown. Examples for traps are out-of-bounds memory accesses, or integer divisions by zero. Without the TrapIf and TrapUnless operators trap check in WebAssembly introduces 5 TurboFan nodes (branch, if_true, if_false, trap-reason constant, trap-position constant), in addition to the trap condition itself. Additionally, each WebAssembly function has four TurboFan nodes (merge, effect_phi, 2 phis) whose number of inputs is linear to the number of trap checks in the function. Especially for functions with high numbers of trap checks we observe a significant slowdown in compilation time, down to 0.22 MiB/s in the sqlite benchmark instead of the average of 3 MiB/s in other benchmarks. By introducing a TrapIf common operator only a single node is necessary per trap check, in addition to the trap condition. Also the nodes which are shared between trap checks (merge, effect_phi, 2 phis) would disappear. First measurements suggest a speedup of 30-50% on average. This CL only implements TrapIf and TrapUnless on x64. The implementation is also hidden behind the --wasm-trap-if flag. Please take a special look at how the source position is transfered from the instruction selector to the code generator, and at the context that is used for the runtime call. R=ahaas@chromium.org, titzer@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com BUG= LOG=N Review-Url: https://codereview.chromium.org/2666433002 Cr-Commit-Position: refs/heads/master@{#42793} Committed: https://chromium.googlesource.com/v8/v8/+/544308b8f7351b55862d26ccc840fb210927f96a

Patch Set 1 #

Patch Set 2 : fix for ppc constantpool #

Unified diffs Side-by-side diffs Delta from patch set Stats (+177 lines, -12 lines) Patch
M src/compiler/ppc/code-generator-ppc.cc View 1 1 chunk +73 lines, -1 line 0 comments Download
M src/compiler/ppc/instruction-selector-ppc.cc View 3 chunks +14 lines, -4 lines 0 comments Download
M src/compiler/s390/code-generator-s390.cc View 1 chunk +72 lines, -1 line 0 comments Download
M src/compiler/s390/instruction-selector-s390.cc View 3 chunks +14 lines, -4 lines 0 comments Download
M src/compiler/wasm-compiler.cc View 1 chunk +4 lines, -2 lines 0 comments Download

Messages

Total messages: 17 (10 generated)
JaideepBajwa
ptal
3 years, 10 months ago (2017-01-29 16:37:32 UTC) #4
john.yan
lgtm
3 years, 10 months ago (2017-01-29 17:04:44 UTC) #5
JaideepBajwa
@titzer@chromium.org @ahaas@chromium.org ptal, need lgtm for wasm-compiler.cc. Thank you.
3 years, 10 months ago (2017-01-30 19:45:19 UTC) #10
titzer
On 2017/01/30 19:45:19, JaideepBajwa wrote: > mailto:@titzer@chromium.org > mailto:@ahaas@chromium.org > ptal, need lgtm for wasm-compiler.cc. ...
3 years, 10 months ago (2017-01-30 21:13:35 UTC) #11
JaideepBajwa
On 2017/01/30 21:13:35, titzer wrote: > On 2017/01/30 19:45:19, JaideepBajwa wrote: > > mailto:@titzer@chromium.org > ...
3 years, 10 months ago (2017-01-30 21:15:49 UTC) #12
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/v2/patch-status/codereview.chromium.org/2666433002/20001
3 years, 10 months ago (2017-01-30 21:16:00 UTC) #14
commit-bot: I haz the power
3 years, 10 months ago (2017-01-30 21:41:57 UTC) #17
Message was sent while issue was closed.
Committed patchset #2 (id:20001) as
https://chromium.googlesource.com/v8/v8/+/544308b8f7351b55862d26ccc840fb21092...

Powered by Google App Engine
This is Rietveld 408576698