blob: 1b7e32e7a1860c631d75f8b958ccc347ea115b89 [file] [log] [blame]
yangguo@chromium.org56454712012-02-16 15:33:53 +00001// Copyright 2012 the V8 project authors. All rights reserved.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +00002// Redistribution and use in source and binary forms, with or without
3// modification, are permitted provided that the following conditions are
4// met:
5//
6// * Redistributions of source code must retain the above copyright
7// notice, this list of conditions and the following disclaimer.
8// * Redistributions in binary form must reproduce the above
9// copyright notice, this list of conditions and the following
10// disclaimer in the documentation and/or other materials provided
11// with the distribution.
12// * Neither the name of Google Inc. nor the names of its
13// contributors may be used to endorse or promote products derived
14// from this software without specific prior written permission.
15//
16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28#ifndef V8_RUNTIME_H_
29#define V8_RUNTIME_H_
30
lrn@chromium.org1c092762011-05-09 09:42:16 +000031#include "allocation.h"
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +000032#include "zone.h"
33
kasperl@chromium.org71affb52009-05-26 05:44:31 +000034namespace v8 {
35namespace internal {
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000036
37// The interface to C++ runtime functions.
38
39// ----------------------------------------------------------------------------
kasper.lund44510672008-07-25 07:37:58 +000040// RUNTIME_FUNCTION_LIST_ALWAYS defines runtime calls available in both
41// release and debug mode.
42// This macro should only be used by the macro RUNTIME_FUNCTION_LIST.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000043
ager@chromium.orgce58e172009-05-13 07:11:48 +000044// WARNING: RUNTIME_FUNCTION_LIST_ALWAYS_* is a very large macro that caused
45// MSVC Intellisense to crash. It was broken into two macros to work around
46// this problem. Please avoid large recursive macros whenever possible.
47#define RUNTIME_FUNCTION_LIST_ALWAYS_1(F) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000048 /* Property access */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +000049 F(GetProperty, 2, 1) \
50 F(KeyedGetProperty, 2, 1) \
kmillikin@chromium.org49edbdf2011-02-16 12:32:18 +000051 F(DeleteProperty, 3, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +000052 F(HasLocalProperty, 2, 1) \
53 F(HasProperty, 2, 1) \
54 F(HasElement, 2, 1) \
55 F(IsPropertyEnumerable, 2, 1) \
56 F(GetPropertyNames, 1, 1) \
57 F(GetPropertyNamesFast, 1, 1) \
mstarzinger@chromium.orgf705b502013-04-04 11:38:09 +000058 F(GetLocalPropertyNames, 2, 1) \
sgjesse@chromium.orgb302e562010-02-03 11:26:59 +000059 F(GetLocalElementNames, 1, 1) \
60 F(GetInterceptorInfo, 1, 1) \
61 F(GetNamedInterceptorPropertyNames, 1, 1) \
62 F(GetIndexedInterceptorElementNames, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +000063 F(GetArgumentsProperty, 1, 1) \
64 F(ToFastProperties, 1, 1) \
ager@chromium.orgce5e87b2010-03-10 10:24:18 +000065 F(FinishArrayPrototypeSetup, 1, 1) \
vegorov@chromium.orgf8372902010-03-15 10:26:20 +000066 F(SpecialArrayFunctions, 1, 1) \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +000067 F(IsClassicModeFunction, 1, 1) \
ricow@chromium.org4668a2c2011-08-29 10:41:00 +000068 F(GetDefaultReceiver, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000069 \
erik.corry@gmail.comd6076d92011-06-06 09:39:18 +000070 F(GetPrototype, 1, 1) \
ulan@chromium.org750145a2013-03-07 15:14:13 +000071 F(SetPrototype, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +000072 F(IsInPrototypeChain, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000073 \
fschneider@chromium.org0c20e672010-01-14 15:28:53 +000074 F(GetOwnProperty, 2, 1) \
75 \
sgjesse@chromium.orgb302e562010-02-03 11:26:59 +000076 F(IsExtensible, 1, 1) \
kmillikin@chromium.org69ea3962010-07-05 11:01:40 +000077 F(PreventExtensions, 1, 1)\
sgjesse@chromium.orgb302e562010-02-03 11:26:59 +000078 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000079 /* Utilities */ \
fschneider@chromium.org1805e212011-09-05 10:49:12 +000080 F(CheckIsBootstrapping, 0, 1) \
mstarzinger@chromium.org88d326b2012-04-23 12:57:22 +000081 F(GetRootNaN, 0, 1) \
danno@chromium.orgc612e022011-11-10 11:38:15 +000082 F(Call, -1 /* >= 2 */, 1) \
lrn@chromium.org34e60782011-09-15 07:25:40 +000083 F(Apply, 5, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +000084 F(GetFunctionDelegate, 1, 1) \
85 F(GetConstructorDelegate, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +000086 F(NewArgumentsFast, 3, 1) \
whesse@chromium.org7b260152011-06-20 15:33:18 +000087 F(NewStrictArgumentsFast, 3, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +000088 F(LazyCompile, 1, 1) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +000089 F(LazyRecompile, 1, 1) \
rossberg@chromium.org92597162013-08-23 13:28:00 +000090 F(ConcurrentRecompile, 1, 1) \
dslomov@chromium.org4a35c5a2013-09-13 07:28:52 +000091 F(TryInstallRecompiledCode, 1, 1) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +000092 F(NotifyDeoptimized, 1, 1) \
jkummerow@chromium.org59297c72013-01-09 16:32:23 +000093 F(NotifyStubFailure, 0, 1) \
ager@chromium.orga9aa5fa2011-04-13 08:46:07 +000094 F(DeoptimizeFunction, 1, 1) \
jkummerow@chromium.org212d9642012-05-11 15:02:09 +000095 F(ClearFunctionTypeFeedback, 1, 1) \
svenpanne@chromium.org6d786c92011-06-15 10:58:27 +000096 F(RunningInSimulator, 0, 1) \
rossberg@chromium.org92597162013-08-23 13:28:00 +000097 F(IsConcurrentRecompilationSupported, 0, 1) \
kmillikin@chromium.orgbe6bd102012-02-23 08:45:21 +000098 F(OptimizeFunctionOnNextCall, -1, 1) \
jkummerow@chromium.orgba72ec82013-07-22 09:21:20 +000099 F(NeverOptimizeFunction, 1, 1) \
100 F(GetOptimizationStatus, -1, 1) \
lrn@chromium.org1c092762011-05-09 09:42:16 +0000101 F(GetOptimizationCount, 1, 1) \
mstarzinger@chromium.orga2e1a402013-10-15 08:25:05 +0000102 F(UnblockConcurrentRecompilation, 0, 1) \
dslomov@chromium.orge97852d2013-09-12 09:02:59 +0000103 F(CompileForOnStackReplacement, 2, 1) \
rossberg@chromium.orgebeba022013-08-19 09:36:44 +0000104 F(SetAllocationTimeout, 2, 1) \
lrn@chromium.orgc4e51ac2010-08-09 09:47:21 +0000105 F(AllocateInNewSpace, 1, 1) \
svenpanne@chromium.org2bda5432013-03-15 12:39:50 +0000106 F(AllocateInOldPointerSpace, 1, 1) \
jkummerow@chromium.orgc1184022013-05-28 16:58:15 +0000107 F(AllocateInOldDataSpace, 1, 1) \
ricow@chromium.orgd2be9012011-06-01 06:00:58 +0000108 F(SetNativeFlag, 1, 1) \
jkummerow@chromium.orgc3b37122011-11-07 10:14:12 +0000109 F(StoreArrayLiteralElement, 5, 1) \
mstarzinger@chromium.org88d326b2012-04-23 12:57:22 +0000110 F(DebugCallbackSupportsStepping, 1, 1) \
111 F(DebugPrepareStepInIfStepping, 1, 1) \
jkummerow@chromium.org59297c72013-01-09 16:32:23 +0000112 F(FlattenString, 1, 1) \
danno@chromium.org59400602013-08-13 17:09:37 +0000113 F(MigrateInstance, 1, 1) \
verwaest@chromium.orgec6855e2013-08-22 12:26:58 +0000114 F(NotifyContextDisposed, 0, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000115 \
ager@chromium.org9258b6b2008-09-11 09:11:10 +0000116 /* Array join support */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000117 F(PushIfAbsent, 2, 1) \
118 F(ArrayConcat, 1, 1) \
ager@chromium.org9258b6b2008-09-11 09:11:10 +0000119 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000120 /* Conversions */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000121 F(ToBool, 1, 1) \
122 F(Typeof, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000123 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000124 F(StringToNumber, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000125 F(StringParseInt, 2, 1) \
126 F(StringParseFloat, 1, 1) \
127 F(StringToLowerCase, 1, 1) \
128 F(StringToUpperCase, 1, 1) \
fschneider@chromium.org086aac62010-03-17 13:18:24 +0000129 F(StringSplit, 3, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000130 F(CharFromCode, 1, 1) \
131 F(URIEscape, 1, 1) \
132 F(URIUnescape, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000133 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000134 F(NumberToString, 1, 1) \
ager@chromium.org357bf652010-04-12 11:30:10 +0000135 F(NumberToStringSkipCache, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000136 F(NumberToInteger, 1, 1) \
mstarzinger@chromium.orgf705b502013-04-04 11:38:09 +0000137 F(NumberToPositiveInteger, 1, 1) \
ricow@chromium.org30ce4112010-05-31 10:38:25 +0000138 F(NumberToIntegerMapMinusZero, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000139 F(NumberToJSUint32, 1, 1) \
140 F(NumberToJSInt32, 1, 1) \
141 F(NumberToSmi, 1, 1) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +0000142 F(AllocateHeapNumber, 0, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000143 \
144 /* Arithmetic operations */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000145 F(NumberAdd, 2, 1) \
146 F(NumberSub, 2, 1) \
147 F(NumberMul, 2, 1) \
148 F(NumberDiv, 2, 1) \
149 F(NumberMod, 2, 1) \
150 F(NumberUnaryMinus, 1, 1) \
ager@chromium.org6a2b0aa2010-07-13 20:58:03 +0000151 F(NumberAlloc, 0, 1) \
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000152 F(NumberImul, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000153 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000154 F(StringAdd, 2, 1) \
fschneider@chromium.org0c20e672010-01-14 15:28:53 +0000155 F(StringBuilderConcat, 3, 1) \
kmillikin@chromium.org49edbdf2011-02-16 12:32:18 +0000156 F(StringBuilderJoin, 3, 1) \
ricow@chromium.org27bf2882011-11-17 08:34:43 +0000157 F(SparseJoinWithSeparator, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000158 \
159 /* Bit operations */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000160 F(NumberOr, 2, 1) \
161 F(NumberAnd, 2, 1) \
162 F(NumberXor, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000163 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000164 F(NumberShl, 2, 1) \
165 F(NumberShr, 2, 1) \
166 F(NumberSar, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000167 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000168 /* Comparisons */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000169 F(NumberEquals, 2, 1) \
170 F(StringEquals, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000171 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000172 F(NumberCompare, 3, 1) \
173 F(SmiLexicographicCompare, 2, 1) \
174 F(StringCompare, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000175 \
176 /* Math */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000177 F(Math_acos, 1, 1) \
178 F(Math_asin, 1, 1) \
179 F(Math_atan, 1, 1) \
180 F(Math_atan2, 2, 1) \
181 F(Math_ceil, 1, 1) \
182 F(Math_cos, 1, 1) \
183 F(Math_exp, 1, 1) \
184 F(Math_floor, 1, 1) \
185 F(Math_log, 1, 1) \
186 F(Math_pow, 2, 1) \
ager@chromium.orgce5e87b2010-03-10 10:24:18 +0000187 F(Math_pow_cfunction, 2, 1) \
whesse@chromium.orgcec079d2010-03-22 14:44:04 +0000188 F(RoundNumber, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000189 F(Math_sin, 1, 1) \
190 F(Math_sqrt, 1, 1) \
191 F(Math_tan, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000192 \
193 /* Regular expressions */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000194 F(RegExpCompile, 3, 1) \
195 F(RegExpExec, 4, 1) \
lrn@chromium.org25156de2010-04-06 13:10:27 +0000196 F(RegExpExecMultiple, 4, 1) \
197 F(RegExpInitializeObject, 5, 1) \
whesse@chromium.orgb6e43bb2010-04-14 09:36:28 +0000198 F(RegExpConstructResult, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000199 \
fschneider@chromium.orge03fb642010-11-01 12:34:09 +0000200 /* JSON */ \
201 F(ParseJson, 1, 1) \
mstarzinger@chromium.org32280cf2012-12-06 17:32:37 +0000202 F(BasicJSONStringify, 1, 1) \
203 F(QuoteJSONString, 1, 1) \
fschneider@chromium.orge03fb642010-11-01 12:34:09 +0000204 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000205 /* Strings */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000206 F(StringCharCodeAt, 2, 1) \
207 F(StringIndexOf, 3, 1) \
208 F(StringLastIndexOf, 3, 1) \
209 F(StringLocaleCompare, 2, 1) \
ager@chromium.orgc4c92722009-11-18 14:12:51 +0000210 F(SubString, 3, 1) \
hpayer@chromium.org8432c912013-02-28 15:55:26 +0000211 F(StringReplaceGlobalRegExpWithString, 4, 1) \
ulan@chromium.org2efb9002012-01-19 15:36:35 +0000212 F(StringReplaceOneCharWithString, 3, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000213 F(StringMatch, 3, 1) \
christian.plesner.hansen@gmail.com9d58c2b2009-10-16 11:48:38 +0000214 F(StringTrim, 3, 1) \
ager@chromium.orgbeb25712010-11-29 08:02:25 +0000215 F(StringToArray, 2, 1) \
ricow@chromium.orgd236f4d2010-09-01 06:52:08 +0000216 F(NewStringWrapper, 1, 1) \
mstarzinger@chromium.org32280cf2012-12-06 17:32:37 +0000217 F(NewString, 2, 1) \
218 F(TruncateString, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000219 \
220 /* Numbers */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000221 F(NumberToRadixString, 2, 1) \
222 F(NumberToFixed, 2, 1) \
223 F(NumberToExponential, 2, 1) \
verwaest@chromium.org662436e2013-08-28 08:41:27 +0000224 F(NumberToPrecision, 2, 1) \
225 F(IsValidSmi, 1, 1)
ager@chromium.orgce58e172009-05-13 07:11:48 +0000226
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000227
ager@chromium.orgce58e172009-05-13 07:11:48 +0000228#define RUNTIME_FUNCTION_LIST_ALWAYS_2(F) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000229 /* Reflection */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000230 F(FunctionSetInstanceClassName, 2, 1) \
231 F(FunctionSetLength, 2, 1) \
232 F(FunctionSetPrototype, 2, 1) \
ricow@chromium.org2c99e282011-07-28 09:15:17 +0000233 F(FunctionSetReadOnlyPrototype, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000234 F(FunctionGetName, 1, 1) \
235 F(FunctionSetName, 2, 1) \
kmillikin@chromium.org7c2628c2011-08-10 11:27:35 +0000236 F(FunctionNameShouldPrintAsAnonymous, 1, 1) \
237 F(FunctionMarkNameShouldPrintAsAnonymous, 1, 1) \
ulan@chromium.org57ff8812013-05-10 08:16:55 +0000238 F(FunctionIsGenerator, 1, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000239 F(FunctionBindArguments, 4, 1) \
240 F(BoundFunctionGetBindings, 1, 1) \
kmillikin@chromium.org4111b802010-05-03 10:34:42 +0000241 F(FunctionRemovePrototype, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000242 F(FunctionGetSourceCode, 1, 1) \
243 F(FunctionGetScript, 1, 1) \
244 F(FunctionGetScriptSourcePosition, 1, 1) \
245 F(FunctionGetPositionForOffset, 2, 1) \
246 F(FunctionIsAPIFunction, 1, 1) \
christian.plesner.hansen@gmail.com2bc58ef2009-09-22 10:00:30 +0000247 F(FunctionIsBuiltin, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000248 F(GetScript, 1, 1) \
jkummerow@chromium.orgab7dad42012-02-07 12:07:34 +0000249 F(CollectStackTrace, 3, 1) \
jkummerow@chromium.orgfb732b12013-07-26 10:27:09 +0000250 F(GetAndClearOverflowedStackTrace, 1, 1) \
ager@chromium.org3811b432009-10-28 14:53:37 +0000251 F(GetV8Version, 0, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000252 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000253 F(ClassOf, 1, 1) \
254 F(SetCode, 2, 1) \
ricow@chromium.orgd236f4d2010-09-01 06:52:08 +0000255 F(SetExpectedNumberOfProperties, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000256 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000257 F(CreateApiFunction, 1, 1) \
258 F(IsTemplate, 1, 1) \
259 F(GetTemplateField, 2, 1) \
260 F(DisableAccessChecks, 1, 1) \
261 F(EnableAccessChecks, 1, 1) \
jkummerow@chromium.org1e8da742013-08-26 17:13:35 +0000262 F(SetAccessorProperty, 6, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000263 \
264 /* Dates */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000265 F(DateCurrentTime, 0, 1) \
266 F(DateParseString, 2, 1) \
267 F(DateLocalTimezone, 1, 1) \
svenpanne@chromium.org4efbdb12012-03-12 08:18:42 +0000268 F(DateToUTC, 1, 1) \
jkummerow@chromium.orgc3b37122011-11-07 10:14:12 +0000269 F(DateMakeDay, 2, 1) \
svenpanne@chromium.org4efbdb12012-03-12 08:18:42 +0000270 F(DateSetValue, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000271 \
272 /* Numbers */ \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000273 \
274 /* Globals */ \
svenpanne@chromium.org9faefa42013-03-08 13:13:16 +0000275 F(CompileString, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000276 F(GlobalPrint, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000277 \
278 /* Eval */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000279 F(GlobalReceiver, 1, 1) \
jkummerow@chromium.org04e4f1e2011-11-14 13:36:17 +0000280 F(ResolvePossiblyDirectEval, 5, 2) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000281 \
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000282 F(SetProperty, -1 /* 4 or 5 */, 1) \
ager@chromium.org5c838252010-02-19 08:53:10 +0000283 F(DefineOrRedefineDataProperty, 4, 1) \
284 F(DefineOrRedefineAccessorProperty, 5, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000285 F(IgnoreAttributesAndSetProperty, -1 /* 3 or 4 */, 1) \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000286 F(GetDataProperty, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000287 \
288 /* Arrays */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000289 F(RemoveArrayHoles, 2, 1) \
290 F(GetArrayKeys, 2, 1) \
291 F(MoveArrayContents, 2, 1) \
292 F(EstimateNumberOfElements, 1, 1) \
ulan@chromium.orgdfe53072013-06-06 14:14:51 +0000293 F(ArrayConstructor, -1, 1) \
294 F(InternalArrayConstructor, -1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000295 \
296 /* Getters and Setters */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000297 F(LookupAccessor, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000298 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000299 /* Literals */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000300 F(MaterializeRegExpLiteral, 4, 1)\
vegorov@chromium.orgf8372902010-03-15 10:26:20 +0000301 F(CreateObjectLiteral, 4, 1) \
kmillikin@chromium.org13bd2942009-12-16 15:36:05 +0000302 F(CreateArrayLiteral, 3, 1) \
303 F(CreateArrayLiteralShallow, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000304 \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000305 /* Harmony generators */ \
306 F(CreateJSGeneratorObject, 0, 1) \
ulan@chromium.org77ca49a2013-04-22 09:43:56 +0000307 F(SuspendJSGeneratorObject, 1, 1) \
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000308 F(ResumeJSGeneratorObject, 3, 1) \
309 F(ThrowGeneratorStateError, 1, 1) \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000310 \
svenpanne@chromium.orga53e8e02013-05-24 12:35:50 +0000311 /* ES5 */ \
312 F(ObjectFreeze, 1, 1) \
313 \
danno@chromium.org81cac2b2012-07-10 11:28:27 +0000314 /* Harmony modules */ \
315 F(IsJSModule, 1, 1) \
316 \
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000317 /* Harmony symbols */ \
mstarzinger@chromium.orgf705b502013-04-04 11:38:09 +0000318 F(CreateSymbol, 1, 1) \
319 F(SymbolName, 1, 1) \
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000320 \
vegorov@chromium.org7304bca2011-05-16 12:14:13 +0000321 /* Harmony proxies */ \
322 F(CreateJSProxy, 2, 1) \
lrn@chromium.org34e60782011-09-15 07:25:40 +0000323 F(CreateJSFunctionProxy, 4, 1) \
erik.corry@gmail.comd6076d92011-06-06 09:39:18 +0000324 F(IsJSProxy, 1, 1) \
lrn@chromium.org34e60782011-09-15 07:25:40 +0000325 F(IsJSFunctionProxy, 1, 1) \
erik.corry@gmail.comd6076d92011-06-06 09:39:18 +0000326 F(GetHandler, 1, 1) \
lrn@chromium.org34e60782011-09-15 07:25:40 +0000327 F(GetCallTrap, 1, 1) \
328 F(GetConstructTrap, 1, 1) \
rossberg@chromium.org717967f2011-07-20 13:44:42 +0000329 F(Fix, 1, 1) \
vegorov@chromium.org7304bca2011-05-16 12:14:13 +0000330 \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000331 /* Harmony sets */ \
332 F(SetInitialize, 1, 1) \
333 F(SetAdd, 2, 1) \
334 F(SetHas, 2, 1) \
335 F(SetDelete, 2, 1) \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000336 F(SetGetSize, 1, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000337 \
338 /* Harmony maps */ \
339 F(MapInitialize, 1, 1) \
340 F(MapGet, 2, 1) \
jkummerow@chromium.org7a6fc812012-06-27 11:12:38 +0000341 F(MapHas, 2, 1) \
342 F(MapDelete, 2, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000343 F(MapSet, 3, 1) \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000344 F(MapGetSize, 1, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000345 \
jkummerow@chromium.orgba72ec82013-07-22 09:21:20 +0000346 /* Harmony weak maps and sets */ \
347 F(WeakCollectionInitialize, 1, 1) \
348 F(WeakCollectionGet, 2, 1) \
349 F(WeakCollectionHas, 2, 1) \
350 F(WeakCollectionDelete, 2, 1) \
351 F(WeakCollectionSet, 3, 1) \
kmillikin@chromium.org7c2628c2011-08-10 11:27:35 +0000352 \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000353 /* Harmony observe */ \
354 F(IsObserved, 1, 1) \
danno@chromium.org169691d2013-07-15 08:01:13 +0000355 F(SetIsObserved, 1, 1) \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000356 F(SetObserverDeliveryPending, 0, 1) \
357 F(GetObservationState, 0, 1) \
mmassi@chromium.org2f0efde2013-02-06 14:12:58 +0000358 F(ObservationWeakMapCreate, 0, 1) \
359 F(UnwrapGlobalProxy, 1, 1) \
dslomov@chromium.orge97852d2013-09-12 09:02:59 +0000360 F(IsAccessAllowedForObserver, 3, 1) \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000361 \
mstarzinger@chromium.orgf705b502013-04-04 11:38:09 +0000362 /* Harmony typed arrays */ \
363 F(ArrayBufferInitialize, 2, 1)\
364 F(ArrayBufferGetByteLength, 1, 1)\
365 F(ArrayBufferSliceImpl, 3, 1) \
mvstanton@chromium.org63ea3d22013-10-10 09:24:12 +0000366 F(ArrayBufferIsView, 1, 1) \
mstarzinger@chromium.orgf705b502013-04-04 11:38:09 +0000367 \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000368 F(TypedArrayInitialize, 5, 1) \
danno@chromium.orgd3c42102013-08-01 16:58:23 +0000369 F(TypedArrayInitializeFromArrayLike, 4, 1) \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000370 F(TypedArrayGetBuffer, 1, 1) \
371 F(TypedArrayGetByteLength, 1, 1) \
372 F(TypedArrayGetByteOffset, 1, 1) \
373 F(TypedArrayGetLength, 1, 1) \
ulan@chromium.org57ff8812013-05-10 08:16:55 +0000374 F(TypedArraySetFastCases, 3, 1) \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000375 \
mstarzinger@chromium.org1510d582013-06-28 14:00:48 +0000376 F(DataViewInitialize, 4, 1) \
377 F(DataViewGetBuffer, 1, 1) \
378 F(DataViewGetByteLength, 1, 1) \
379 F(DataViewGetByteOffset, 1, 1) \
380 F(DataViewGetInt8, 3, 1) \
381 F(DataViewGetUint8, 3, 1) \
382 F(DataViewGetInt16, 3, 1) \
383 F(DataViewGetUint16, 3, 1) \
384 F(DataViewGetInt32, 3, 1) \
385 F(DataViewGetUint32, 3, 1) \
386 F(DataViewGetFloat32, 3, 1) \
387 F(DataViewGetFloat64, 3, 1) \
388 \
389 F(DataViewSetInt8, 4, 1) \
390 F(DataViewSetUint8, 4, 1) \
391 F(DataViewSetInt16, 4, 1) \
392 F(DataViewSetUint16, 4, 1) \
393 F(DataViewSetInt32, 4, 1) \
394 F(DataViewSetUint32, 4, 1) \
395 F(DataViewSetFloat32, 4, 1) \
396 F(DataViewSetFloat64, 4, 1) \
397 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000398 /* Statements */ \
vegorov@chromium.org21b5e952010-11-23 10:24:40 +0000399 F(NewClosure, 3, 1) \
verwaest@chromium.org662436e2013-08-28 08:41:27 +0000400 F(NewClosureFromStubFailure, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000401 F(NewObject, 1, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000402 F(NewObjectFromBound, 1, 1) \
whesse@chromium.org4a1fe7d2010-09-27 12:32:04 +0000403 F(FinalizeInstanceSize, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000404 F(Throw, 1, 1) \
405 F(ReThrow, 1, 1) \
406 F(ThrowReferenceError, 1, 1) \
mstarzinger@chromium.orgde886792012-09-11 13:22:37 +0000407 F(ThrowNotDateError, 0, 1) \
whesse@chromium.org4a5224e2010-10-20 12:37:07 +0000408 F(StackGuard, 0, 1) \
yangguo@chromium.org56454712012-02-16 15:33:53 +0000409 F(Interrupt, 0, 1) \
ager@chromium.orgc4c92722009-11-18 14:12:51 +0000410 F(PromoteScheduledException, 0, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000411 \
412 /* Contexts */ \
yangguo@chromium.org46839fb2012-08-28 09:06:19 +0000413 F(NewGlobalContext, 2, 1) \
svenpanne@chromium.org6d786c92011-06-15 10:58:27 +0000414 F(NewFunctionContext, 1, 1) \
vegorov@chromium.org3cf47312011-06-29 13:20:01 +0000415 F(PushWithContext, 2, 1) \
416 F(PushCatchContext, 3, 1) \
whesse@chromium.org4acdc2c2011-08-15 13:01:23 +0000417 F(PushBlockContext, 2, 1) \
ulan@chromium.org8e8d8822012-11-23 14:36:46 +0000418 F(PushModuleContext, 2, 1) \
ager@chromium.org0ee099b2011-01-25 14:06:47 +0000419 F(DeleteContextSlot, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000420 F(LoadContextSlot, 2, 2) \
421 F(LoadContextSlotNoReferenceError, 2, 2) \
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000422 F(StoreContextSlot, 4, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000423 \
424 /* Declarations and initialization */ \
fschneider@chromium.org1805e212011-09-05 10:49:12 +0000425 F(DeclareGlobals, 3, 1) \
ulan@chromium.org8e8d8822012-11-23 14:36:46 +0000426 F(DeclareModules, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000427 F(DeclareContextSlot, 4, 1) \
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000428 F(InitializeVarGlobal, -1 /* 2 or 3 */, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000429 F(InitializeConstGlobal, 2, 1) \
430 F(InitializeConstContextSlot, 3, 1) \
431 F(OptimizeObjectForAddingMultipleProperties, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000432 \
433 /* Debugging */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000434 F(DebugPrint, 1, 1) \
435 F(DebugTrace, 0, 1) \
436 F(TraceEnter, 0, 1) \
437 F(TraceExit, 1, 1) \
438 F(Abort, 2, 1) \
christian.plesner.hansen@gmail.com37abdec2009-01-06 14:43:28 +0000439 /* Logging */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000440 F(Log, 2, 1) \
christian.plesner.hansen@gmail.com2bc58ef2009-09-22 10:00:30 +0000441 /* ES5 */ \
442 F(LocalKeys, 1, 1) \
ricow@chromium.orgc9c80822010-04-21 08:22:37 +0000443 /* Cache suport */ \
444 F(GetFromCache, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000445 \
kmillikin@chromium.org31b12772011-02-02 16:08:26 +0000446 /* Message objects */ \
kmillikin@chromium.org31b12772011-02-02 16:08:26 +0000447 F(MessageGetStartPosition, 1, 1) \
448 F(MessageGetScript, 1, 1) \
449 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000450 /* Pseudo functions - handled as macros by parser */ \
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000451 F(IS_VAR, 1, 1) \
452 \
453 /* expose boolean functions from objects-inl.h */ \
svenpanne@chromium.org830d30c2012-05-29 13:20:14 +0000454 F(HasFastSmiElements, 1, 1) \
455 F(HasFastSmiOrObjectElements, 1, 1) \
456 F(HasFastObjectElements, 1, 1) \
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000457 F(HasFastDoubleElements, 1, 1) \
svenpanne@chromium.org830d30c2012-05-29 13:20:14 +0000458 F(HasFastHoleyElements, 1, 1) \
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000459 F(HasDictionaryElements, 1, 1) \
svenpanne@chromium.orga53e8e02013-05-24 12:35:50 +0000460 F(HasNonStrictArgumentsElements, 1, 1) \
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000461 F(HasExternalPixelElements, 1, 1) \
462 F(HasExternalArrayElements, 1, 1) \
463 F(HasExternalByteElements, 1, 1) \
464 F(HasExternalUnsignedByteElements, 1, 1) \
465 F(HasExternalShortElements, 1, 1) \
466 F(HasExternalUnsignedShortElements, 1, 1) \
467 F(HasExternalIntElements, 1, 1) \
468 F(HasExternalUnsignedIntElements, 1, 1) \
469 F(HasExternalFloatElements, 1, 1) \
whesse@chromium.org030d38e2011-07-13 13:23:34 +0000470 F(HasExternalDoubleElements, 1, 1) \
mmassi@chromium.org7028c052012-06-13 11:51:58 +0000471 F(HasFastProperties, 1, 1) \
danno@chromium.org94b0d6f2013-02-04 13:33:20 +0000472 F(TransitionElementsKind, 2, 1) \
dslomov@chromium.orge97852d2013-09-12 09:02:59 +0000473 F(HaveSameMap, 2, 1) \
474 F(IsAccessCheckNeeded, 1, 1)
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000475
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000476
ager@chromium.org65dad4b2009-04-23 08:48:43 +0000477#ifdef ENABLE_DEBUGGER_SUPPORT
478#define RUNTIME_FUNCTION_LIST_DEBUGGER_SUPPORT(F) \
479 /* Debugger support*/ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000480 F(DebugBreak, 0, 1) \
481 F(SetDebugEventListener, 2, 1) \
482 F(Break, 0, 1) \
483 F(DebugGetPropertyDetails, 2, 1) \
484 F(DebugGetProperty, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000485 F(DebugPropertyTypeFromDetails, 1, 1) \
486 F(DebugPropertyAttributesFromDetails, 1, 1) \
487 F(DebugPropertyIndexFromDetails, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000488 F(DebugNamedInterceptorPropertyValue, 2, 1) \
489 F(DebugIndexedInterceptorElementValue, 2, 1) \
490 F(CheckExecutionState, 1, 1) \
491 F(GetFrameCount, 1, 1) \
492 F(GetFrameDetails, 2, 1) \
493 F(GetScopeCount, 2, 1) \
mstarzinger@chromium.org1510d582013-06-28 14:00:48 +0000494 F(GetStepInPositions, 2, 1) \
svenpanne@chromium.org84bcc552011-07-18 09:50:57 +0000495 F(GetScopeDetails, 4, 1) \
danno@chromium.org1044a4d2012-04-30 12:34:39 +0000496 F(GetFunctionScopeCount, 1, 1) \
497 F(GetFunctionScopeDetails, 2, 1) \
mmassi@chromium.org49a44672012-12-04 13:52:03 +0000498 F(SetScopeVariableValue, 6, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000499 F(DebugPrintScopes, 0, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000500 F(GetThreadCount, 1, 1) \
501 F(GetThreadDetails, 2, 1) \
whesse@chromium.orge90029b2010-08-02 11:52:17 +0000502 F(SetDisableBreak, 1, 1) \
jkummerow@chromium.org93a47f42013-07-02 14:43:41 +0000503 F(GetBreakLocations, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000504 F(SetFunctionBreakPoint, 3, 1) \
jkummerow@chromium.org93a47f42013-07-02 14:43:41 +0000505 F(SetScriptBreakPoint, 4, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000506 F(ClearBreakPoint, 1, 1) \
507 F(ChangeBreakOnException, 2, 1) \
fschneider@chromium.orgc20610a2010-09-22 09:44:58 +0000508 F(IsBreakOnException, 1, 1) \
dslomov@chromium.org639bac02013-09-09 11:58:54 +0000509 F(PrepareStep, 4, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000510 F(ClearStepping, 0, 1) \
svenpanne@chromium.org84bcc552011-07-18 09:50:57 +0000511 F(DebugEvaluate, 6, 1) \
ager@chromium.org5f0c45f2010-12-17 08:51:21 +0000512 F(DebugEvaluateGlobal, 4, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000513 F(DebugGetLoadedScripts, 0, 1) \
514 F(DebugReferencedBy, 3, 1) \
515 F(DebugConstructedBy, 2, 1) \
516 F(DebugGetPrototype, 1, 1) \
rossberg@chromium.org2c067b12012-03-19 11:01:52 +0000517 F(DebugSetScriptSource, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000518 F(SystemBreak, 0, 1) \
519 F(DebugDisassembleFunction, 1, 1) \
520 F(DebugDisassembleConstructor, 1, 1) \
ager@chromium.orgce5e87b2010-03-10 10:24:18 +0000521 F(FunctionGetInferredName, 1, 1) \
522 F(LiveEditFindSharedFunctionInfosForScript, 1, 1) \
523 F(LiveEditGatherCompileInfo, 2, 1) \
524 F(LiveEditReplaceScript, 3, 1) \
525 F(LiveEditReplaceFunctionCode, 2, 1) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +0000526 F(LiveEditFunctionSourceUpdated, 1, 1) \
kmillikin@chromium.org4111b802010-05-03 10:34:42 +0000527 F(LiveEditFunctionSetScript, 2, 1) \
528 F(LiveEditReplaceRefToNestedFunction, 3, 1) \
ager@chromium.orgce5e87b2010-03-10 10:24:18 +0000529 F(LiveEditPatchFunctionPositions, 2, 1) \
ager@chromium.org357bf652010-04-12 11:30:10 +0000530 F(LiveEditCheckAndDropActivations, 2, 1) \
sgjesse@chromium.orgc6c57182011-01-17 12:24:25 +0000531 F(LiveEditCompareStrings, 2, 1) \
yangguo@chromium.org5a11aaf2012-06-20 11:29:00 +0000532 F(LiveEditRestartFrame, 2, 1) \
ager@chromium.org357bf652010-04-12 11:30:10 +0000533 F(GetFunctionCodePositionFromSource, 2, 1) \
kmillikin@chromium.orgd2c22f02011-01-10 08:15:37 +0000534 F(ExecuteInDebugContext, 2, 1) \
535 \
536 F(SetFlags, 1, 1) \
537 F(CollectGarbage, 1, 1) \
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000538 F(GetHeapUsage, 0, 1) \
kmillikin@chromium.orgd2c22f02011-01-10 08:15:37 +0000539
ager@chromium.org65dad4b2009-04-23 08:48:43 +0000540#else
541#define RUNTIME_FUNCTION_LIST_DEBUGGER_SUPPORT(F)
542#endif
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000543
danno@chromium.org59400602013-08-13 17:09:37 +0000544
545#ifdef V8_I18N_SUPPORT
546#define RUNTIME_FUNCTION_LIST_I18N_SUPPORT(F) \
547 /* i18n support */ \
548 /* Standalone, helper methods. */ \
549 F(CanonicalizeLanguageTag, 1, 1) \
550 F(AvailableLocalesOf, 1, 1) \
551 F(GetDefaultICULocale, 0, 1) \
552 F(GetLanguageTagVariants, 1, 1) \
553 \
554 /* Date format and parse. */ \
555 F(CreateDateTimeFormat, 3, 1) \
556 F(InternalDateFormat, 2, 1) \
557 F(InternalDateParse, 2, 1) \
558 \
559 /* Number format and parse. */ \
560 F(CreateNumberFormat, 3, 1) \
561 F(InternalNumberFormat, 2, 1) \
562 F(InternalNumberParse, 2, 1) \
563 \
564 /* Collator. */ \
565 F(CreateCollator, 3, 1) \
566 F(InternalCompare, 3, 1) \
verwaest@chromium.org32cb9b22013-08-21 11:18:12 +0000567 \
568 /* Break iterator. */ \
569 F(CreateBreakIterator, 3, 1) \
570 F(BreakIteratorAdoptText, 2, 1) \
571 F(BreakIteratorFirst, 1, 1) \
572 F(BreakIteratorNext, 1, 1) \
573 F(BreakIteratorCurrent, 1, 1) \
574 F(BreakIteratorBreakType, 1, 1) \
danno@chromium.org59400602013-08-13 17:09:37 +0000575
576#else
577#define RUNTIME_FUNCTION_LIST_I18N_SUPPORT(F)
578#endif
579
580
kasper.lund44510672008-07-25 07:37:58 +0000581#ifdef DEBUG
582#define RUNTIME_FUNCTION_LIST_DEBUG(F) \
583 /* Testing */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000584 F(ListNatives, 0, 1)
kasper.lund44510672008-07-25 07:37:58 +0000585#else
586#define RUNTIME_FUNCTION_LIST_DEBUG(F)
587#endif
588
kasper.lund44510672008-07-25 07:37:58 +0000589// ----------------------------------------------------------------------------
590// RUNTIME_FUNCTION_LIST defines all runtime functions accessed
591// either directly by id (via the code generator), or indirectly
592// via a native call by name (from within JS code).
593
594#define RUNTIME_FUNCTION_LIST(F) \
ager@chromium.orgce58e172009-05-13 07:11:48 +0000595 RUNTIME_FUNCTION_LIST_ALWAYS_1(F) \
596 RUNTIME_FUNCTION_LIST_ALWAYS_2(F) \
ager@chromium.org65dad4b2009-04-23 08:48:43 +0000597 RUNTIME_FUNCTION_LIST_DEBUG(F) \
danno@chromium.org59400602013-08-13 17:09:37 +0000598 RUNTIME_FUNCTION_LIST_DEBUGGER_SUPPORT(F) \
599 RUNTIME_FUNCTION_LIST_I18N_SUPPORT(F)
kasper.lund44510672008-07-25 07:37:58 +0000600
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000601// ----------------------------------------------------------------------------
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000602// INLINE_FUNCTION_LIST defines all inlined functions accessed
603// with a native call of the form %_name from within JS code.
604// Entries have the form F(name, number of arguments, number of return values).
605#define INLINE_FUNCTION_LIST(F) \
606 F(IsSmi, 1, 1) \
607 F(IsNonNegativeSmi, 1, 1) \
608 F(IsArray, 1, 1) \
609 F(IsRegExp, 1, 1) \
rossberg@chromium.org2c067b12012-03-19 11:01:52 +0000610 F(IsConstructCall, 0, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000611 F(CallFunction, -1 /* receiver + n args + function */, 1) \
612 F(ArgumentsLength, 0, 1) \
613 F(Arguments, 1, 1) \
614 F(ValueOf, 1, 1) \
615 F(SetValueOf, 2, 1) \
rossberg@chromium.org2c067b12012-03-19 11:01:52 +0000616 F(DateField, 2 /* date object, field index */, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000617 F(StringCharFromCode, 1, 1) \
618 F(StringCharAt, 2, 1) \
mstarzinger@chromium.org32280cf2012-12-06 17:32:37 +0000619 F(OneByteSeqStringSetChar, 3, 1) \
620 F(TwoByteSeqStringSetChar, 3, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000621 F(ObjectEquals, 2, 1) \
622 F(RandomHeapNumber, 0, 1) \
623 F(IsObject, 1, 1) \
624 F(IsFunction, 1, 1) \
625 F(IsUndetectableObject, 1, 1) \
626 F(IsSpecObject, 1, 1) \
627 F(IsStringWrapperSafeForDefaultValueOf, 1, 1) \
628 F(MathPow, 2, 1) \
629 F(MathSin, 1, 1) \
630 F(MathCos, 1, 1) \
mstarzinger@chromium.org1b3afd12011-11-29 14:28:56 +0000631 F(MathTan, 1, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000632 F(MathSqrt, 1, 1) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +0000633 F(MathLog, 1, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000634 F(IsRegExpEquivalent, 2, 1) \
635 F(HasCachedArrayIndex, 1, 1) \
vegorov@chromium.org21b5e952010-11-23 10:24:40 +0000636 F(GetCachedArrayIndex, 1, 1) \
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000637 F(FastAsciiArrayJoin, 2, 1) \
verwaest@chromium.org8a00e822013-06-10 15:11:22 +0000638 F(GeneratorNext, 2, 1) \
jkummerow@chromium.org93a47f42013-07-02 14:43:41 +0000639 F(GeneratorThrow, 2, 1) \
640 F(DebugBreakInOptimizedCode, 0, 1)
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000641
642
643// ----------------------------------------------------------------------------
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000644// INLINE_RUNTIME_FUNCTION_LIST defines all inlined functions accessed
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000645// with a native call of the form %_name from within JS code that also have
lrn@chromium.orgfa943b72010-11-03 08:14:36 +0000646// a corresponding runtime function, that is called for slow cases.
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000647// Entries have the form F(name, number of arguments, number of return values).
648#define INLINE_RUNTIME_FUNCTION_LIST(F) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000649 F(ClassOf, 1, 1) \
650 F(StringCharCodeAt, 2, 1) \
651 F(Log, 3, 1) \
652 F(StringAdd, 2, 1) \
653 F(SubString, 3, 1) \
654 F(StringCompare, 2, 1) \
655 F(RegExpExec, 4, 1) \
656 F(RegExpConstructResult, 3, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000657 F(GetFromCache, 2, 1) \
ulan@chromium.orgd6899c32012-05-18 14:12:25 +0000658 F(NumberToString, 1, 1)
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000659
660
661//---------------------------------------------------------------------------
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000662// Runtime provides access to all C++ runtime functions.
663
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000664class RuntimeState {
665 public:
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000666 StaticResource<ConsStringIteratorOp>* string_iterator() {
667 return &string_iterator_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000668 }
669 unibrow::Mapping<unibrow::ToUppercase, 128>* to_upper_mapping() {
670 return &to_upper_mapping_;
671 }
672 unibrow::Mapping<unibrow::ToLowercase, 128>* to_lower_mapping() {
673 return &to_lower_mapping_;
674 }
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000675 ConsStringIteratorOp* string_iterator_compare_x() {
676 return &string_iterator_compare_x_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000677 }
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000678 ConsStringIteratorOp* string_iterator_compare_y() {
679 return &string_iterator_compare_y_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000680 }
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000681 ConsStringIteratorOp* string_locale_compare_it1() {
682 return &string_locale_compare_it1_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000683 }
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000684 ConsStringIteratorOp* string_locale_compare_it2() {
685 return &string_locale_compare_it2_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000686 }
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000687
688 private:
689 RuntimeState() {}
690 // Non-reentrant string buffer for efficient general use in the runtime.
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000691 StaticResource<ConsStringIteratorOp> string_iterator_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000692 unibrow::Mapping<unibrow::ToUppercase, 128> to_upper_mapping_;
693 unibrow::Mapping<unibrow::ToLowercase, 128> to_lower_mapping_;
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000694 ConsStringIteratorOp string_iterator_compare_x_;
695 ConsStringIteratorOp string_iterator_compare_y_;
696 ConsStringIteratorOp string_locale_compare_it1_;
697 ConsStringIteratorOp string_locale_compare_it2_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000698
699 friend class Isolate;
700 friend class Runtime;
701
702 DISALLOW_COPY_AND_ASSIGN(RuntimeState);
703};
704
705
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000706class Runtime : public AllStatic {
707 public:
708 enum FunctionId {
ager@chromium.orga1645e22009-09-09 19:27:10 +0000709#define F(name, nargs, ressize) k##name,
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000710 RUNTIME_FUNCTION_LIST(F)
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000711#undef F
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000712#define F(name, nargs, ressize) kInline##name,
713 INLINE_FUNCTION_LIST(F)
714 INLINE_RUNTIME_FUNCTION_LIST(F)
715#undef F
716 kNumFunctions,
717 kFirstInlineFunction = kInlineIsSmi
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000718 };
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000719
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000720 enum IntrinsicType {
721 RUNTIME,
722 INLINE
723 };
724
725 // Intrinsic function descriptor.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000726 struct Function {
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000727 FunctionId function_id;
728 IntrinsicType intrinsic_type;
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000729 // The JS name of the function.
730 const char* name;
731
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000732 // The C++ (native) entry point. NULL if the function is inlined.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000733 byte* entry;
734
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000735 // The number of arguments expected. nargs is -1 if the function takes
736 // a variable number of arguments.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000737 int nargs;
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000738 // Size of result. Most functions return a single pointer, size 1.
ager@chromium.orga1645e22009-09-09 19:27:10 +0000739 int result_size;
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000740 };
741
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000742 static const int kNotFound = -1;
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000743
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000744 // Add internalized strings for all the intrinsic function names to a
745 // StringDictionary.
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000746 // Returns failure if an allocation fails. In this case, it must be
747 // retried with a new, empty StringDictionary, not with the same one.
748 // Alternatively, heap initialization can be completely restarted.
lrn@chromium.org303ada72010-10-27 09:33:13 +0000749 MUST_USE_RESULT static MaybeObject* InitializeIntrinsicFunctionNames(
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000750 Heap* heap, Object* dictionary);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000751
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000752 // Get the intrinsic function with the given name, which must be internalized.
753 static const Function* FunctionForName(Handle<String> name);
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000754
755 // Get the intrinsic function with the given FunctionId.
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000756 static const Function* FunctionForId(FunctionId id);
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000757
758 // General-purpose helper functions for runtime system.
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000759 static int StringMatch(Isolate* isolate,
760 Handle<String> sub,
761 Handle<String> pat,
762 int index);
kasperl@chromium.org41044eb2008-10-06 08:24:46 +0000763
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000764 static bool IsUpperCaseChar(RuntimeState* runtime_state, uint16_t ch);
kasperl@chromium.orgd1e3e722009-04-14 13:38:25 +0000765
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000766 // TODO(1240886): Some of the following methods are *not* handle safe, but
767 // accept handle arguments. This seems fragile.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000768
769 // Support getting the characters in a string using [] notation as
770 // in Firefox/SpiderMonkey, Safari and Opera.
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000771 MUST_USE_RESULT static MaybeObject* GetElementOrCharAt(Isolate* isolate,
772 Handle<Object> object,
lrn@chromium.org303ada72010-10-27 09:33:13 +0000773 uint32_t index);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000774
ulan@chromium.org77ca49a2013-04-22 09:43:56 +0000775 MUST_USE_RESULT static MaybeObject* GetElementOrCharAtOrFail(
776 Isolate* isolate,
777 Handle<Object> object,
778 uint32_t index);
779
lrn@chromium.org303ada72010-10-27 09:33:13 +0000780 MUST_USE_RESULT static MaybeObject* SetObjectProperty(
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000781 Isolate* isolate,
lrn@chromium.org303ada72010-10-27 09:33:13 +0000782 Handle<Object> object,
783 Handle<Object> key,
784 Handle<Object> value,
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000785 PropertyAttributes attr,
karlklose@chromium.org8f806e82011-03-07 14:06:08 +0000786 StrictModeFlag strict_mode);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000787
mstarzinger@chromium.orgb228be02013-04-18 14:56:59 +0000788 MUST_USE_RESULT static MaybeObject* SetObjectPropertyOrFail(
789 Isolate* isolate,
790 Handle<Object> object,
791 Handle<Object> key,
792 Handle<Object> value,
793 PropertyAttributes attr,
794 StrictModeFlag strict_mode);
795
lrn@chromium.org303ada72010-10-27 09:33:13 +0000796 MUST_USE_RESULT static MaybeObject* ForceSetObjectProperty(
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000797 Isolate* isolate,
lrn@chromium.org303ada72010-10-27 09:33:13 +0000798 Handle<JSObject> object,
799 Handle<Object> key,
800 Handle<Object> value,
801 PropertyAttributes attr);
ager@chromium.org65dad4b2009-04-23 08:48:43 +0000802
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000803 MUST_USE_RESULT static MaybeObject* DeleteObjectProperty(
804 Isolate* isolate,
805 Handle<JSReceiver> object,
806 Handle<Object> key,
807 JSReceiver::DeleteMode mode);
808
809 MUST_USE_RESULT static MaybeObject* HasObjectProperty(
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000810 Isolate* isolate,
svenpanne@chromium.org84bcc552011-07-18 09:50:57 +0000811 Handle<JSReceiver> object,
lrn@chromium.org303ada72010-10-27 09:33:13 +0000812 Handle<Object> key);
ager@chromium.orge2902be2009-06-08 12:21:35 +0000813
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000814 MUST_USE_RESULT static MaybeObject* GetObjectProperty(
815 Isolate* isolate,
816 Handle<Object> object,
817 Handle<Object> key);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000818
mstarzinger@chromium.orgb228be02013-04-18 14:56:59 +0000819 MUST_USE_RESULT static MaybeObject* GetObjectPropertyOrFail(
820 Isolate* isolate,
821 Handle<Object> object,
822 Handle<Object> key);
823
svenpanne@chromium.orga53e8e02013-05-24 12:35:50 +0000824 static void SetupArrayBuffer(Isolate* isolate,
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000825 Handle<JSArrayBuffer> array_buffer,
svenpanne@chromium.orga53e8e02013-05-24 12:35:50 +0000826 bool is_external,
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000827 void* data,
828 size_t allocated_length);
829
830 static bool SetupArrayBufferAllocatingData(
831 Isolate* isolate,
832 Handle<JSArrayBuffer> array_buffer,
danno@chromium.orgd3c42102013-08-01 16:58:23 +0000833 size_t allocated_length,
834 bool initialize = true);
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000835
mstarzinger@chromium.org1510d582013-06-28 14:00:48 +0000836 static void FreeArrayBuffer(
837 Isolate* isolate,
838 JSArrayBuffer* phantom_array_buffer);
839
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000840 // Helper functions used stubs.
machenbach@chromium.org528ce022013-09-23 14:09:36 +0000841 static void PerformGC(Object* result, Isolate* isolate);
ricow@chromium.org7ad65222011-12-19 12:13:11 +0000842
843 // Used in runtime.cc and hydrogen's VisitArrayLiteral.
844 static Handle<Object> CreateArrayLiteralBoilerplate(
845 Isolate* isolate,
846 Handle<FixedArray> literals,
847 Handle<FixedArray> elements);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000848};
849
fschneider@chromium.org1805e212011-09-05 10:49:12 +0000850
851//---------------------------------------------------------------------------
852// Constants used by interface to runtime functions.
853
mstarzinger@chromium.org1b3afd12011-11-29 14:28:56 +0000854class DeclareGlobalsEvalFlag: public BitField<bool, 0, 1> {};
855class DeclareGlobalsNativeFlag: public BitField<bool, 1, 1> {};
856class DeclareGlobalsLanguageMode: public BitField<LanguageMode, 2, 2> {};
fschneider@chromium.org1805e212011-09-05 10:49:12 +0000857
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000858} } // namespace v8::internal
859
860#endif // V8_RUNTIME_H_