Reland "Enable lazy source positions by default"

This is a reland of 69fafb5fe3
after fixing the in crash with
https://chromium-review.googlesource.com/c/v8/v8/+/1664334

Original change's description:
> Enable lazy source positions by default
>
> Also adds a compile time flag which allows the default to be configured
> so node can disable it since it hangs the node cpu profiler tests.
>
> Bug: v8:8510
> Change-Id: Idf4785036dc6242769410091518a67ac9179b718
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1491491
> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org>
> Commit-Queue: Dan Elphick <delphick@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#62089}

Bug: v8:8510
Change-Id: I81b36dbba3cc7b9a99dc5cc4ea72040fabfec97e
Cq-Include-Trybots: luci.v8.try:v8_linux_gc_stress_dbg,v8_linux64_gc_stress_custom_snapshot_dbg_ng
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1660484
Commit-Queue: Ross McIlroy <rmcilroy@chromium.org>
Auto-Submit: Dan Elphick <delphick@chromium.org>
Reviewed-by: Ross McIlroy <rmcilroy@chromium.org>
Cr-Commit-Position: refs/heads/master@{#62288}
This commit is contained in:
Dan Elphick 2019-06-19 14:17:10 +01:00 committed by Commit Bot
parent 668650574a
commit ccf0d80261
2 changed files with 13 additions and 2 deletions

View File

@ -187,6 +187,9 @@ declare_args() {
# Enable sharing read-only space across isolates. # Enable sharing read-only space across isolates.
# Sets -DV8_SHARED_RO_HEAP. # Sets -DV8_SHARED_RO_HEAP.
v8_enable_shared_ro_heap = "" v8_enable_shared_ro_heap = ""
# Enables lazy source positions by default.
v8_enable_lazy_source_positions = true
} }
# We reuse the snapshot toolchain for building torque and other generators to # We reuse the snapshot toolchain for building torque and other generators to
@ -430,6 +433,9 @@ config("features") {
if (v8_enable_concurrent_marking) { if (v8_enable_concurrent_marking) {
defines += [ "V8_CONCURRENT_MARKING" ] defines += [ "V8_CONCURRENT_MARKING" ]
} }
if (v8_enable_lazy_source_positions) {
defines += [ "V8_ENABLE_LAZY_SOURCE_POSITIONS" ]
}
if (v8_check_microtasks_scopes_consistency) { if (v8_check_microtasks_scopes_consistency) {
defines += [ "V8_CHECK_MICROTASKS_SCOPES_CONSISTENCY" ] defines += [ "V8_CHECK_MICROTASKS_SCOPES_CONSISTENCY" ]
} }

View File

@ -300,13 +300,18 @@ DEFINE_BOOL(icu_timezone_data, true, "get information about timezones from ICU")
#define V8_LITE_BOOL false #define V8_LITE_BOOL false
#endif #endif
#ifdef V8_ENABLE_LAZY_SOURCE_POSITIONS
#define V8_LAZY_SOURCE_POSITIONS_BOOL true
#else
#define V8_LAZY_SOURCE_POSITIONS_BOOL false
#endif
DEFINE_BOOL(lite_mode, V8_LITE_BOOL, DEFINE_BOOL(lite_mode, V8_LITE_BOOL,
"enables trade-off of performance for memory savings") "enables trade-off of performance for memory savings")
// Lite mode implies other flags to trade-off performance for memory. // Lite mode implies other flags to trade-off performance for memory.
DEFINE_IMPLICATION(lite_mode, jitless) DEFINE_IMPLICATION(lite_mode, jitless)
DEFINE_IMPLICATION(lite_mode, lazy_feedback_allocation) DEFINE_IMPLICATION(lite_mode, lazy_feedback_allocation)
DEFINE_IMPLICATION(lite_mode, enable_lazy_source_positions)
DEFINE_IMPLICATION(lite_mode, optimize_for_size) DEFINE_IMPLICATION(lite_mode, optimize_for_size)
#ifdef V8_ENABLE_FUTURE #ifdef V8_ENABLE_FUTURE
@ -406,7 +411,7 @@ DEFINE_BOOL(ignition_share_named_property_feedback, true,
"the same object") "the same object")
DEFINE_BOOL(print_bytecode, false, DEFINE_BOOL(print_bytecode, false,
"print bytecode generated by ignition interpreter") "print bytecode generated by ignition interpreter")
DEFINE_BOOL(enable_lazy_source_positions, false, DEFINE_BOOL(enable_lazy_source_positions, V8_LAZY_SOURCE_POSITIONS_BOOL,
"skip generating source positions during initial compile but " "skip generating source positions during initial compile but "
"regenerate when actually required") "regenerate when actually required")
DEFINE_STRING(print_bytecode_filter, "*", DEFINE_STRING(print_bytecode_filter, "*",