• Benedikt Meurer's avatar
    [turbofan] Significantly improve ConsString creation performance. · d6a60a0e
    Benedikt Meurer authored
    This change significantly improves the performance of string
    concatenation in optimized code for the case where the resulting string
    is represented as a ConsString. On the relevant test cases we go from
    
      serializeNaive: 10762 ms.
      serializeClever: 7813 ms.
      serializeConcat: 10271 ms.
    
    to
    
      serializeNaive: 10278 ms.
      serializeClever: 5533 ms.
      serializeConcat: 10310 ms.
    
    which represents a 30% improvement on the "clever" benchmark, which
    tests specifically the ConsString creation performance.
    
    This was accomplished via a couple of different steps, which are briefly
    outlined here:
    
      1. The empty_string gets its own map, so that we can easily recognize
         and handle it appropriately in the TurboFan type system. This
         allows us to express (and assert) that the inputs to NewConsString
         are non-empty strings, making sure that TurboFan no longer creates
         "crippled ConsStrings" with empty left or right hand sides.
      2. Further split the existing String types in TurboFan to be able to
         distinguish between OneByte and TwoByte strings on the type system
         level. This allows us to avoid having to dynamically lookup the
         resulting ConsString map in case of ConsString creation (i.e. when
         we know that both input strings are OneByte strings or at least
         one of the input strings is TwoByte).
      3. We also introduced more finegrained feedback for the Add bytecode
         in the interpreter, having it collect feedback about ConsStrings,
         specifically ConsOneByteString and ConsTwoByteString. This feedback
         can be used by TurboFan to only inline the relevant code for what
         was seen so far. This allows us to remove the Octane/Splay specific
         magic in JSTypedLowering to detect ConsString creation, and instead
         purely rely on the feedback of what was seen so far (also making it
         possible to change the semantics of NewConsString to be a low-level
         operator, which is only introduced in SimplifiedLowering by looking
         at the input types of StringConcat).
      4. On top of the before mentioned type and interpreter changes we added
         new operators CheckNonEmptyString, CheckNonEmptyOneByteString, and
         CheckNonEmptyTwoByteString, which perform the appropriate (dynamic)
         checks.
    
    There are several more improvements that are possible based on this, but
    since the change was already quite big, we decided not to put everything
    into the first change, but do some follow up tweaks to the type system,
    and builtin optimizations later.
    
    Tbr: mstarzinger@chromium.org
    Bug: v8:8834, v8:8931, v8:8939, v8:8951
    Change-Id: Ia24e17c6048bf2b04df966d3cd441f0edda05c93
    Cq-Include-Trybots: luci.chromium.try:linux-blink-rel
    Doc: https://bit.ly/fast-string-concatenation-in-javascript
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1499497
    Commit-Queue: Michael Achenbach <machenbach@chromium.org>
    Reviewed-by: 's avatarYang Guo <yangguo@chromium.org>
    Reviewed-by: 's avatarJaroslav Sevcik <jarin@chromium.org>
    Reviewed-by: 's avatarMythri Alle <mythria@chromium.org>
    Reviewed-by: 's avatarBenedikt Meurer <bmeurer@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#60318}
    d6a60a0e
Name
Last commit
Last update
..
blink_tests Loading commit data...
cfi Loading commit data...
clusterfuzz Loading commit data...
dev Loading commit data...
gcmole Loading commit data...
generate_shim_headers Loading commit data...
heap-stats Loading commit data...
ignition Loading commit data...
jsfunfuzz Loading commit data...
link_clicker.extension Loading commit data...
mb Loading commit data...
memory Loading commit data...
msan Loading commit data...
ninja Loading commit data...
node Loading commit data...
perf Loading commit data...
profview Loading commit data...
profviz Loading commit data...
release Loading commit data...
sanitizers Loading commit data...
snapshot Loading commit data...
sodium Loading commit data...
testrunner Loading commit data...
toolchain Loading commit data...
torque Loading commit data...
turbolizer Loading commit data...
ubsan Loading commit data...
unittests Loading commit data...
v8.xcodeproj Loading commit data...
valgrind/asan Loading commit data...
vim Loading commit data...
visual_studio Loading commit data...
wasm Loading commit data...
BUILD.gn Loading commit data...
DEPS Loading commit data...
Makefile.tags Loading commit data...
OWNERS Loading commit data...
PRESUBMIT.py Loading commit data...
SourceMap.js Loading commit data...
__init__.py Loading commit data...
adb-d8.py Loading commit data...
android-build.sh Loading commit data...
android-ll-prof.sh Loading commit data...
android-run.py Loading commit data...
android-sync.sh Loading commit data...
arguments.js Loading commit data...
avg.py Loading commit data...
bash-completion.sh Loading commit data...
bigint-tester.py Loading commit data...
callstats.html Loading commit data...
callstats.py Loading commit data...
callstats.py.vpython Loading commit data...
check-inline-includes.sh Loading commit data...
check-static-initializers.sh Loading commit data...
check-unused-bailouts.sh Loading commit data...
check-unused-symbols.sh Loading commit data...
codemap.js Loading commit data...
collect_deprecation_stats.sh Loading commit data...
compare-table-gen.js Loading commit data...
concatenate-files.py Loading commit data...
consarray.js Loading commit data...
cpu.sh Loading commit data...
cross_build_gcc.sh Loading commit data...
csvparser.js Loading commit data...
deprecation_stats.py Loading commit data...
detect-builtins.js Loading commit data...
disasm.py Loading commit data...
draw_instruction_graph.sh Loading commit data...
dump-cpp.py Loading commit data...
dumpcpp-driver.js Loading commit data...
dumpcpp.js Loading commit data...
eval_gc_nvp.py Loading commit data...
eval_gc_time.sh Loading commit data...
find-commit-for-patch.py Loading commit data...
find_depot_tools.py Loading commit data...
freebsd-tick-processor Loading commit data...
fuzz-harness.sh Loading commit data...
gc-nvp-to-csv.py Loading commit data...
gc-nvp-trace-processor.py Loading commit data...
gc_nvp_common.py Loading commit data...
gdb-v8-support.py Loading commit data...
gdbinit Loading commit data...
gen-inlining-tests.py Loading commit data...
gen-keywords-gen-h.py Loading commit data...
gen-postmortem-metadata.py Loading commit data...
generate-builtins-tests.py Loading commit data...
generate-header-include-checks.py Loading commit data...
generate-ten-powers.scm Loading commit data...
get_landmines.py Loading commit data...
grokdump.py Loading commit data...
ic-explorer.html Loading commit data...
ic-processor Loading commit data...
ic-processor-driver.js Loading commit data...
ic-processor.js Loading commit data...
js2c.py Loading commit data...
linux-tick-processor Loading commit data...
ll_prof.py Loading commit data...
lldb_commands.py Loading commit data...
locs.py Loading commit data...
logreader.js Loading commit data...
mac-nm Loading commit data...
mac-tick-processor Loading commit data...
map-processor Loading commit data...
map-processor-driver.js Loading commit data...
map-processor.html Loading commit data...
map-processor.js Loading commit data...
mips_toolchain.tar.gz.sha1 Loading commit data...
objdump-v8 Loading commit data...
parse-processor Loading commit data...
parse-processor-driver.js Loading commit data...
parse-processor.html Loading commit data...
parse-processor.js Loading commit data...
perf-compare.py Loading commit data...
plot-timer-events Loading commit data...
predictable_wrapper.py Loading commit data...
profile.js Loading commit data...
profile_view.js Loading commit data...
run-clang-tidy.py Loading commit data...
run-llprof.sh Loading commit data...
run-num-fuzzer.py Loading commit data...
run-perf.sh Loading commit data...
run-tests.py Loading commit data...
run.py Loading commit data...
run_perf.py Loading commit data...
shell-utils.h Loading commit data...
splaytree.js Loading commit data...
stats-viewer.py Loading commit data...
test262-results-parser.js Loading commit data...
tick-processor.html Loading commit data...
tickprocessor-driver.js Loading commit data...
tickprocessor.js Loading commit data...
trace-maps-processor.py Loading commit data...
try_perf.py Loading commit data...
turbolizer-perf.py Loading commit data...
update-object-macros-undef.py Loading commit data...
v8_presubmit.py Loading commit data...
v8heapconst.py Loading commit data...
whitespace.txt Loading commit data...
windbg.js Loading commit data...
windows-tick-processor.bat Loading commit data...