Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(46)

Unified Diff: src/code-factory.cc

Issue 2184063002: [stubs] Cleanup CodeFactory. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Fix Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | src/code-stubs.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/code-factory.cc
diff --git a/src/code-factory.cc b/src/code-factory.cc
index 0fb5c108dc18f0dc879c262a0deee61c1b3c6636..63cd5d0765e6d5c6a55bba10316806eb8cf9260e 100644
--- a/src/code-factory.cc
+++ b/src/code-factory.cc
@@ -10,58 +10,74 @@
namespace v8 {
namespace internal {
+namespace {
+
+// TODO(ishell): make it (const Stub& stub) once CodeStub::GetCode() is const.
+template <typename Stub>
+Callable make_callable(Stub& stub) {
+ typedef typename Stub::Descriptor Descriptor;
+ return Callable(stub.GetCode(), Descriptor(stub.isolate()));
+}
+
+} // namespace
// static
Callable CodeFactory::LoadIC(Isolate* isolate) {
if (FLAG_tf_load_ic_stub) {
LoadICTrampolineTFStub stub(isolate);
- return Callable(stub.GetCode(), LoadDescriptor(isolate));
+ return make_callable(stub);
}
LoadICTrampolineStub stub(isolate);
- return Callable(stub.GetCode(), LoadDescriptor(isolate));
+ return make_callable(stub);
}
// static
Callable CodeFactory::ApiGetter(Isolate* isolate) {
CallApiGetterStub stub(isolate);
- return Callable(stub.GetCode(), ApiGetterDescriptor(isolate));
+ return make_callable(stub);
}
// static
Callable CodeFactory::LoadICInOptimizedCode(Isolate* isolate) {
- auto code = LoadIC::initialize_stub_in_optimized_code(isolate);
- return Callable(code, LoadWithVectorDescriptor(isolate));
+ if (FLAG_tf_load_ic_stub) {
+ LoadICTFStub stub(isolate);
+ return make_callable(stub);
+ }
+ LoadICStub stub(isolate);
+ return make_callable(stub);
}
// static
Callable CodeFactory::LoadGlobalIC(Isolate* isolate, TypeofMode typeof_mode) {
LoadGlobalICTrampolineStub stub(isolate, LoadGlobalICState(typeof_mode));
- return Callable(stub.GetCode(), LoadGlobalDescriptor(isolate));
+ return make_callable(stub);
}
// static
Callable CodeFactory::LoadGlobalICInOptimizedCode(Isolate* isolate,
TypeofMode typeof_mode) {
- auto code = LoadGlobalIC::initialize_stub_in_optimized_code(
- isolate, LoadGlobalICState(typeof_mode).GetExtraICState());
- return Callable(code, LoadGlobalWithVectorDescriptor(isolate));
+ LoadGlobalICStub stub(isolate, LoadGlobalICState(typeof_mode));
+ return make_callable(stub);
}
// static
Callable CodeFactory::KeyedLoadIC(Isolate* isolate) {
if (FLAG_tf_load_ic_stub) {
KeyedLoadICTrampolineTFStub stub(isolate);
- return Callable(stub.GetCode(), LoadDescriptor(isolate));
+ return make_callable(stub);
}
KeyedLoadICTrampolineStub stub(isolate);
- return Callable(stub.GetCode(), LoadDescriptor(isolate));
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::KeyedLoadICInOptimizedCode(Isolate* isolate) {
- auto code = KeyedLoadIC::initialize_stub_in_optimized_code(isolate);
- return Callable(code, LoadWithVectorDescriptor(isolate));
+ if (FLAG_tf_load_ic_stub) {
+ KeyedLoadICTFStub stub(isolate);
+ return make_callable(stub);
+ }
+ KeyedLoadICStub stub(isolate);
+ return make_callable(stub);
}
// static
@@ -75,80 +91,66 @@ Callable CodeFactory::CallIC(Isolate* isolate, int argc,
ConvertReceiverMode mode,
TailCallMode tail_call_mode) {
CallICTrampolineStub stub(isolate, CallICState(argc, mode, tail_call_mode));
- return Callable(stub.GetCode(), CallFunctionWithFeedbackDescriptor(isolate));
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::CallICInOptimizedCode(Isolate* isolate, int argc,
ConvertReceiverMode mode,
TailCallMode tail_call_mode) {
- return Callable(CallIC::initialize_stub_in_optimized_code(isolate, argc, mode,
- tail_call_mode),
- CallFunctionWithFeedbackAndVectorDescriptor(isolate));
+ CallICStub stub(isolate, CallICState(argc, mode, tail_call_mode));
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::StoreIC(Isolate* isolate, LanguageMode language_mode) {
StoreICTrampolineStub stub(isolate, StoreICState(language_mode));
- return Callable(stub.GetCode(), StoreDescriptor(isolate));
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::StoreICInOptimizedCode(Isolate* isolate,
LanguageMode language_mode) {
- CallInterfaceDescriptor descriptor = StoreWithVectorDescriptor(isolate);
- return Callable(
- StoreIC::initialize_stub_in_optimized_code(isolate, language_mode),
- descriptor);
+ StoreICStub stub(isolate, StoreICState(language_mode));
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::KeyedStoreIC(Isolate* isolate,
LanguageMode language_mode) {
KeyedStoreICTrampolineStub stub(isolate, StoreICState(language_mode));
- return Callable(stub.GetCode(), StoreDescriptor(isolate));
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::KeyedStoreICInOptimizedCode(Isolate* isolate,
LanguageMode language_mode) {
- CallInterfaceDescriptor descriptor = StoreWithVectorDescriptor(isolate);
- return Callable(
- KeyedStoreIC::initialize_stub_in_optimized_code(isolate, language_mode),
- descriptor);
+ KeyedStoreICStub stub(isolate, StoreICState(language_mode));
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::CompareIC(Isolate* isolate, Token::Value op) {
- Handle<Code> code = CompareIC::GetUninitialized(isolate, op);
- return Callable(code, CompareDescriptor(isolate));
+ CompareICStub stub(isolate, op);
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::BinaryOpIC(Isolate* isolate, Token::Value op) {
BinaryOpICStub stub(isolate, op);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::InstanceOf(Isolate* isolate) {
InstanceOfStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::GetProperty(Isolate* isolate) {
GetPropertyStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
@@ -157,14 +159,12 @@ Callable CodeFactory::ToBoolean(Isolate* isolate) {
TypeConversionDescriptor(isolate));
}
-
// static
Callable CodeFactory::ToNumber(Isolate* isolate) {
return Callable(isolate->builtins()->ToNumber(),
TypeConversionDescriptor(isolate));
}
-
// static
Callable CodeFactory::NonNumberToNumber(Isolate* isolate) {
return Callable(isolate->builtins()->NonNumberToNumber(),
@@ -180,34 +180,31 @@ Callable CodeFactory::StringToNumber(Isolate* isolate) {
// static
Callable CodeFactory::ToString(Isolate* isolate) {
ToStringStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::ToName(Isolate* isolate) {
ToNameStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::ToInteger(Isolate* isolate) {
ToIntegerStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::ToLength(Isolate* isolate) {
ToLengthStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::ToObject(Isolate* isolate) {
ToObjectStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
@@ -227,16 +224,15 @@ Callable CodeFactory::OrdinaryToPrimitive(Isolate* isolate,
// static
Callable CodeFactory::NumberToString(Isolate* isolate) {
NumberToStringStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::RegExpConstructResult(Isolate* isolate) {
RegExpConstructResultStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::RegExpExec(Isolate* isolate) {
RegExpExecStub stub(isolate);
@@ -246,134 +242,134 @@ Callable CodeFactory::RegExpExec(Isolate* isolate) {
// static
Callable CodeFactory::Add(Isolate* isolate) {
AddStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::Subtract(Isolate* isolate) {
SubtractStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::Multiply(Isolate* isolate) {
MultiplyStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::Divide(Isolate* isolate) {
DivideStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::Modulus(Isolate* isolate) {
ModulusStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::ShiftRight(Isolate* isolate) {
ShiftRightStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::ShiftRightLogical(Isolate* isolate) {
ShiftRightLogicalStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::ShiftLeft(Isolate* isolate) {
ShiftLeftStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::BitwiseAnd(Isolate* isolate) {
BitwiseAndStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::BitwiseOr(Isolate* isolate) {
BitwiseOrStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::BitwiseXor(Isolate* isolate) {
BitwiseXorStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::Inc(Isolate* isolate) {
IncStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::Dec(Isolate* isolate) {
DecStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::LessThan(Isolate* isolate) {
LessThanStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::LessThanOrEqual(Isolate* isolate) {
LessThanOrEqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::GreaterThan(Isolate* isolate) {
GreaterThanStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::GreaterThanOrEqual(Isolate* isolate) {
GreaterThanOrEqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::Equal(Isolate* isolate) {
EqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::NotEqual(Isolate* isolate) {
NotEqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::StrictEqual(Isolate* isolate) {
StrictEqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::StrictNotEqual(Isolate* isolate) {
StrictNotEqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::StringAdd(Isolate* isolate, StringAddFlags flags,
PretenureFlag pretenure_flag) {
StringAddStub stub(isolate, flags, pretenure_flag);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
@@ -403,37 +399,37 @@ Callable CodeFactory::StringCompare(Isolate* isolate, Token::Value token) {
// static
Callable CodeFactory::StringEqual(Isolate* isolate) {
StringEqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::StringNotEqual(Isolate* isolate) {
StringNotEqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::StringLessThan(Isolate* isolate) {
StringLessThanStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::StringLessThanOrEqual(Isolate* isolate) {
StringLessThanOrEqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::StringGreaterThan(Isolate* isolate) {
StringGreaterThanStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::StringGreaterThanOrEqual(Isolate* isolate) {
StringGreaterThanOrEqualStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
@@ -442,7 +438,6 @@ Callable CodeFactory::SubString(Isolate* isolate) {
return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
}
-
// static
Callable CodeFactory::ResumeGenerator(Isolate* isolate) {
return Callable(isolate->builtins()->ResumeGeneratorTrampoline(),
@@ -452,87 +447,78 @@ Callable CodeFactory::ResumeGenerator(Isolate* isolate) {
// static
Callable CodeFactory::Typeof(Isolate* isolate) {
TypeofStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::FastCloneRegExp(Isolate* isolate) {
FastCloneRegExpStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::FastCloneShallowArray(Isolate* isolate) {
// TODO(mstarzinger): Thread through AllocationSiteMode at some point.
FastCloneShallowArrayStub stub(isolate, DONT_TRACK_ALLOCATION_SITE);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::FastCloneShallowObject(Isolate* isolate, int length) {
FastCloneShallowObjectStub stub(isolate, length);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::FastNewContext(Isolate* isolate, int slot_count) {
FastNewFunctionContextStub stub(isolate, slot_count);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::FastNewClosure(Isolate* isolate) {
FastNewClosureStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::FastNewObject(Isolate* isolate) {
FastNewObjectStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::FastNewRestParameter(Isolate* isolate,
bool skip_stub_frame) {
FastNewRestParameterStub stub(isolate, skip_stub_frame);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::FastNewSloppyArguments(Isolate* isolate,
bool skip_stub_frame) {
FastNewSloppyArgumentsStub stub(isolate, skip_stub_frame);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::FastNewStrictArguments(Isolate* isolate,
bool skip_stub_frame) {
FastNewStrictArgumentsStub stub(isolate, skip_stub_frame);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-
// static
Callable CodeFactory::AllocateHeapNumber(Isolate* isolate) {
AllocateHeapNumberStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
-#define SIMD128_ALLOC(TYPE, Type, type, lane_count, lane_type) \
- Callable CodeFactory::Allocate##Type(Isolate* isolate) { \
- Allocate##Type##Stub stub(isolate); \
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor()); \
+#define SIMD128_ALLOC(TYPE, Type, type, lane_count, lane_type) \
+ Callable CodeFactory::Allocate##Type(Isolate* isolate) { \
+ Allocate##Type##Stub stub(isolate); \
+ return make_callable(stub); \
}
SIMD128_TYPES(SIMD128_ALLOC)
#undef SIMD128_ALLOC
@@ -543,7 +529,6 @@ Callable CodeFactory::ArgumentAdaptor(Isolate* isolate) {
ArgumentAdaptorDescriptor(isolate));
}
-
// static
Callable CodeFactory::Call(Isolate* isolate, ConvertReceiverMode mode,
TailCallMode tail_call_mode) {
@@ -551,21 +536,18 @@ Callable CodeFactory::Call(Isolate* isolate, ConvertReceiverMode mode,
CallTrampolineDescriptor(isolate));
}
-
// static
Callable CodeFactory::CallFunction(Isolate* isolate, ConvertReceiverMode mode) {
return Callable(isolate->builtins()->CallFunction(mode),
CallTrampolineDescriptor(isolate));
}
-
// static
Callable CodeFactory::Construct(Isolate* isolate) {
return Callable(isolate->builtins()->Construct(),
ConstructTrampolineDescriptor(isolate));
}
-
// static
Callable CodeFactory::ConstructFunction(Isolate* isolate) {
return Callable(isolate->builtins()->ConstructFunction(),
@@ -575,13 +557,13 @@ Callable CodeFactory::ConstructFunction(Isolate* isolate) {
// static
Callable CodeFactory::HasProperty(Isolate* isolate) {
HasPropertyStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
Callable CodeFactory::ForInFilter(Isolate* isolate) {
ForInFilterStub stub(isolate);
- return Callable(stub.GetCode(), stub.GetCallInterfaceDescriptor());
+ return make_callable(stub);
}
// static
@@ -593,14 +575,12 @@ Callable CodeFactory::InterpreterPushArgsAndCall(Isolate* isolate,
InterpreterPushArgsAndCallDescriptor(isolate));
}
-
// static
Callable CodeFactory::InterpreterPushArgsAndConstruct(Isolate* isolate) {
return Callable(isolate->builtins()->InterpreterPushArgsAndConstruct(),
InterpreterPushArgsAndConstructDescriptor(isolate));
}
-
// static
Callable CodeFactory::InterpreterCEntry(Isolate* isolate, int result_size) {
// Note: If we ever use fpregs in the interpreter then we will need to
« no previous file with comments | « no previous file | src/code-stubs.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698