From 9843361c076a348c0fbc3e09b1ecec3cefc4fbea Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C3=ABl=20Zasso?= Date: Fri, 29 Jan 2021 08:00:35 +0100 Subject: [PATCH] tools: update V8 gypfiles for 9.0 PR-URL: https://github.com/nodejs/node/pull/37587 Reviewed-By: Jiawen Geng Reviewed-By: Colin Ihrig Reviewed-By: Myles Borins --- tools/v8_gypfiles/features.gypi | 27 +++++++++++++++---- tools/v8_gypfiles/v8.gyp | 48 ++++++++++++++++++++++++++------- 2 files changed, 60 insertions(+), 15 deletions(-) diff --git a/tools/v8_gypfiles/features.gypi b/tools/v8_gypfiles/features.gypi index b9b975ed3e7ec3..b21bf1d8ed7930 100644 --- a/tools/v8_gypfiles/features.gypi +++ b/tools/v8_gypfiles/features.gypi @@ -73,11 +73,6 @@ # Sets -DV8_ENABLE_FUTURE. 'v8_enable_future%': 0, - # Lite mode disables a number of performance optimizations to reduce memory - # at the cost of performance. - # Sets --DV8_LITE_MODE. - 'v8_enable_lite_mode%': 0, - # Sets -DVERIFY_HEAP. 'v8_enable_verify_heap%': 0, @@ -217,11 +212,27 @@ # Requires use_rtti = true 'v8_enable_precise_zone_stats%': 0, + # Experimental feature for tracking constness of properties in non-global + # dictionaries. Enabling this also always keeps prototypes in dict mode, + # meaning that they are not switched to fast mode. + # Sets -DV8_DICT_PROPERTY_CONST_TRACKING + 'v8_dict_property_const_tracking%': 0, + # Variables from v8.gni # Enable ECMAScript Internationalization API. Enabling this feature will # add a dependency on the ICU library. 'v8_enable_i18n_support%': 1, + + # Lite mode disables a number of performance optimizations to reduce memory + # at the cost of performance. + # Sets --DV8_LITE_MODE. + 'v8_enable_lite_mode%': 0, + + # Include support for WebAssembly. If disabled, the 'WebAssembly' global + # will not be available, and embedder APIs to generate WebAssembly modules + # will fail. + 'v8_enable_webassembly%': 1, }, 'target_defaults': { @@ -355,6 +366,12 @@ ['v8_enable_precise_zone_stats==1', { 'defines': ['V8_ENABLE_PRECISE_ZONE_STATS',], }], + ['v8_enable_webassembly==1', { + 'defines': ['V8_ENABLE_WEBASSEMBLY',], + }], + ['v8_dict_property_const_tracking==1', { + 'defines': ['V8_DICT_PROPERTY_CONST_TRACKING',], + }], ], # conditions 'defines': [ 'V8_GYP_BUILD', diff --git a/tools/v8_gypfiles/v8.gyp b/tools/v8_gypfiles/v8.gyp index 9abbcc0289d9af..2b2d4234a665ea 100644 --- a/tools/v8_gypfiles/v8.gyp +++ b/tools/v8_gypfiles/v8.gyp @@ -66,22 +66,24 @@ 'outputs': [ "<(SHARED_INTERMEDIATE_DIR)/torque-generated/bit-fields.h", "<(SHARED_INTERMEDIATE_DIR)/torque-generated/builtin-definitions.h", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/interface-descriptors.inc", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/factory.cc", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/factory.inc", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/field-offsets.h", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/class-debug-readers.cc", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/class-debug-readers.h", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/class-forward-declarations.h", "<(SHARED_INTERMEDIATE_DIR)/torque-generated/class-verifiers.cc", "<(SHARED_INTERMEDIATE_DIR)/torque-generated/class-verifiers.h", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/csa-types.h", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/debug-macros.cc", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/debug-macros.h", "<(SHARED_INTERMEDIATE_DIR)/torque-generated/enum-verifiers.cc", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/objects-printer.cc", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/objects-body-descriptors-inl.inc", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/class-debug-readers.cc", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/class-debug-readers.h", "<(SHARED_INTERMEDIATE_DIR)/torque-generated/exported-macros-assembler.cc", "<(SHARED_INTERMEDIATE_DIR)/torque-generated/exported-macros-assembler.h", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/csa-types.h", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/factory.cc", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/factory.inc", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/field-offsets.h", "<(SHARED_INTERMEDIATE_DIR)/torque-generated/instance-types.h", - "<(SHARED_INTERMEDIATE_DIR)/torque-generated/class-forward-declarations.h", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/interface-descriptors.inc", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/objects-body-descriptors-inl.inc", + "<(SHARED_INTERMEDIATE_DIR)/torque-generated/objects-printer.cc", '<@(torque_outputs_csa_cc)', '<@(torque_outputs_csa_h)', '<@(torque_outputs_inl_inc)', @@ -455,6 +457,8 @@ '<(V8_ROOT)/include/v8-cppgc.h', '<(V8_ROOT)/include/v8-fast-api-calls.h', '<(V8_ROOT)/include/v8-internal.h', + '<(V8_ROOT)/include/v8-profiler.h', + '<(V8_ROOT)/include/v8-util.h', '<(V8_ROOT)/include/v8.h', '<(V8_ROOT)/include/v8config.h', @@ -603,6 +607,19 @@ '<(V8_ROOT)/src/heap/third-party/heap-api-stub.cc', ], }], + ['v8_enable_webassembly==1', { + 'sources': [ + '<(V8_ROOT)/src/asmjs/asm-js.cc', + '<(V8_ROOT)/src/asmjs/asm-js.h', + '<(V8_ROOT)/src/asmjs/asm-names.h', + '<(V8_ROOT)/src/asmjs/asm-parser.cc', + '<(V8_ROOT)/src/asmjs/asm-parser.h', + '<(V8_ROOT)/src/asmjs/asm-scanner.cc', + '<(V8_ROOT)/src/asmjs/asm-scanner.h', + '<(V8_ROOT)/src/asmjs/asm-types.cc', + '<(V8_ROOT)/src/asmjs/asm-types.h', + ], + }], ['want_separate_host_toolset', { 'toolsets': ['host', 'target'], }], @@ -649,6 +666,13 @@ '