1 // Copyright 2011 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
11 // Specifies extra arguments required by a C++ builtin.
12 enum BuiltinExtraArguments {
13 NO_EXTRA_ARGUMENTS = 0,
14 NEEDS_CALLED_FUNCTION = 1
18 #define CODE_AGE_LIST_WITH_ARG(V, A) \
19 V(Quadragenarian, A) \
20 V(Quinquagenarian, A) \
22 V(Septuagenarian, A) \
25 #define CODE_AGE_LIST_IGNORE_ARG(X, V) V(X)
27 #define CODE_AGE_LIST(V) \
28 CODE_AGE_LIST_WITH_ARG(CODE_AGE_LIST_IGNORE_ARG, V)
30 #define CODE_AGE_LIST_COMPLETE(V) \
34 CODE_AGE_LIST_WITH_ARG(CODE_AGE_LIST_IGNORE_ARG, V)
36 #define DECLARE_CODE_AGE_BUILTIN(C, V) \
37 V(Make##C##CodeYoungAgainOddMarking, BUILTIN, \
38 UNINITIALIZED, kNoExtraICState) \
39 V(Make##C##CodeYoungAgainEvenMarking, BUILTIN, \
40 UNINITIALIZED, kNoExtraICState)
43 // Define list of builtins implemented in C++.
44 #define BUILTIN_LIST_C(V) \
45 V(Illegal, NO_EXTRA_ARGUMENTS) \
47 V(EmptyFunction, NO_EXTRA_ARGUMENTS) \
49 V(ArrayPush, NO_EXTRA_ARGUMENTS) \
50 V(ArrayPop, NO_EXTRA_ARGUMENTS) \
51 V(ArrayShift, NO_EXTRA_ARGUMENTS) \
52 V(ArrayUnshift, NO_EXTRA_ARGUMENTS) \
53 V(ArraySlice, NO_EXTRA_ARGUMENTS) \
54 V(ArraySplice, NO_EXTRA_ARGUMENTS) \
55 V(ArrayConcat, NO_EXTRA_ARGUMENTS) \
57 V(HandleApiCall, NEEDS_CALLED_FUNCTION) \
58 V(HandleApiCallConstruct, NEEDS_CALLED_FUNCTION) \
59 V(HandleApiCallAsFunction, NO_EXTRA_ARGUMENTS) \
60 V(HandleApiCallAsConstructor, NO_EXTRA_ARGUMENTS) \
62 V(StrictModePoisonPill, NO_EXTRA_ARGUMENTS) \
63 V(GeneratorPoisonPill, NO_EXTRA_ARGUMENTS)
65 // Define list of builtins implemented in assembly.
66 #define BUILTIN_LIST_A(V) \
67 V(ArgumentsAdaptorTrampoline, BUILTIN, UNINITIALIZED, \
69 V(InOptimizationQueue, BUILTIN, UNINITIALIZED, \
71 V(JSConstructStubGeneric, BUILTIN, UNINITIALIZED, \
73 V(JSConstructStubApi, BUILTIN, UNINITIALIZED, \
75 V(JSEntryTrampoline, BUILTIN, UNINITIALIZED, \
77 V(JSConstructEntryTrampoline, BUILTIN, UNINITIALIZED, \
79 V(CompileUnoptimized, BUILTIN, UNINITIALIZED, \
81 V(CompileOptimized, BUILTIN, UNINITIALIZED, \
83 V(CompileOptimizedConcurrent, BUILTIN, UNINITIALIZED, \
85 V(NotifyDeoptimized, BUILTIN, UNINITIALIZED, \
87 V(NotifySoftDeoptimized, BUILTIN, UNINITIALIZED, \
89 V(NotifyLazyDeoptimized, BUILTIN, UNINITIALIZED, \
91 V(NotifyStubFailure, BUILTIN, UNINITIALIZED, \
93 V(NotifyStubFailureSaveDoubles, BUILTIN, UNINITIALIZED, \
96 V(LoadIC_Miss, BUILTIN, UNINITIALIZED, \
98 V(KeyedLoadIC_Miss, BUILTIN, UNINITIALIZED, \
100 V(StoreIC_Miss, BUILTIN, UNINITIALIZED, \
102 V(KeyedStoreIC_Miss, BUILTIN, UNINITIALIZED, \
104 V(LoadIC_Getter_ForDeopt, LOAD_IC, MONOMORPHIC, \
106 V(KeyedLoadIC_Initialize, KEYED_LOAD_IC, UNINITIALIZED, \
108 V(KeyedLoadIC_PreMonomorphic, KEYED_LOAD_IC, PREMONOMORPHIC, \
110 V(KeyedLoadIC_Generic, KEYED_LOAD_IC, GENERIC, \
112 V(KeyedLoadIC_String, KEYED_LOAD_IC, MEGAMORPHIC, \
114 V(KeyedLoadIC_IndexedInterceptor, KEYED_LOAD_IC, MONOMORPHIC, \
116 V(KeyedLoadIC_SloppyArguments, KEYED_LOAD_IC, MONOMORPHIC, \
119 V(StoreIC_Setter_ForDeopt, STORE_IC, MONOMORPHIC, \
120 StoreIC::kStrictModeState) \
122 V(KeyedStoreIC_Initialize, KEYED_STORE_IC, UNINITIALIZED, \
124 V(KeyedStoreIC_PreMonomorphic, KEYED_STORE_IC, PREMONOMORPHIC, \
126 V(KeyedStoreIC_Generic, KEYED_STORE_IC, GENERIC, \
129 V(KeyedStoreIC_Initialize_Strict, KEYED_STORE_IC, UNINITIALIZED, \
130 StoreIC::kStrictModeState) \
131 V(KeyedStoreIC_PreMonomorphic_Strict, KEYED_STORE_IC, PREMONOMORPHIC, \
132 StoreIC::kStrictModeState) \
133 V(KeyedStoreIC_Generic_Strict, KEYED_STORE_IC, GENERIC, \
134 StoreIC::kStrictModeState) \
135 V(KeyedStoreIC_SloppyArguments, KEYED_STORE_IC, MONOMORPHIC, \
138 /* Uses KeyedLoadIC_Initialize; must be after in list. */ \
139 V(FunctionCall, BUILTIN, UNINITIALIZED, \
141 V(FunctionApply, BUILTIN, UNINITIALIZED, \
144 V(InternalArrayCode, BUILTIN, UNINITIALIZED, \
146 V(ArrayCode, BUILTIN, UNINITIALIZED, \
149 V(StringConstructCode, BUILTIN, UNINITIALIZED, \
152 V(OnStackReplacement, BUILTIN, UNINITIALIZED, \
154 V(InterruptCheck, BUILTIN, UNINITIALIZED, \
156 V(OsrAfterStackCheck, BUILTIN, UNINITIALIZED, \
158 V(StackCheck, BUILTIN, UNINITIALIZED, \
161 V(MarkCodeAsExecutedOnce, BUILTIN, UNINITIALIZED, \
163 V(MarkCodeAsExecutedTwice, BUILTIN, UNINITIALIZED, \
165 CODE_AGE_LIST_WITH_ARG(DECLARE_CODE_AGE_BUILTIN, V)
167 // Define list of builtin handlers implemented in assembly.
168 #define BUILTIN_LIST_H(V) \
169 V(LoadIC_Slow, LOAD_IC) \
170 V(KeyedLoadIC_Slow, KEYED_LOAD_IC) \
171 V(StoreIC_Slow, STORE_IC) \
172 V(KeyedStoreIC_Slow, KEYED_STORE_IC) \
173 V(LoadIC_Normal, LOAD_IC) \
174 V(StoreIC_Normal, STORE_IC)
176 // Define list of builtins used by the debugger implemented in assembly.
177 #define BUILTIN_LIST_DEBUG_A(V) \
178 V(Return_DebugBreak, BUILTIN, DEBUG_STUB, \
180 V(CallFunctionStub_DebugBreak, BUILTIN, DEBUG_STUB, \
182 V(CallConstructStub_DebugBreak, BUILTIN, DEBUG_STUB, \
184 V(CallConstructStub_Recording_DebugBreak, BUILTIN, DEBUG_STUB, \
186 V(CallICStub_DebugBreak, CALL_IC, DEBUG_STUB, \
188 V(LoadIC_DebugBreak, LOAD_IC, DEBUG_STUB, \
190 V(KeyedLoadIC_DebugBreak, KEYED_LOAD_IC, DEBUG_STUB, \
192 V(StoreIC_DebugBreak, STORE_IC, DEBUG_STUB, \
194 V(KeyedStoreIC_DebugBreak, KEYED_STORE_IC, DEBUG_STUB, \
196 V(CompareNilIC_DebugBreak, COMPARE_NIL_IC, DEBUG_STUB, \
198 V(Slot_DebugBreak, BUILTIN, DEBUG_STUB, \
200 V(PlainReturn_LiveEdit, BUILTIN, DEBUG_STUB, \
202 V(FrameDropper_LiveEdit, BUILTIN, DEBUG_STUB, \
205 // Define list of builtins implemented in JavaScript.
206 #define BUILTINS_LIST_JS(V) \
208 V(STRICT_EQUALS, 1) \
225 V(CALL_NON_FUNCTION, 0) \
226 V(CALL_NON_FUNCTION_AS_CONSTRUCTOR, 0) \
227 V(CALL_FUNCTION_PROXY, 1) \
228 V(CALL_FUNCTION_PROXY_AS_CONSTRUCTOR, 1) \
232 V(STRING_ADD_LEFT, 1) \
233 V(STRING_ADD_RIGHT, 1) \
234 V(APPLY_PREPARE, 1) \
237 class BuiltinFunctionTable;
245 // Generate all builtin code objects. Should be called once during
246 // isolate initialization.
247 void SetUp(Isolate* isolate, bool create_heap_objects);
250 // Garbage collection support.
251 void IterateBuiltins(ObjectVisitor* v);
253 // Disassembler support.
254 const char* Lookup(byte* pc);
257 #define DEF_ENUM_C(name, ignore) k##name,
258 #define DEF_ENUM_A(name, kind, state, extra) k##name,
259 #define DEF_ENUM_H(name, kind) k##name,
260 BUILTIN_LIST_C(DEF_ENUM_C)
261 BUILTIN_LIST_A(DEF_ENUM_A)
262 BUILTIN_LIST_H(DEF_ENUM_H)
263 BUILTIN_LIST_DEBUG_A(DEF_ENUM_A)
270 #define DEF_ENUM_C(name, ignore) c_##name,
271 BUILTIN_LIST_C(DEF_ENUM_C)
277 #define DEF_ENUM(name, ignore) name,
278 BUILTINS_LIST_JS(DEF_ENUM)
283 #define DECLARE_BUILTIN_ACCESSOR_C(name, ignore) Handle<Code> name();
284 #define DECLARE_BUILTIN_ACCESSOR_A(name, kind, state, extra) \
286 #define DECLARE_BUILTIN_ACCESSOR_H(name, kind) Handle<Code> name();
287 BUILTIN_LIST_C(DECLARE_BUILTIN_ACCESSOR_C)
288 BUILTIN_LIST_A(DECLARE_BUILTIN_ACCESSOR_A)
289 BUILTIN_LIST_H(DECLARE_BUILTIN_ACCESSOR_H)
290 BUILTIN_LIST_DEBUG_A(DECLARE_BUILTIN_ACCESSOR_A)
291 #undef DECLARE_BUILTIN_ACCESSOR_C
292 #undef DECLARE_BUILTIN_ACCESSOR_A
294 Code* builtin(Name name) {
295 // Code::cast cannot be used here since we access builtins
296 // during the marking phase of mark sweep. See IC::Clear.
297 return reinterpret_cast<Code*>(builtins_[name]);
300 Address builtin_address(Name name) {
301 return reinterpret_cast<Address>(&builtins_[name]);
304 static Address c_function_address(CFunctionId id) {
305 return c_functions_[id];
308 static const char* GetName(JavaScript id) { return javascript_names_[id]; }
309 const char* name(int index) {
311 DCHECK(index < builtin_count);
312 return names_[index];
314 static int GetArgumentsCount(JavaScript id) { return javascript_argc_[id]; }
315 Handle<Code> GetCode(JavaScript id, bool* resolved);
316 static int NumberOfJavaScriptBuiltins() { return id_count; }
318 bool is_initialized() const { return initialized_; }
323 // The external C++ functions called from the code.
324 static Address const c_functions_[cfunction_count];
326 // Note: These are always Code objects, but to conform with
327 // IterateBuiltins() above which assumes Object**'s for the callback
328 // function f, we use an Object* array here.
329 Object* builtins_[builtin_count];
330 const char* names_[builtin_count];
331 static const char* const javascript_names_[id_count];
332 static int const javascript_argc_[id_count];
334 static void Generate_Adaptor(MacroAssembler* masm,
336 BuiltinExtraArguments extra_args);
337 static void Generate_CompileUnoptimized(MacroAssembler* masm);
338 static void Generate_InOptimizationQueue(MacroAssembler* masm);
339 static void Generate_CompileOptimized(MacroAssembler* masm);
340 static void Generate_CompileOptimizedConcurrent(MacroAssembler* masm);
341 static void Generate_JSConstructStubGeneric(MacroAssembler* masm);
342 static void Generate_JSConstructStubApi(MacroAssembler* masm);
343 static void Generate_JSEntryTrampoline(MacroAssembler* masm);
344 static void Generate_JSConstructEntryTrampoline(MacroAssembler* masm);
345 static void Generate_NotifyDeoptimized(MacroAssembler* masm);
346 static void Generate_NotifySoftDeoptimized(MacroAssembler* masm);
347 static void Generate_NotifyLazyDeoptimized(MacroAssembler* masm);
348 static void Generate_NotifyStubFailure(MacroAssembler* masm);
349 static void Generate_NotifyStubFailureSaveDoubles(MacroAssembler* masm);
350 static void Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm);
352 static void Generate_FunctionCall(MacroAssembler* masm);
353 static void Generate_FunctionApply(MacroAssembler* masm);
355 static void Generate_InternalArrayCode(MacroAssembler* masm);
356 static void Generate_ArrayCode(MacroAssembler* masm);
358 static void Generate_StringConstructCode(MacroAssembler* masm);
359 static void Generate_OnStackReplacement(MacroAssembler* masm);
360 static void Generate_OsrAfterStackCheck(MacroAssembler* masm);
361 static void Generate_InterruptCheck(MacroAssembler* masm);
362 static void Generate_StackCheck(MacroAssembler* masm);
364 #define DECLARE_CODE_AGE_BUILTIN_GENERATOR(C) \
365 static void Generate_Make##C##CodeYoungAgainEvenMarking( \
366 MacroAssembler* masm); \
367 static void Generate_Make##C##CodeYoungAgainOddMarking( \
368 MacroAssembler* masm);
369 CODE_AGE_LIST(DECLARE_CODE_AGE_BUILTIN_GENERATOR)
370 #undef DECLARE_CODE_AGE_BUILTIN_GENERATOR
372 static void Generate_MarkCodeAsExecutedOnce(MacroAssembler* masm);
373 static void Generate_MarkCodeAsExecutedTwice(MacroAssembler* masm);
375 static void InitBuiltinFunctionTable();
379 friend class BuiltinFunctionTable;
380 friend class Isolate;
382 DISALLOW_COPY_AND_ASSIGN(Builtins);
385 } } // namespace v8::internal
387 #endif // V8_BUILTINS_H_