blob: 4928e788160e13264e97fc19a684482dc867e4bc [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) \
yangguo@chromium.orgfb377212012-11-16 14:43:43 +000090 F(ParallelRecompile, 1, 1) \
yangguo@chromium.orgfb377212012-11-16 14:43:43 +000091 F(InstallRecompiledCode, 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) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +000094 F(NotifyOSR, 0, 1) \
ager@chromium.orga9aa5fa2011-04-13 08:46:07 +000095 F(DeoptimizeFunction, 1, 1) \
jkummerow@chromium.org212d9642012-05-11 15:02:09 +000096 F(ClearFunctionTypeFeedback, 1, 1) \
svenpanne@chromium.org6d786c92011-06-15 10:58:27 +000097 F(RunningInSimulator, 0, 1) \
dslomov@chromium.orgb752d402013-06-18 11:54:54 +000098 F(IsParallelRecompilationSupported, 0, 1) \
kmillikin@chromium.orgbe6bd102012-02-23 08:45:21 +000099 F(OptimizeFunctionOnNextCall, -1, 1) \
danno@chromium.org41728482013-06-12 22:31:22 +0000100 F(CompleteOptimization, 1, 1) \
lrn@chromium.org1c092762011-05-09 09:42:16 +0000101 F(GetOptimizationStatus, 1, 1) \
102 F(GetOptimizationCount, 1, 1) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +0000103 F(CompileForOnStackReplacement, 1, 1) \
lrn@chromium.orgc4e51ac2010-08-09 09:47:21 +0000104 F(AllocateInNewSpace, 1, 1) \
svenpanne@chromium.org2bda5432013-03-15 12:39:50 +0000105 F(AllocateInOldPointerSpace, 1, 1) \
jkummerow@chromium.orgc1184022013-05-28 16:58:15 +0000106 F(AllocateInOldDataSpace, 1, 1) \
ricow@chromium.orgd2be9012011-06-01 06:00:58 +0000107 F(SetNativeFlag, 1, 1) \
jkummerow@chromium.orgc3b37122011-11-07 10:14:12 +0000108 F(StoreArrayLiteralElement, 5, 1) \
mstarzinger@chromium.org88d326b2012-04-23 12:57:22 +0000109 F(DebugCallbackSupportsStepping, 1, 1) \
110 F(DebugPrepareStepInIfStepping, 1, 1) \
jkummerow@chromium.org59297c72013-01-09 16:32:23 +0000111 F(FlattenString, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000112 \
ager@chromium.org9258b6b2008-09-11 09:11:10 +0000113 /* Array join support */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000114 F(PushIfAbsent, 2, 1) \
115 F(ArrayConcat, 1, 1) \
ager@chromium.org9258b6b2008-09-11 09:11:10 +0000116 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000117 /* Conversions */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000118 F(ToBool, 1, 1) \
119 F(Typeof, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000120 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000121 F(StringToNumber, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000122 F(StringParseInt, 2, 1) \
123 F(StringParseFloat, 1, 1) \
124 F(StringToLowerCase, 1, 1) \
125 F(StringToUpperCase, 1, 1) \
fschneider@chromium.org086aac62010-03-17 13:18:24 +0000126 F(StringSplit, 3, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000127 F(CharFromCode, 1, 1) \
128 F(URIEscape, 1, 1) \
129 F(URIUnescape, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000130 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000131 F(NumberToString, 1, 1) \
ager@chromium.org357bf652010-04-12 11:30:10 +0000132 F(NumberToStringSkipCache, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000133 F(NumberToInteger, 1, 1) \
mstarzinger@chromium.orgf705b502013-04-04 11:38:09 +0000134 F(NumberToPositiveInteger, 1, 1) \
ricow@chromium.org30ce4112010-05-31 10:38:25 +0000135 F(NumberToIntegerMapMinusZero, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000136 F(NumberToJSUint32, 1, 1) \
137 F(NumberToJSInt32, 1, 1) \
138 F(NumberToSmi, 1, 1) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +0000139 F(AllocateHeapNumber, 0, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000140 \
141 /* Arithmetic operations */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000142 F(NumberAdd, 2, 1) \
143 F(NumberSub, 2, 1) \
144 F(NumberMul, 2, 1) \
145 F(NumberDiv, 2, 1) \
146 F(NumberMod, 2, 1) \
147 F(NumberUnaryMinus, 1, 1) \
ager@chromium.org6a2b0aa2010-07-13 20:58:03 +0000148 F(NumberAlloc, 0, 1) \
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000149 F(NumberImul, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000150 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000151 F(StringAdd, 2, 1) \
fschneider@chromium.org0c20e672010-01-14 15:28:53 +0000152 F(StringBuilderConcat, 3, 1) \
kmillikin@chromium.org49edbdf2011-02-16 12:32:18 +0000153 F(StringBuilderJoin, 3, 1) \
ricow@chromium.org27bf2882011-11-17 08:34:43 +0000154 F(SparseJoinWithSeparator, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000155 \
156 /* Bit operations */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000157 F(NumberOr, 2, 1) \
158 F(NumberAnd, 2, 1) \
159 F(NumberXor, 2, 1) \
160 F(NumberNot, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000161 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000162 F(NumberShl, 2, 1) \
163 F(NumberShr, 2, 1) \
164 F(NumberSar, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000165 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000166 /* Comparisons */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000167 F(NumberEquals, 2, 1) \
168 F(StringEquals, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000169 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000170 F(NumberCompare, 3, 1) \
171 F(SmiLexicographicCompare, 2, 1) \
172 F(StringCompare, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000173 \
174 /* Math */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000175 F(Math_acos, 1, 1) \
176 F(Math_asin, 1, 1) \
177 F(Math_atan, 1, 1) \
178 F(Math_atan2, 2, 1) \
179 F(Math_ceil, 1, 1) \
180 F(Math_cos, 1, 1) \
181 F(Math_exp, 1, 1) \
182 F(Math_floor, 1, 1) \
183 F(Math_log, 1, 1) \
184 F(Math_pow, 2, 1) \
ager@chromium.orgce5e87b2010-03-10 10:24:18 +0000185 F(Math_pow_cfunction, 2, 1) \
whesse@chromium.orgcec079d2010-03-22 14:44:04 +0000186 F(RoundNumber, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000187 F(Math_sin, 1, 1) \
188 F(Math_sqrt, 1, 1) \
189 F(Math_tan, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000190 \
191 /* Regular expressions */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000192 F(RegExpCompile, 3, 1) \
193 F(RegExpExec, 4, 1) \
lrn@chromium.org25156de2010-04-06 13:10:27 +0000194 F(RegExpExecMultiple, 4, 1) \
195 F(RegExpInitializeObject, 5, 1) \
whesse@chromium.orgb6e43bb2010-04-14 09:36:28 +0000196 F(RegExpConstructResult, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000197 \
fschneider@chromium.orge03fb642010-11-01 12:34:09 +0000198 /* JSON */ \
199 F(ParseJson, 1, 1) \
mstarzinger@chromium.org32280cf2012-12-06 17:32:37 +0000200 F(BasicJSONStringify, 1, 1) \
201 F(QuoteJSONString, 1, 1) \
fschneider@chromium.orge03fb642010-11-01 12:34:09 +0000202 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000203 /* Strings */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000204 F(StringCharCodeAt, 2, 1) \
205 F(StringIndexOf, 3, 1) \
206 F(StringLastIndexOf, 3, 1) \
207 F(StringLocaleCompare, 2, 1) \
ager@chromium.orgc4c92722009-11-18 14:12:51 +0000208 F(SubString, 3, 1) \
hpayer@chromium.org8432c912013-02-28 15:55:26 +0000209 F(StringReplaceGlobalRegExpWithString, 4, 1) \
ulan@chromium.org2efb9002012-01-19 15:36:35 +0000210 F(StringReplaceOneCharWithString, 3, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000211 F(StringMatch, 3, 1) \
christian.plesner.hansen@gmail.com9d58c2b2009-10-16 11:48:38 +0000212 F(StringTrim, 3, 1) \
ager@chromium.orgbeb25712010-11-29 08:02:25 +0000213 F(StringToArray, 2, 1) \
ricow@chromium.orgd236f4d2010-09-01 06:52:08 +0000214 F(NewStringWrapper, 1, 1) \
mstarzinger@chromium.org32280cf2012-12-06 17:32:37 +0000215 F(NewString, 2, 1) \
216 F(TruncateString, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000217 \
218 /* Numbers */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000219 F(NumberToRadixString, 2, 1) \
220 F(NumberToFixed, 2, 1) \
221 F(NumberToExponential, 2, 1) \
222 F(NumberToPrecision, 2, 1)
ager@chromium.orgce58e172009-05-13 07:11:48 +0000223
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000224
ager@chromium.orgce58e172009-05-13 07:11:48 +0000225#define RUNTIME_FUNCTION_LIST_ALWAYS_2(F) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000226 /* Reflection */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000227 F(FunctionSetInstanceClassName, 2, 1) \
228 F(FunctionSetLength, 2, 1) \
229 F(FunctionSetPrototype, 2, 1) \
ricow@chromium.org2c99e282011-07-28 09:15:17 +0000230 F(FunctionSetReadOnlyPrototype, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000231 F(FunctionGetName, 1, 1) \
232 F(FunctionSetName, 2, 1) \
kmillikin@chromium.org7c2628c2011-08-10 11:27:35 +0000233 F(FunctionNameShouldPrintAsAnonymous, 1, 1) \
234 F(FunctionMarkNameShouldPrintAsAnonymous, 1, 1) \
ulan@chromium.org57ff8812013-05-10 08:16:55 +0000235 F(FunctionIsGenerator, 1, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000236 F(FunctionBindArguments, 4, 1) \
237 F(BoundFunctionGetBindings, 1, 1) \
kmillikin@chromium.org4111b802010-05-03 10:34:42 +0000238 F(FunctionRemovePrototype, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000239 F(FunctionGetSourceCode, 1, 1) \
240 F(FunctionGetScript, 1, 1) \
241 F(FunctionGetScriptSourcePosition, 1, 1) \
242 F(FunctionGetPositionForOffset, 2, 1) \
243 F(FunctionIsAPIFunction, 1, 1) \
christian.plesner.hansen@gmail.com2bc58ef2009-09-22 10:00:30 +0000244 F(FunctionIsBuiltin, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000245 F(GetScript, 1, 1) \
jkummerow@chromium.orgab7dad42012-02-07 12:07:34 +0000246 F(CollectStackTrace, 3, 1) \
yangguo@chromium.org46a2a512013-01-18 16:29:40 +0000247 F(MarkOneShotGetter, 1, 1) \
248 F(GetOverflowedStackTrace, 1, 1) \
249 F(SetOverflowedStackTrace, 2, 1) \
ager@chromium.org3811b432009-10-28 14:53:37 +0000250 F(GetV8Version, 0, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000251 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000252 F(ClassOf, 1, 1) \
253 F(SetCode, 2, 1) \
ricow@chromium.orgd236f4d2010-09-01 06:52:08 +0000254 F(SetExpectedNumberOfProperties, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000255 \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000256 F(CreateApiFunction, 1, 1) \
257 F(IsTemplate, 1, 1) \
258 F(GetTemplateField, 2, 1) \
259 F(DisableAccessChecks, 1, 1) \
260 F(EnableAccessChecks, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000261 \
262 /* Dates */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000263 F(DateCurrentTime, 0, 1) \
264 F(DateParseString, 2, 1) \
265 F(DateLocalTimezone, 1, 1) \
svenpanne@chromium.org4efbdb12012-03-12 08:18:42 +0000266 F(DateToUTC, 1, 1) \
jkummerow@chromium.orgc3b37122011-11-07 10:14:12 +0000267 F(DateMakeDay, 2, 1) \
svenpanne@chromium.org4efbdb12012-03-12 08:18:42 +0000268 F(DateSetValue, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000269 \
270 /* Numbers */ \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000271 \
272 /* Globals */ \
svenpanne@chromium.org9faefa42013-03-08 13:13:16 +0000273 F(CompileString, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000274 F(GlobalPrint, 1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000275 \
276 /* Eval */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000277 F(GlobalReceiver, 1, 1) \
jkummerow@chromium.org04e4f1e2011-11-14 13:36:17 +0000278 F(ResolvePossiblyDirectEval, 5, 2) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000279 \
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000280 F(SetProperty, -1 /* 4 or 5 */, 1) \
ager@chromium.org5c838252010-02-19 08:53:10 +0000281 F(DefineOrRedefineDataProperty, 4, 1) \
282 F(DefineOrRedefineAccessorProperty, 5, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000283 F(IgnoreAttributesAndSetProperty, -1 /* 3 or 4 */, 1) \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000284 F(GetDataProperty, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000285 \
286 /* Arrays */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000287 F(RemoveArrayHoles, 2, 1) \
288 F(GetArrayKeys, 2, 1) \
289 F(MoveArrayContents, 2, 1) \
290 F(EstimateNumberOfElements, 1, 1) \
ulan@chromium.orgdfe53072013-06-06 14:14:51 +0000291 F(ArrayConstructor, -1, 1) \
292 F(InternalArrayConstructor, -1, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000293 \
294 /* Getters and Setters */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000295 F(LookupAccessor, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000296 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000297 /* Literals */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000298 F(MaterializeRegExpLiteral, 4, 1)\
vegorov@chromium.orgf8372902010-03-15 10:26:20 +0000299 F(CreateObjectLiteral, 4, 1) \
300 F(CreateObjectLiteralShallow, 4, 1) \
kmillikin@chromium.org13bd2942009-12-16 15:36:05 +0000301 F(CreateArrayLiteral, 3, 1) \
302 F(CreateArrayLiteralShallow, 3, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000303 \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000304 /* Harmony generators */ \
305 F(CreateJSGeneratorObject, 0, 1) \
ulan@chromium.org77ca49a2013-04-22 09:43:56 +0000306 F(SuspendJSGeneratorObject, 1, 1) \
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000307 F(ResumeJSGeneratorObject, 3, 1) \
308 F(ThrowGeneratorStateError, 1, 1) \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000309 \
svenpanne@chromium.orga53e8e02013-05-24 12:35:50 +0000310 /* ES5 */ \
311 F(ObjectFreeze, 1, 1) \
312 \
danno@chromium.org81cac2b2012-07-10 11:28:27 +0000313 /* Harmony modules */ \
314 F(IsJSModule, 1, 1) \
315 \
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000316 /* Harmony symbols */ \
mstarzinger@chromium.orgf705b502013-04-04 11:38:09 +0000317 F(CreateSymbol, 1, 1) \
318 F(SymbolName, 1, 1) \
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000319 \
vegorov@chromium.org7304bca2011-05-16 12:14:13 +0000320 /* Harmony proxies */ \
321 F(CreateJSProxy, 2, 1) \
lrn@chromium.org34e60782011-09-15 07:25:40 +0000322 F(CreateJSFunctionProxy, 4, 1) \
erik.corry@gmail.comd6076d92011-06-06 09:39:18 +0000323 F(IsJSProxy, 1, 1) \
lrn@chromium.org34e60782011-09-15 07:25:40 +0000324 F(IsJSFunctionProxy, 1, 1) \
erik.corry@gmail.comd6076d92011-06-06 09:39:18 +0000325 F(GetHandler, 1, 1) \
lrn@chromium.org34e60782011-09-15 07:25:40 +0000326 F(GetCallTrap, 1, 1) \
327 F(GetConstructTrap, 1, 1) \
rossberg@chromium.org717967f2011-07-20 13:44:42 +0000328 F(Fix, 1, 1) \
vegorov@chromium.org7304bca2011-05-16 12:14:13 +0000329 \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000330 /* Harmony sets */ \
331 F(SetInitialize, 1, 1) \
332 F(SetAdd, 2, 1) \
333 F(SetHas, 2, 1) \
334 F(SetDelete, 2, 1) \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000335 F(SetGetSize, 1, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000336 \
337 /* Harmony maps */ \
338 F(MapInitialize, 1, 1) \
339 F(MapGet, 2, 1) \
jkummerow@chromium.org7a6fc812012-06-27 11:12:38 +0000340 F(MapHas, 2, 1) \
341 F(MapDelete, 2, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000342 F(MapSet, 3, 1) \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000343 F(MapGetSize, 1, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000344 \
kmillikin@chromium.org7c2628c2011-08-10 11:27:35 +0000345 /* Harmony weakmaps */ \
346 F(WeakMapInitialize, 1, 1) \
347 F(WeakMapGet, 2, 1) \
jkummerow@chromium.org7a6fc812012-06-27 11:12:38 +0000348 F(WeakMapHas, 2, 1) \
349 F(WeakMapDelete, 2, 1) \
kmillikin@chromium.org7c2628c2011-08-10 11:27:35 +0000350 F(WeakMapSet, 3, 1) \
351 \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000352 /* Harmony observe */ \
353 F(IsObserved, 1, 1) \
354 F(SetIsObserved, 2, 1) \
355 F(SetObserverDeliveryPending, 0, 1) \
356 F(GetObservationState, 0, 1) \
mmassi@chromium.org2f0efde2013-02-06 14:12:58 +0000357 F(ObservationWeakMapCreate, 0, 1) \
358 F(UnwrapGlobalProxy, 1, 1) \
mvstanton@chromium.orge4ac3ef2012-11-12 14:53:34 +0000359 \
mstarzinger@chromium.orgf705b502013-04-04 11:38:09 +0000360 /* Harmony typed arrays */ \
361 F(ArrayBufferInitialize, 2, 1)\
362 F(ArrayBufferGetByteLength, 1, 1)\
363 F(ArrayBufferSliceImpl, 3, 1) \
364 \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000365 F(TypedArrayInitialize, 5, 1) \
366 F(TypedArrayGetBuffer, 1, 1) \
367 F(TypedArrayGetByteLength, 1, 1) \
368 F(TypedArrayGetByteOffset, 1, 1) \
369 F(TypedArrayGetLength, 1, 1) \
ulan@chromium.org57ff8812013-05-10 08:16:55 +0000370 F(TypedArraySetFastCases, 3, 1) \
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000371 \
mstarzinger@chromium.org1510d582013-06-28 14:00:48 +0000372 F(DataViewInitialize, 4, 1) \
373 F(DataViewGetBuffer, 1, 1) \
374 F(DataViewGetByteLength, 1, 1) \
375 F(DataViewGetByteOffset, 1, 1) \
376 F(DataViewGetInt8, 3, 1) \
377 F(DataViewGetUint8, 3, 1) \
378 F(DataViewGetInt16, 3, 1) \
379 F(DataViewGetUint16, 3, 1) \
380 F(DataViewGetInt32, 3, 1) \
381 F(DataViewGetUint32, 3, 1) \
382 F(DataViewGetFloat32, 3, 1) \
383 F(DataViewGetFloat64, 3, 1) \
384 \
385 F(DataViewSetInt8, 4, 1) \
386 F(DataViewSetUint8, 4, 1) \
387 F(DataViewSetInt16, 4, 1) \
388 F(DataViewSetUint16, 4, 1) \
389 F(DataViewSetInt32, 4, 1) \
390 F(DataViewSetUint32, 4, 1) \
391 F(DataViewSetFloat32, 4, 1) \
392 F(DataViewSetFloat64, 4, 1) \
393 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000394 /* Statements */ \
vegorov@chromium.org21b5e952010-11-23 10:24:40 +0000395 F(NewClosure, 3, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000396 F(NewObject, 1, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000397 F(NewObjectFromBound, 1, 1) \
whesse@chromium.org4a1fe7d2010-09-27 12:32:04 +0000398 F(FinalizeInstanceSize, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000399 F(Throw, 1, 1) \
400 F(ReThrow, 1, 1) \
401 F(ThrowReferenceError, 1, 1) \
mstarzinger@chromium.orgde886792012-09-11 13:22:37 +0000402 F(ThrowNotDateError, 0, 1) \
whesse@chromium.org4a5224e2010-10-20 12:37:07 +0000403 F(StackGuard, 0, 1) \
yangguo@chromium.org56454712012-02-16 15:33:53 +0000404 F(Interrupt, 0, 1) \
ager@chromium.orgc4c92722009-11-18 14:12:51 +0000405 F(PromoteScheduledException, 0, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000406 \
407 /* Contexts */ \
yangguo@chromium.org46839fb2012-08-28 09:06:19 +0000408 F(NewGlobalContext, 2, 1) \
svenpanne@chromium.org6d786c92011-06-15 10:58:27 +0000409 F(NewFunctionContext, 1, 1) \
vegorov@chromium.org3cf47312011-06-29 13:20:01 +0000410 F(PushWithContext, 2, 1) \
411 F(PushCatchContext, 3, 1) \
whesse@chromium.org4acdc2c2011-08-15 13:01:23 +0000412 F(PushBlockContext, 2, 1) \
ulan@chromium.org8e8d8822012-11-23 14:36:46 +0000413 F(PushModuleContext, 2, 1) \
ager@chromium.org0ee099b2011-01-25 14:06:47 +0000414 F(DeleteContextSlot, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000415 F(LoadContextSlot, 2, 2) \
416 F(LoadContextSlotNoReferenceError, 2, 2) \
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000417 F(StoreContextSlot, 4, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000418 \
419 /* Declarations and initialization */ \
fschneider@chromium.org1805e212011-09-05 10:49:12 +0000420 F(DeclareGlobals, 3, 1) \
ulan@chromium.org8e8d8822012-11-23 14:36:46 +0000421 F(DeclareModules, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000422 F(DeclareContextSlot, 4, 1) \
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000423 F(InitializeVarGlobal, -1 /* 2 or 3 */, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000424 F(InitializeConstGlobal, 2, 1) \
425 F(InitializeConstContextSlot, 3, 1) \
426 F(OptimizeObjectForAddingMultipleProperties, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000427 \
428 /* Debugging */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000429 F(DebugPrint, 1, 1) \
430 F(DebugTrace, 0, 1) \
431 F(TraceEnter, 0, 1) \
432 F(TraceExit, 1, 1) \
433 F(Abort, 2, 1) \
christian.plesner.hansen@gmail.com37abdec2009-01-06 14:43:28 +0000434 /* Logging */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000435 F(Log, 2, 1) \
christian.plesner.hansen@gmail.com2bc58ef2009-09-22 10:00:30 +0000436 /* ES5 */ \
437 F(LocalKeys, 1, 1) \
ricow@chromium.orgc9c80822010-04-21 08:22:37 +0000438 /* Cache suport */ \
439 F(GetFromCache, 2, 1) \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000440 \
kmillikin@chromium.org31b12772011-02-02 16:08:26 +0000441 /* Message objects */ \
kmillikin@chromium.org31b12772011-02-02 16:08:26 +0000442 F(MessageGetStartPosition, 1, 1) \
443 F(MessageGetScript, 1, 1) \
444 \
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000445 /* Pseudo functions - handled as macros by parser */ \
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000446 F(IS_VAR, 1, 1) \
447 \
448 /* expose boolean functions from objects-inl.h */ \
svenpanne@chromium.org830d30c2012-05-29 13:20:14 +0000449 F(HasFastSmiElements, 1, 1) \
450 F(HasFastSmiOrObjectElements, 1, 1) \
451 F(HasFastObjectElements, 1, 1) \
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000452 F(HasFastDoubleElements, 1, 1) \
svenpanne@chromium.org830d30c2012-05-29 13:20:14 +0000453 F(HasFastHoleyElements, 1, 1) \
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000454 F(HasDictionaryElements, 1, 1) \
svenpanne@chromium.orga53e8e02013-05-24 12:35:50 +0000455 F(HasNonStrictArgumentsElements, 1, 1) \
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000456 F(HasExternalPixelElements, 1, 1) \
457 F(HasExternalArrayElements, 1, 1) \
458 F(HasExternalByteElements, 1, 1) \
459 F(HasExternalUnsignedByteElements, 1, 1) \
460 F(HasExternalShortElements, 1, 1) \
461 F(HasExternalUnsignedShortElements, 1, 1) \
462 F(HasExternalIntElements, 1, 1) \
463 F(HasExternalUnsignedIntElements, 1, 1) \
464 F(HasExternalFloatElements, 1, 1) \
whesse@chromium.org030d38e2011-07-13 13:23:34 +0000465 F(HasExternalDoubleElements, 1, 1) \
mmassi@chromium.org7028c052012-06-13 11:51:58 +0000466 F(HasFastProperties, 1, 1) \
danno@chromium.org94b0d6f2013-02-04 13:33:20 +0000467 F(TransitionElementsKind, 2, 1) \
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000468 F(TransitionElementsSmiToDouble, 1, 1) \
469 F(TransitionElementsDoubleToObject, 1, 1) \
rossberg@chromium.orgb4b2aa62011-10-13 09:49:59 +0000470 F(HaveSameMap, 2, 1) \
whesse@chromium.org030d38e2011-07-13 13:23:34 +0000471 /* profiler */ \
472 F(ProfilerResume, 0, 1) \
473 F(ProfilerPause, 0, 1)
ricow@chromium.org4f693d62011-07-04 14:01:31 +0000474
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000475
ager@chromium.org65dad4b2009-04-23 08:48:43 +0000476#ifdef ENABLE_DEBUGGER_SUPPORT
477#define RUNTIME_FUNCTION_LIST_DEBUGGER_SUPPORT(F) \
478 /* Debugger support*/ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000479 F(DebugBreak, 0, 1) \
480 F(SetDebugEventListener, 2, 1) \
481 F(Break, 0, 1) \
482 F(DebugGetPropertyDetails, 2, 1) \
483 F(DebugGetProperty, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000484 F(DebugPropertyTypeFromDetails, 1, 1) \
485 F(DebugPropertyAttributesFromDetails, 1, 1) \
486 F(DebugPropertyIndexFromDetails, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000487 F(DebugNamedInterceptorPropertyValue, 2, 1) \
488 F(DebugIndexedInterceptorElementValue, 2, 1) \
489 F(CheckExecutionState, 1, 1) \
490 F(GetFrameCount, 1, 1) \
491 F(GetFrameDetails, 2, 1) \
492 F(GetScopeCount, 2, 1) \
mstarzinger@chromium.org1510d582013-06-28 14:00:48 +0000493 F(GetStepInPositions, 2, 1) \
svenpanne@chromium.org84bcc552011-07-18 09:50:57 +0000494 F(GetScopeDetails, 4, 1) \
danno@chromium.org1044a4d2012-04-30 12:34:39 +0000495 F(GetFunctionScopeCount, 1, 1) \
496 F(GetFunctionScopeDetails, 2, 1) \
mmassi@chromium.org49a44672012-12-04 13:52:03 +0000497 F(SetScopeVariableValue, 6, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000498 F(DebugPrintScopes, 0, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000499 F(GetThreadCount, 1, 1) \
500 F(GetThreadDetails, 2, 1) \
whesse@chromium.orge90029b2010-08-02 11:52:17 +0000501 F(SetDisableBreak, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000502 F(GetBreakLocations, 1, 1) \
503 F(SetFunctionBreakPoint, 3, 1) \
504 F(SetScriptBreakPoint, 3, 1) \
505 F(ClearBreakPoint, 1, 1) \
506 F(ChangeBreakOnException, 2, 1) \
fschneider@chromium.orgc20610a2010-09-22 09:44:58 +0000507 F(IsBreakOnException, 1, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000508 F(PrepareStep, 3, 1) \
509 F(ClearStepping, 0, 1) \
svenpanne@chromium.org84bcc552011-07-18 09:50:57 +0000510 F(DebugEvaluate, 6, 1) \
ager@chromium.org5f0c45f2010-12-17 08:51:21 +0000511 F(DebugEvaluateGlobal, 4, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000512 F(DebugGetLoadedScripts, 0, 1) \
513 F(DebugReferencedBy, 3, 1) \
514 F(DebugConstructedBy, 2, 1) \
515 F(DebugGetPrototype, 1, 1) \
rossberg@chromium.org2c067b12012-03-19 11:01:52 +0000516 F(DebugSetScriptSource, 2, 1) \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000517 F(SystemBreak, 0, 1) \
518 F(DebugDisassembleFunction, 1, 1) \
519 F(DebugDisassembleConstructor, 1, 1) \
ager@chromium.orgce5e87b2010-03-10 10:24:18 +0000520 F(FunctionGetInferredName, 1, 1) \
521 F(LiveEditFindSharedFunctionInfosForScript, 1, 1) \
522 F(LiveEditGatherCompileInfo, 2, 1) \
523 F(LiveEditReplaceScript, 3, 1) \
524 F(LiveEditReplaceFunctionCode, 2, 1) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +0000525 F(LiveEditFunctionSourceUpdated, 1, 1) \
kmillikin@chromium.org4111b802010-05-03 10:34:42 +0000526 F(LiveEditFunctionSetScript, 2, 1) \
527 F(LiveEditReplaceRefToNestedFunction, 3, 1) \
ager@chromium.orgce5e87b2010-03-10 10:24:18 +0000528 F(LiveEditPatchFunctionPositions, 2, 1) \
ager@chromium.org357bf652010-04-12 11:30:10 +0000529 F(LiveEditCheckAndDropActivations, 2, 1) \
sgjesse@chromium.orgc6c57182011-01-17 12:24:25 +0000530 F(LiveEditCompareStrings, 2, 1) \
yangguo@chromium.org5a11aaf2012-06-20 11:29:00 +0000531 F(LiveEditRestartFrame, 2, 1) \
ager@chromium.org357bf652010-04-12 11:30:10 +0000532 F(GetFunctionCodePositionFromSource, 2, 1) \
kmillikin@chromium.orgd2c22f02011-01-10 08:15:37 +0000533 F(ExecuteInDebugContext, 2, 1) \
534 \
535 F(SetFlags, 1, 1) \
536 F(CollectGarbage, 1, 1) \
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000537 F(GetHeapUsage, 0, 1) \
kmillikin@chromium.orgd2c22f02011-01-10 08:15:37 +0000538
ager@chromium.org65dad4b2009-04-23 08:48:43 +0000539#else
540#define RUNTIME_FUNCTION_LIST_DEBUGGER_SUPPORT(F)
541#endif
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000542
kasper.lund44510672008-07-25 07:37:58 +0000543#ifdef DEBUG
544#define RUNTIME_FUNCTION_LIST_DEBUG(F) \
545 /* Testing */ \
ager@chromium.orga1645e22009-09-09 19:27:10 +0000546 F(ListNatives, 0, 1)
kasper.lund44510672008-07-25 07:37:58 +0000547#else
548#define RUNTIME_FUNCTION_LIST_DEBUG(F)
549#endif
550
kasper.lund44510672008-07-25 07:37:58 +0000551// ----------------------------------------------------------------------------
552// RUNTIME_FUNCTION_LIST defines all runtime functions accessed
553// either directly by id (via the code generator), or indirectly
554// via a native call by name (from within JS code).
555
556#define RUNTIME_FUNCTION_LIST(F) \
ager@chromium.orgce58e172009-05-13 07:11:48 +0000557 RUNTIME_FUNCTION_LIST_ALWAYS_1(F) \
558 RUNTIME_FUNCTION_LIST_ALWAYS_2(F) \
ager@chromium.org65dad4b2009-04-23 08:48:43 +0000559 RUNTIME_FUNCTION_LIST_DEBUG(F) \
whesse@chromium.org030d38e2011-07-13 13:23:34 +0000560 RUNTIME_FUNCTION_LIST_DEBUGGER_SUPPORT(F)
kasper.lund44510672008-07-25 07:37:58 +0000561
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000562// ----------------------------------------------------------------------------
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000563// INLINE_FUNCTION_LIST defines all inlined functions accessed
564// with a native call of the form %_name from within JS code.
565// Entries have the form F(name, number of arguments, number of return values).
566#define INLINE_FUNCTION_LIST(F) \
567 F(IsSmi, 1, 1) \
568 F(IsNonNegativeSmi, 1, 1) \
569 F(IsArray, 1, 1) \
570 F(IsRegExp, 1, 1) \
rossberg@chromium.org2c067b12012-03-19 11:01:52 +0000571 F(IsConstructCall, 0, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000572 F(CallFunction, -1 /* receiver + n args + function */, 1) \
573 F(ArgumentsLength, 0, 1) \
574 F(Arguments, 1, 1) \
575 F(ValueOf, 1, 1) \
576 F(SetValueOf, 2, 1) \
rossberg@chromium.org2c067b12012-03-19 11:01:52 +0000577 F(DateField, 2 /* date object, field index */, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000578 F(StringCharFromCode, 1, 1) \
579 F(StringCharAt, 2, 1) \
mstarzinger@chromium.org32280cf2012-12-06 17:32:37 +0000580 F(OneByteSeqStringSetChar, 3, 1) \
581 F(TwoByteSeqStringSetChar, 3, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000582 F(ObjectEquals, 2, 1) \
583 F(RandomHeapNumber, 0, 1) \
584 F(IsObject, 1, 1) \
585 F(IsFunction, 1, 1) \
586 F(IsUndetectableObject, 1, 1) \
587 F(IsSpecObject, 1, 1) \
588 F(IsStringWrapperSafeForDefaultValueOf, 1, 1) \
589 F(MathPow, 2, 1) \
590 F(MathSin, 1, 1) \
591 F(MathCos, 1, 1) \
mstarzinger@chromium.org1b3afd12011-11-29 14:28:56 +0000592 F(MathTan, 1, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000593 F(MathSqrt, 1, 1) \
kasperl@chromium.orga5551262010-12-07 12:49:48 +0000594 F(MathLog, 1, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000595 F(IsRegExpEquivalent, 2, 1) \
596 F(HasCachedArrayIndex, 1, 1) \
vegorov@chromium.org21b5e952010-11-23 10:24:40 +0000597 F(GetCachedArrayIndex, 1, 1) \
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000598 F(FastAsciiArrayJoin, 2, 1) \
verwaest@chromium.org8a00e822013-06-10 15:11:22 +0000599 F(GeneratorNext, 2, 1) \
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000600 F(GeneratorThrow, 2, 1)
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000601
602
603// ----------------------------------------------------------------------------
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000604// INLINE_RUNTIME_FUNCTION_LIST defines all inlined functions accessed
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000605// with a native call of the form %_name from within JS code that also have
lrn@chromium.orgfa943b72010-11-03 08:14:36 +0000606// a corresponding runtime function, that is called for slow cases.
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000607// Entries have the form F(name, number of arguments, number of return values).
608#define INLINE_RUNTIME_FUNCTION_LIST(F) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000609 F(ClassOf, 1, 1) \
610 F(StringCharCodeAt, 2, 1) \
611 F(Log, 3, 1) \
612 F(StringAdd, 2, 1) \
613 F(SubString, 3, 1) \
614 F(StringCompare, 2, 1) \
615 F(RegExpExec, 4, 1) \
616 F(RegExpConstructResult, 3, 1) \
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000617 F(GetFromCache, 2, 1) \
ulan@chromium.orgd6899c32012-05-18 14:12:25 +0000618 F(NumberToString, 1, 1)
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000619
620
621//---------------------------------------------------------------------------
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000622// Runtime provides access to all C++ runtime functions.
623
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000624class RuntimeState {
625 public:
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000626 StaticResource<ConsStringIteratorOp>* string_iterator() {
627 return &string_iterator_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000628 }
629 unibrow::Mapping<unibrow::ToUppercase, 128>* to_upper_mapping() {
630 return &to_upper_mapping_;
631 }
632 unibrow::Mapping<unibrow::ToLowercase, 128>* to_lower_mapping() {
633 return &to_lower_mapping_;
634 }
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000635 ConsStringIteratorOp* string_iterator_compare_x() {
636 return &string_iterator_compare_x_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000637 }
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000638 ConsStringIteratorOp* string_iterator_compare_y() {
639 return &string_iterator_compare_y_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000640 }
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000641 ConsStringIteratorOp* string_locale_compare_it1() {
642 return &string_locale_compare_it1_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000643 }
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000644 ConsStringIteratorOp* string_locale_compare_it2() {
645 return &string_locale_compare_it2_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000646 }
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000647
648 private:
649 RuntimeState() {}
650 // Non-reentrant string buffer for efficient general use in the runtime.
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000651 StaticResource<ConsStringIteratorOp> string_iterator_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000652 unibrow::Mapping<unibrow::ToUppercase, 128> to_upper_mapping_;
653 unibrow::Mapping<unibrow::ToLowercase, 128> to_lower_mapping_;
yangguo@chromium.org4cd70b42013-01-04 08:57:54 +0000654 ConsStringIteratorOp string_iterator_compare_x_;
655 ConsStringIteratorOp string_iterator_compare_y_;
656 ConsStringIteratorOp string_locale_compare_it1_;
657 ConsStringIteratorOp string_locale_compare_it2_;
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000658
659 friend class Isolate;
660 friend class Runtime;
661
662 DISALLOW_COPY_AND_ASSIGN(RuntimeState);
663};
664
665
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000666class Runtime : public AllStatic {
667 public:
668 enum FunctionId {
ager@chromium.orga1645e22009-09-09 19:27:10 +0000669#define F(name, nargs, ressize) k##name,
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000670 RUNTIME_FUNCTION_LIST(F)
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000671#undef F
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000672#define F(name, nargs, ressize) kInline##name,
673 INLINE_FUNCTION_LIST(F)
674 INLINE_RUNTIME_FUNCTION_LIST(F)
675#undef F
676 kNumFunctions,
677 kFirstInlineFunction = kInlineIsSmi
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000678 };
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000679
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000680 enum IntrinsicType {
681 RUNTIME,
682 INLINE
683 };
684
685 // Intrinsic function descriptor.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000686 struct Function {
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000687 FunctionId function_id;
688 IntrinsicType intrinsic_type;
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000689 // The JS name of the function.
690 const char* name;
691
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000692 // The C++ (native) entry point. NULL if the function is inlined.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000693 byte* entry;
694
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000695 // The number of arguments expected. nargs is -1 if the function takes
696 // a variable number of arguments.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000697 int nargs;
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000698 // Size of result. Most functions return a single pointer, size 1.
ager@chromium.orga1645e22009-09-09 19:27:10 +0000699 int result_size;
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000700 };
701
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000702 static const int kNotFound = -1;
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000703
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000704 // Add internalized strings for all the intrinsic function names to a
705 // StringDictionary.
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000706 // Returns failure if an allocation fails. In this case, it must be
707 // retried with a new, empty StringDictionary, not with the same one.
708 // Alternatively, heap initialization can be completely restarted.
lrn@chromium.org303ada72010-10-27 09:33:13 +0000709 MUST_USE_RESULT static MaybeObject* InitializeIntrinsicFunctionNames(
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000710 Heap* heap, Object* dictionary);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000711
yangguo@chromium.org4a9f6552013-03-04 14:46:33 +0000712 // Get the intrinsic function with the given name, which must be internalized.
713 static const Function* FunctionForName(Handle<String> name);
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000714
715 // Get the intrinsic function with the given FunctionId.
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000716 static const Function* FunctionForId(FunctionId id);
erik.corry@gmail.comd88afa22010-09-15 12:33:05 +0000717
718 // General-purpose helper functions for runtime system.
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000719 static int StringMatch(Isolate* isolate,
720 Handle<String> sub,
721 Handle<String> pat,
722 int index);
kasperl@chromium.org41044eb2008-10-06 08:24:46 +0000723
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000724 static bool IsUpperCaseChar(RuntimeState* runtime_state, uint16_t ch);
kasperl@chromium.orgd1e3e722009-04-14 13:38:25 +0000725
erik.corry@gmail.com394dbcf2011-10-27 07:38:48 +0000726 // TODO(1240886): Some of the following methods are *not* handle safe, but
727 // accept handle arguments. This seems fragile.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000728
729 // Support getting the characters in a string using [] notation as
730 // in Firefox/SpiderMonkey, Safari and Opera.
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000731 MUST_USE_RESULT static MaybeObject* GetElementOrCharAt(Isolate* isolate,
732 Handle<Object> object,
lrn@chromium.org303ada72010-10-27 09:33:13 +0000733 uint32_t index);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000734
ulan@chromium.org77ca49a2013-04-22 09:43:56 +0000735 MUST_USE_RESULT static MaybeObject* GetElementOrCharAtOrFail(
736 Isolate* isolate,
737 Handle<Object> object,
738 uint32_t index);
739
lrn@chromium.org303ada72010-10-27 09:33:13 +0000740 MUST_USE_RESULT static MaybeObject* SetObjectProperty(
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000741 Isolate* isolate,
lrn@chromium.org303ada72010-10-27 09:33:13 +0000742 Handle<Object> object,
743 Handle<Object> key,
744 Handle<Object> value,
ager@chromium.org9ee27ae2011-03-02 13:43:26 +0000745 PropertyAttributes attr,
karlklose@chromium.org8f806e82011-03-07 14:06:08 +0000746 StrictModeFlag strict_mode);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000747
mstarzinger@chromium.orgb228be02013-04-18 14:56:59 +0000748 MUST_USE_RESULT static MaybeObject* SetObjectPropertyOrFail(
749 Isolate* isolate,
750 Handle<Object> object,
751 Handle<Object> key,
752 Handle<Object> value,
753 PropertyAttributes attr,
754 StrictModeFlag strict_mode);
755
lrn@chromium.org303ada72010-10-27 09:33:13 +0000756 MUST_USE_RESULT static MaybeObject* ForceSetObjectProperty(
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000757 Isolate* isolate,
lrn@chromium.org303ada72010-10-27 09:33:13 +0000758 Handle<JSObject> object,
759 Handle<Object> key,
760 Handle<Object> value,
761 PropertyAttributes attr);
ager@chromium.org65dad4b2009-04-23 08:48:43 +0000762
mstarzinger@chromium.orge27d6172013-04-17 11:51:44 +0000763 MUST_USE_RESULT static MaybeObject* DeleteObjectProperty(
764 Isolate* isolate,
765 Handle<JSReceiver> object,
766 Handle<Object> key,
767 JSReceiver::DeleteMode mode);
768
769 MUST_USE_RESULT static MaybeObject* HasObjectProperty(
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000770 Isolate* isolate,
svenpanne@chromium.org84bcc552011-07-18 09:50:57 +0000771 Handle<JSReceiver> object,
lrn@chromium.org303ada72010-10-27 09:33:13 +0000772 Handle<Object> key);
ager@chromium.orge2902be2009-06-08 12:21:35 +0000773
sgjesse@chromium.orgea88ce92011-03-23 11:19:56 +0000774 MUST_USE_RESULT static MaybeObject* GetObjectProperty(
775 Isolate* isolate,
776 Handle<Object> object,
777 Handle<Object> key);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000778
mstarzinger@chromium.orgb228be02013-04-18 14:56:59 +0000779 MUST_USE_RESULT static MaybeObject* GetObjectPropertyOrFail(
780 Isolate* isolate,
781 Handle<Object> object,
782 Handle<Object> key);
783
svenpanne@chromium.orga53e8e02013-05-24 12:35:50 +0000784 static void SetupArrayBuffer(Isolate* isolate,
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000785 Handle<JSArrayBuffer> array_buffer,
svenpanne@chromium.orga53e8e02013-05-24 12:35:50 +0000786 bool is_external,
danno@chromium.orgca29dd82013-04-26 11:59:48 +0000787 void* data,
788 size_t allocated_length);
789
790 static bool SetupArrayBufferAllocatingData(
791 Isolate* isolate,
792 Handle<JSArrayBuffer> array_buffer,
793 size_t allocated_length);
794
mstarzinger@chromium.org1510d582013-06-28 14:00:48 +0000795 static void FreeArrayBuffer(
796 Isolate* isolate,
797 JSArrayBuffer* phantom_array_buffer);
798
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000799 // Helper functions used stubs.
800 static void PerformGC(Object* result);
ricow@chromium.org7ad65222011-12-19 12:13:11 +0000801
802 // Used in runtime.cc and hydrogen's VisitArrayLiteral.
803 static Handle<Object> CreateArrayLiteralBoilerplate(
804 Isolate* isolate,
805 Handle<FixedArray> literals,
806 Handle<FixedArray> elements);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000807};
808
fschneider@chromium.org1805e212011-09-05 10:49:12 +0000809
810//---------------------------------------------------------------------------
811// Constants used by interface to runtime functions.
812
mstarzinger@chromium.org1b3afd12011-11-29 14:28:56 +0000813class DeclareGlobalsEvalFlag: public BitField<bool, 0, 1> {};
814class DeclareGlobalsNativeFlag: public BitField<bool, 1, 1> {};
815class DeclareGlobalsLanguageMode: public BitField<LanguageMode, 2, 2> {};
fschneider@chromium.org1805e212011-09-05 10:49:12 +0000816
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +0000817} } // namespace v8::internal
818
819#endif // V8_RUNTIME_H_