• Adam Klein's avatar
    Skip hole initialization of lexical variables when possible · ededfcd2
    Adam Klein authored
    This patch expands scope analysis to skip hole initialization
    when it can be determined statically that no hole checks will
    be generated at runtime.
    
    Two conditions must be met to safely eliminate hole initialization:
      - There must not exist a VariableProxy referencing this Variable
        whose HoleCheckMode is kRequired
      - The Variable must be stack allocated; any other allocation implies
        that it may be accessed from not-yet-analyzed scopes (other modules,
        inner functions, or eval code) and that code may require
        hole checks.
    
    The new logic required removing debug code in full-codegen which is
    now incorrect in some cases.
    
    Also fixed Variable's bitfield helpers to take no more space than needed.
    
    Bug: chromium:651637
    Change-Id: Ie5ac326af4e05b7a5c3c37cd4d0afba6a51a504d
    Reviewed-on: https://chromium-review.googlesource.com/494006
    Commit-Queue: Adam Klein <adamk@chromium.org>
    Reviewed-by: 's avatarGeorg Neis <neis@chromium.org>
    Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
    Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#45170}
    ededfcd2
Name
Last commit
Last update
benchmarks Loading commit data...
build_overrides Loading commit data...
docs Loading commit data...
gni Loading commit data...
gypfiles Loading commit data...
include Loading commit data...
infra Loading commit data...
samples Loading commit data...
src Loading commit data...
test Loading commit data...
testing Loading commit data...
third_party Loading commit data...
tools Loading commit data...
.clang-format Loading commit data...
.gitignore Loading commit data...
.gn Loading commit data...
.ycm_extra_conf.py Loading commit data...
AUTHORS Loading commit data...
BUILD.gn Loading commit data...
CODE_OF_CONDUCT.md Loading commit data...
ChangeLog Loading commit data...
DEPS Loading commit data...
LICENSE Loading commit data...
LICENSE.fdlibm Loading commit data...
LICENSE.strongtalk Loading commit data...
LICENSE.v8 Loading commit data...
LICENSE.valgrind Loading commit data...
Makefile Loading commit data...
Makefile.android Loading commit data...
OWNERS Loading commit data...
PRESUBMIT.py Loading commit data...
README.md Loading commit data...
WATCHLISTS Loading commit data...
codereview.settings Loading commit data...
snapshot_toolchain.gni Loading commit data...