• Benedikt Meurer's avatar
    [turbofan] Fix CanTreatHoleAsUndefined check. · e1e35df3
    Benedikt Meurer authored
    The test for CanTreatHoleAsUndefined on keyed element access was
    checking for stability of Object.prototype and Array.prototype and
    even adding stability dependencies on both, which is too restrictive
    and leads to unnecessary deoptimizations (and might disable further
    optimization of the keyed access depending on the state of the
    prototype objects during optimization). This was not intended and
    is considered a (performance) bug.
    
    Instead use the correct approach of checking whether the receiver's
    prototype is one of the current Object.prototype or Array.prototype
    objects (since the Array protector works isolate-wide), and then
    check the Array protector and install an appropriate code dependency
    on the protector only.
    
    Bug: v8:6607
    Change-Id: I0bcfe32813ca3693e7b22de31b03edb3509d0a27
    Reviewed-on: https://chromium-review.googlesource.com/574849Reviewed-by: 's avatarDaniel Clifford <danno@chromium.org>
    Commit-Queue: Benedikt Meurer <bmeurer@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#46743}
    e1e35df3
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...