Commit ea5298f7 authored by Igor Sheludko's avatar Igor Sheludko Committed by V8 LUCI CQ

[ext-code-space] Fix improperly created CodeT handles in TurboFan

Bug: v8:11880
Change-Id: Ia86bab21851e8ff2f2317495a9f0e19140b0de2c
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2969827
Commit-Queue: Igor Sheludko <ishell@chromium.org>
Auto-Submit: Igor Sheludko <ishell@chromium.org>
Reviewed-by: 's avatarGeorg Neis <neis@chromium.org>
Cr-Commit-Position: refs/heads/master@{#75240}
parent e77d9d84
...@@ -2283,9 +2283,8 @@ void BytecodeGraphBuilder::VisitCreateClosure() { ...@@ -2283,9 +2283,8 @@ void BytecodeGraphBuilder::VisitCreateClosure() {
bytecode_iterator().GetFlagOperand(2)) bytecode_iterator().GetFlagOperand(2))
? AllocationType::kOld ? AllocationType::kOld
: AllocationType::kYoung; : AllocationType::kYoung;
Handle<CodeT> compile_lazy = Handle<CodeT> compile_lazy = broker()->CanonicalPersistentHandle(
ToCodeT(broker()->local_isolate_or_isolate(), ToCodeT(*BUILTIN_CODE(jsgraph()->isolate(), CompileLazy)));
BUILTIN_CODE(jsgraph()->isolate(), CompileLazy));
const Operator* op = javascript()->CreateClosure(shared_info.object(), const Operator* op = javascript()->CreateClosure(shared_info.object(),
compile_lazy, allocation); compile_lazy, allocation);
Node* closure = NewNode( Node* closure = NewNode(
......
...@@ -843,7 +843,7 @@ class PromiseBuiltinReducerAssembler : public JSCallReducerAssembler { ...@@ -843,7 +843,7 @@ class PromiseBuiltinReducerAssembler : public JSCallReducerAssembler {
Callable const callable = Callable const callable =
Builtins::CallableFor(isolate(), shared.builtin_id()); Builtins::CallableFor(isolate(), shared.builtin_id());
Handle<CodeT> code = Handle<CodeT> code =
ToCodeT(broker_->local_isolate_or_isolate(), callable.code()); broker_->CanonicalPersistentHandle(ToCodeT(*callable.code()));
return AddNode<JSFunction>(graph()->NewNode( return AddNode<JSFunction>(graph()->NewNode(
javascript()->CreateClosure(shared.object(), code), javascript()->CreateClosure(shared.object(), code),
HeapConstant(feedback_cell), context, effect(), control())); HeapConstant(feedback_cell), context, effect(), control()));
...@@ -6752,7 +6752,7 @@ Node* JSCallReducer::CreateClosureFromBuiltinSharedFunctionInfo( ...@@ -6752,7 +6752,7 @@ Node* JSCallReducer::CreateClosureFromBuiltinSharedFunctionInfo(
Callable const callable = Callable const callable =
Builtins::CallableFor(isolate(), shared.builtin_id()); Builtins::CallableFor(isolate(), shared.builtin_id());
Handle<CodeT> code = Handle<CodeT> code =
ToCodeT(broker()->local_isolate_or_isolate(), callable.code()); broker()->CanonicalPersistentHandle(ToCodeT(*callable.code()));
return graph()->NewNode(javascript()->CreateClosure(shared.object(), code), return graph()->NewNode(javascript()->CreateClosure(shared.object(), code),
jsgraph()->HeapConstant(feedback_cell), context, jsgraph()->HeapConstant(feedback_cell), context,
effect, control); effect, control);
......
...@@ -225,22 +225,6 @@ inline CodeT ToCodeT(Code code) { ...@@ -225,22 +225,6 @@ inline CodeT ToCodeT(Code code) {
#endif #endif
} }
inline Handle<CodeT> ToCodeT(Isolate* isolate, Handle<Code> code) {
#if V8_EXTERNAL_CODE_SPACE
return handle(ToCodeT(*code), isolate);
#else
return code;
#endif
}
inline Handle<CodeT> ToCodeT(LocalIsolate* isolate, Handle<Code> code) {
#if V8_EXTERNAL_CODE_SPACE
return handle(ToCodeT(*code), isolate);
#else
return code;
#endif
}
inline Code FromCodeT(CodeT code) { inline Code FromCodeT(CodeT code) {
#if V8_EXTERNAL_CODE_SPACE #if V8_EXTERNAL_CODE_SPACE
return code.code(); return code.code();
......
...@@ -628,8 +628,6 @@ class Code::OptimizedCodeIterator { ...@@ -628,8 +628,6 @@ class Code::OptimizedCodeIterator {
// Helper functions for converting Code objects to CodeDataContainer and back // Helper functions for converting Code objects to CodeDataContainer and back
// when V8_EXTERNAL_CODE_SPACE is enabled. // when V8_EXTERNAL_CODE_SPACE is enabled.
inline CodeT ToCodeT(Code code); inline CodeT ToCodeT(Code code);
inline Handle<CodeT> ToCodeT(Isolate* isolate, Handle<Code> code);
inline Handle<CodeT> ToCodeT(LocalIsolate* isolate, Handle<Code> code);
inline Code FromCodeT(CodeT code); inline Code FromCodeT(CodeT code);
inline CodeDataContainer CodeDataContainerFromCodeT(CodeT code); inline CodeDataContainer CodeDataContainerFromCodeT(CodeT code);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment