Commit 51554eb1 authored by jgruber's avatar jgruber Committed by Commit Bot

[builtins] Check we don't directly call lazy TFJ builtins

Lazy TFJ builtins rely on a mechanism that uses the SharedFunctionInfo
to determine the builtin to deserialize. That obviously doesn't work if
we call the lazy builtin directly, so make sure this does not happen (at
least not through (Tail)CallBuiltin).

Bug: v8:6624
Change-Id: Iea95d83379a5a0e47324e1fef83c005350f2f02a
Reviewed-on: https://chromium-review.googlesource.com/754684Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
Commit-Queue: Jakob Gruber <jgruber@chromium.org>
Cr-Commit-Position: refs/heads/master@{#49169}
parent 14ddbc18
...@@ -1517,11 +1517,15 @@ class V8_EXPORT_PRIVATE CodeStubAssembler : public compiler::CodeAssembler { ...@@ -1517,11 +1517,15 @@ class V8_EXPORT_PRIVATE CodeStubAssembler : public compiler::CodeAssembler {
template <class... TArgs> template <class... TArgs>
Node* CallBuiltin(Builtins::Name id, Node* context, TArgs... args) { Node* CallBuiltin(Builtins::Name id, Node* context, TArgs... args) {
DCHECK_IMPLIES(Builtins::KindOf(id) == Builtins::TFJ,
!Builtins::IsLazy(id));
return CallStub(Builtins::CallableFor(isolate(), id), context, args...); return CallStub(Builtins::CallableFor(isolate(), id), context, args...);
} }
template <class... TArgs> template <class... TArgs>
Node* TailCallBuiltin(Builtins::Name id, Node* context, TArgs... args) { Node* TailCallBuiltin(Builtins::Name id, Node* context, TArgs... args) {
DCHECK_IMPLIES(Builtins::KindOf(id) == Builtins::TFJ,
!Builtins::IsLazy(id));
return TailCallStub(Builtins::CallableFor(isolate(), id), context, args...); return TailCallStub(Builtins::CallableFor(isolate(), id), context, args...);
} }
......
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