diff --git a/common.gypi b/common.gypi index 8b92e0a316c3c7..dce4d664a8d3eb 100644 --- a/common.gypi +++ b/common.gypi @@ -28,7 +28,7 @@ # Reset this number to 0 on major V8 upgrades. # Increment by one for each non-official patch applied to deps/v8. - 'v8_embedder_string': '-node.3', + 'v8_embedder_string': '-node.4', # Enable disassembler for `--print-code` v8 options 'v8_enable_disassembler': 1, diff --git a/deps/v8/src/log.cc b/deps/v8/src/log.cc index 20e5f2c9643cf4..8ed6f43ba6b34f 100644 --- a/deps/v8/src/log.cc +++ b/deps/v8/src/log.cc @@ -2012,10 +2012,10 @@ FILE* Logger::TearDown() { } void ExistingCodeLogger::LogCodeObject(Object* object) { - AbstractCode* code_object = AbstractCode::cast(object); + AbstractCode* abstract_code = AbstractCode::cast(object); CodeEventListener::LogEventsAndTags tag = CodeEventListener::STUB_TAG; const char* description = "Unknown code from before profiling"; - switch (code_object->kind()) { + switch (abstract_code->kind()) { case AbstractCode::INTERPRETED_FUNCTION: case AbstractCode::OPTIMIZED_FUNCTION: return; // We log this later using LogCompiledFunctions. @@ -2023,7 +2023,7 @@ void ExistingCodeLogger::LogCodeObject(Object* object) { return; // We log it later by walking the dispatch table. case AbstractCode::STUB: description = - CodeStub::MajorName(CodeStub::GetMajorKey(code_object->GetCode())); + CodeStub::MajorName(CodeStub::GetMajorKey(abstract_code->GetCode())); if (description == nullptr) description = "A stub from before profiling"; tag = CodeEventListener::STUB_TAG; break; @@ -2032,8 +2032,13 @@ void ExistingCodeLogger::LogCodeObject(Object* object) { tag = CodeEventListener::REG_EXP_TAG; break; case AbstractCode::BUILTIN: + if (Code::cast(object)->is_interpreter_trampoline_builtin() && + Code::cast(object) == + *BUILTIN_CODE(isolate_, InterpreterEntryTrampoline)) { + return; + } description = - isolate_->builtins()->name(code_object->GetCode()->builtin_index()); + isolate_->builtins()->name(abstract_code->GetCode()->builtin_index()); tag = CodeEventListener::BUILTIN_TAG; break; case AbstractCode::WASM_FUNCTION: @@ -2059,7 +2064,7 @@ void ExistingCodeLogger::LogCodeObject(Object* object) { case AbstractCode::NUMBER_OF_KINDS: UNIMPLEMENTED(); } - CALL_CODE_EVENT_HANDLER(CodeCreateEvent(tag, code_object, description)) + CALL_CODE_EVENT_HANDLER(CodeCreateEvent(tag, abstract_code, description)) } void ExistingCodeLogger::LogCodeObjects() { @@ -2085,6 +2090,12 @@ void ExistingCodeLogger::LogCompiledFunctions() { // During iteration, there can be heap allocation due to // GetScriptLineNumber call. for (int i = 0; i < compiled_funcs_count; ++i) { + if (sfis[i]->function_data()->IsInterpreterData()) { + LogExistingFunction(sfis[i], + Handle(AbstractCode::cast( + sfis[i]->InterpreterTrampoline())), + CodeEventListener::INTERPRETED_FUNCTION_TAG); + } if (code_objects[i].is_identical_to(BUILTIN_CODE(isolate_, CompileLazy))) continue; LogExistingFunction(sfis[i], code_objects[i]); @@ -2129,8 +2140,9 @@ void ExistingCodeLogger::LogBytecodeHandlers() { } } -void ExistingCodeLogger::LogExistingFunction(Handle shared, - Handle code) { +void ExistingCodeLogger::LogExistingFunction( + Handle shared, Handle code, + CodeEventListener::LogEventsAndTags tag) { if (shared->script()->IsScript()) { Handle