• Andreas Haas's avatar
    [wasm] Improve stack check in the interpreter · 793c52ed
    Andreas Haas authored
    The existing stack check only checked the number of stack frames on the
    stack, not the actual size of the stack frames. In the test case, each
    stack frame is huge, and the interpreter runs out of memory before the
    stack check stops the execution. With this change we take the size of
    the value stack and the size of the control stack and compare their sum
    to the stack limit of V8. Note that this stack limit is kind of
    arbitrary, because the stack space of the interpreter is not on the
    actual runtime stack but allocated in zone memory, and the stack check
    exists to simulate stack overflows in compiled code, not to prevent
    actual stack overflows.
    
    R=clemensh@chromium.org
    TEST=mjsunit/regress/wasm/regress-778917
    
    Bug: chromium:778917
    Change-Id: Ife47631fcb1a178a68facab1e42c0069b12c0155
    Reviewed-on: https://chromium-review.googlesource.com/744003
    Commit-Queue: Andreas Haas <ahaas@chromium.org>
    Reviewed-by: 's avatarClemens Hammacher <clemensh@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#49071}
    793c52ed
Name
Last commit
Last update
..
benchmarks Loading commit data...
cctest Loading commit data...
common Loading commit data...
debugger Loading commit data...
fuzzer Loading commit data...
inspector Loading commit data...
intl Loading commit data...
js-perf-test Loading commit data...
memory Loading commit data...
message Loading commit data...
mjsunit Loading commit data...
mkgrokdump Loading commit data...
mozilla Loading commit data...
preparser Loading commit data...
promises-aplus Loading commit data...
test262 Loading commit data...
unittests Loading commit data...
wasm-spec-tests Loading commit data...
webkit Loading commit data...
BUILD.gn Loading commit data...
bot_default.gyp Loading commit data...
bot_default.isolate Loading commit data...
default.gyp Loading commit data...
default.isolate Loading commit data...
optimize_for_size.gyp Loading commit data...
optimize_for_size.isolate Loading commit data...
perf.gyp Loading commit data...
perf.isolate Loading commit data...