1 /* 2 * Copyright (c) 2021 Huawei Device Co., Ltd. 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16 #ifndef ECMASCRIPT_INTERPRETER_SLOW_RUNTIME_STUB_H 17 #define ECMASCRIPT_INTERPRETER_SLOW_RUNTIME_STUB_H 18 19 #include "ecmascript/jspandafile/program_object.h" 20 #include "ecmascript/js_tagged_value.h" 21 #include "ecmascript/js_thread.h" 22 23 namespace panda::ecmascript { 24 class GlobalEnv; 25 class JSArray; 26 27 class SlowRuntimeStub { 28 public: 29 static JSTaggedValue CallSpread(JSThread *thread, JSTaggedValue func, JSTaggedValue obj, JSTaggedValue array); 30 static JSTaggedValue Neg(JSThread *thread, JSTaggedValue value); 31 static JSTaggedValue AsyncFunctionEnter(JSThread *thread); 32 static JSTaggedValue ToNumber(JSThread *thread, JSTaggedValue value); 33 static JSTaggedValue ToNumeric(JSThread *thread, JSTaggedValue value); 34 static JSTaggedValue Not(JSThread *thread, JSTaggedValue value); 35 static JSTaggedValue Inc(JSThread *thread, JSTaggedValue value); 36 static JSTaggedValue Dec(JSThread *thread, JSTaggedValue value); 37 static void Throw(JSThread *thread, JSTaggedValue value); 38 static JSTaggedValue GetPropIterator(JSThread *thread, JSTaggedValue value); 39 static void ThrowConstAssignment(JSThread *thread, JSTaggedValue value); 40 static JSTaggedValue Add2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 41 static JSTaggedValue Sub2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 42 static JSTaggedValue Mul2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 43 static JSTaggedValue Div2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 44 static JSTaggedValue Mod2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 45 static JSTaggedValue Eq(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 46 static JSTaggedValue NotEq(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 47 static JSTaggedValue Less(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 48 static JSTaggedValue LessEq(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 49 static JSTaggedValue Greater(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 50 static JSTaggedValue GreaterEq(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 51 static JSTaggedValue Shl2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 52 static JSTaggedValue Shr2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 53 static JSTaggedValue Ashr2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 54 static JSTaggedValue And2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 55 static JSTaggedValue Or2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 56 static JSTaggedValue Xor2(JSThread *thread, JSTaggedValue left, JSTaggedValue right); 57 58 static JSTaggedValue ToJSTaggedValueWithInt32(JSThread *thread, JSTaggedValue value); 59 static JSTaggedValue ToJSTaggedValueWithUint32(JSThread *thread, JSTaggedValue value); 60 61 static JSTaggedValue DelObjProp(JSThread *thread, JSTaggedValue obj, JSTaggedValue prop); 62 static JSTaggedValue NewObjRange(JSThread *thread, JSTaggedValue func, JSTaggedValue newTarget, 63 uint16_t firstArgIdx, uint16_t length); 64 static JSTaggedValue CreateObjectWithExcludedKeys(JSThread *thread, uint16_t numKeys, JSTaggedValue objVal, 65 uint16_t firstArgRegIdx); 66 static JSTaggedValue Exp(JSThread *thread, JSTaggedValue base, JSTaggedValue exponent); 67 static JSTaggedValue IsIn(JSThread *thread, JSTaggedValue prop, JSTaggedValue obj); 68 static JSTaggedValue Instanceof(JSThread *thread, JSTaggedValue obj, JSTaggedValue target); 69 static JSTaggedValue InstanceofByHandler(JSThread *thread, JSTaggedValue target, JSTaggedValue object, 70 JSTaggedValue instOfHandler); 71 72 static JSTaggedValue NewLexicalEnv(JSThread *thread, uint16_t numVars); 73 static JSTaggedValue NewLexicalEnvWithName(JSThread *thread, uint16_t numVars, uint16_t scopeId); 74 static JSTaggedValue CreateIterResultObj(JSThread *thread, JSTaggedValue value, JSTaggedValue flag); 75 76 static JSTaggedValue CreateGeneratorObj(JSThread *thread, JSTaggedValue genFunc); 77 static JSTaggedValue SuspendGenerator(JSThread *thread, JSTaggedValue genObj, JSTaggedValue value); 78 static void SetGeneratorState(JSThread *thread, JSTaggedValue genObj, int32_t index); 79 static JSTaggedValue AsyncFunctionAwaitUncaught(JSThread *thread, JSTaggedValue asyncFuncObj, JSTaggedValue value); 80 static JSTaggedValue AsyncFunctionResolveOrReject(JSThread *thread, JSTaggedValue asyncFuncObj, JSTaggedValue value, 81 bool is_resolve); 82 83 static JSTaggedValue NewObjApply(JSThread *thread, JSTaggedValue func, JSTaggedValue array); 84 static void ThrowUndefinedIfHole(JSThread *thread, JSTaggedValue obj); 85 static void ThrowIfNotObject(JSThread *thread); 86 static void ThrowThrowNotExists(JSThread *thread); 87 static void ThrowPatternNonCoercible(JSThread *thread); 88 static JSTaggedValue ThrowIfSuperNotCorrectCall(JSThread *thread, uint16_t index, JSTaggedValue thisValue); 89 static void ThrowDeleteSuperProperty(JSThread *thread); 90 91 static JSTaggedValue StOwnByName(JSThread *thread, JSTaggedValue obj, JSTaggedValue prop, JSTaggedValue value); 92 static JSTaggedValue StOwnByNameWithNameSet(JSThread *thread, JSTaggedValue obj, JSTaggedValue prop, 93 JSTaggedValue value); 94 static JSTaggedValue StOwnByIndex(JSThread *thread, JSTaggedValue obj, uint32_t idx, JSTaggedValue value); 95 static JSTaggedValue StOwnByValue(JSThread *thread, JSTaggedValue obj, JSTaggedValue key, JSTaggedValue value); 96 static JSTaggedValue StOwnByValueWithNameSet(JSThread *thread, JSTaggedValue obj, JSTaggedValue key, 97 JSTaggedValue value); 98 static JSTaggedValue CreateEmptyArray(JSThread *thread, ObjectFactory *factory, JSHandle<GlobalEnv> globalEnv); 99 static JSTaggedValue CreateEmptyObject(JSThread *thread, ObjectFactory *factory, JSHandle<GlobalEnv> globalEnv); 100 static JSTaggedValue CreateObjectWithBuffer(JSThread *thread, ObjectFactory *factory, JSObject *literal); 101 static JSTaggedValue CreateObjectHavingMethod(JSThread *thread, ObjectFactory *factory, JSObject *literal, 102 JSTaggedValue env); 103 static JSTaggedValue SetObjectWithProto(JSThread *thread, JSTaggedValue proto, JSTaggedValue obj); 104 static JSTaggedValue CreateArrayWithBuffer(JSThread *thread, ObjectFactory *factory, JSArray *literal); 105 106 static JSTaggedValue GetTemplateObject(JSThread *thread, JSTaggedValue literal); 107 static JSTaggedValue GetNextPropName(JSThread *thread, JSTaggedValue iter); 108 static JSTaggedValue CopyDataProperties(JSThread *thread, JSTaggedValue dst, JSTaggedValue src); 109 110 static JSTaggedValue GetUnmapedArgs(JSThread *thread, JSTaggedType *sp, uint32_t actualNumArgs, uint32_t startIdx); 111 static JSTaggedValue CopyRestArgs(JSThread *thread, JSTaggedType *sp, uint32_t restNumArgs, uint32_t startIdx); 112 static JSTaggedValue GetIterator(JSThread *thread, JSTaggedValue obj); 113 static JSTaggedValue GetAsyncIterator(JSThread *thread, JSTaggedValue obj); 114 static JSTaggedValue IterNext(JSThread *thread, JSTaggedValue iter); 115 static JSTaggedValue CloseIterator(JSThread *thread, JSTaggedValue iter); 116 static void StModuleVar(JSThread *thread, JSTaggedValue key, JSTaggedValue value); 117 static JSTaggedValue LdModuleVar(JSThread *thread, JSTaggedValue key, bool inner); 118 static void StModuleVar(JSThread *thread, int32_t index, JSTaggedValue value); 119 static JSTaggedValue LdLocalModuleVar(JSThread *thread, int32_t index); 120 static JSTaggedValue LdExternalModuleVar(JSThread *thread, int32_t index); 121 static JSTaggedValue CreateRegExpWithLiteral(JSThread *thread, JSTaggedValue pattern, uint8_t flags); 122 static JSTaggedValue GetIteratorNext(JSThread *thread, JSTaggedValue obj, JSTaggedValue method); 123 124 static JSTaggedValue DefineGetterSetterByValue(JSThread *thread, JSTaggedValue obj, JSTaggedValue prop, 125 JSTaggedValue getter, JSTaggedValue setter, bool flag); 126 127 static JSTaggedValue LdObjByIndex(JSThread *thread, JSTaggedValue obj, uint32_t idx, bool callGetter, 128 JSTaggedValue receiver); 129 static JSTaggedValue StObjByIndex(JSThread *thread, JSTaggedValue obj, uint32_t idx, JSTaggedValue value); 130 static JSTaggedValue LdObjByName(JSThread *thread, JSTaggedValue obj, JSTaggedValue prop, bool callGetter, 131 JSTaggedValue receiver); 132 static JSTaggedValue StObjByName(JSThread *thread, JSTaggedValue obj, JSTaggedValue prop, JSTaggedValue value); 133 static JSTaggedValue LdObjByValue(JSThread *thread, JSTaggedValue obj, JSTaggedValue prop, bool callGetter, 134 JSTaggedValue receiver); 135 static JSTaggedValue StObjByValue(JSThread *thread, JSTaggedValue obj, JSTaggedValue prop, JSTaggedValue value); 136 static JSTaggedValue TryLdGlobalByNameFromGlobalProto(JSThread *thread, JSTaggedValue global, JSTaggedValue prop); 137 static JSTaggedValue TryStGlobalByName(JSThread *thread, JSTaggedValue prop); 138 static JSTaggedValue LdGlobalVarFromGlobalProto(JSThread *thread, JSTaggedValue global, JSTaggedValue prop); 139 static JSTaggedValue StGlobalVar(JSThread *thread, JSTaggedValue prop, JSTaggedValue value); 140 static JSTaggedValue StGlobalRecord(JSThread *thread, JSTaggedValue prop, JSTaggedValue value, bool isConst); 141 static JSTaggedValue LdGlobalRecord(JSThread *thread, JSTaggedValue key); 142 static JSTaggedValue TryUpdateGlobalRecord(JSThread *thread, JSTaggedValue prop, JSTaggedValue value); 143 static JSTaggedValue StArraySpread(JSThread *thread, JSTaggedValue dst, JSTaggedValue index, JSTaggedValue src); 144 145 static JSTaggedValue DefineFunc(JSThread *thread, Method *method); 146 147 static JSTaggedValue GetSuperConstructor(JSThread *thread, JSTaggedValue ctor); 148 static JSTaggedValue SuperCall(JSThread *thread, JSTaggedValue func, JSTaggedValue newTarget, uint16_t firstVRegIdx, 149 uint16_t length); 150 static JSTaggedValue SuperCallSpread(JSThread *thread, JSTaggedValue func, JSTaggedValue newTarget, 151 JSTaggedValue array); 152 static JSTaggedValue DynamicImport(JSThread *thread, JSTaggedValue specifier, JSTaggedValue func); 153 static JSTaggedValue DefineMethod(JSThread *thread, Method *method, JSTaggedValue homeObject); 154 static JSTaggedValue LdSuperByValue(JSThread *thread, JSTaggedValue obj, JSTaggedValue key, JSTaggedValue thisFunc); 155 static JSTaggedValue StSuperByValue(JSThread *thread, JSTaggedValue obj, JSTaggedValue key, JSTaggedValue value, 156 JSTaggedValue thisFunc); 157 static JSTaggedValue NotifyInlineCache(JSThread *thread, Method *method); 158 static JSTaggedValue ThrowReferenceError(JSThread *thread, JSTaggedValue prop, const char *desc); 159 160 static JSTaggedValue ResolveClass(JSThread *thread, JSTaggedValue ctor, TaggedArray *literal, JSTaggedValue base, 161 JSTaggedValue lexenv); 162 static JSTaggedValue CloneClassFromTemplate(JSThread *thread, JSTaggedValue ctor, JSTaggedValue base, 163 JSTaggedValue lexenv); 164 static JSTaggedValue CreateClassWithBuffer(JSThread *thread, JSTaggedValue base, 165 JSTaggedValue lexenv, JSTaggedValue constpool, 166 uint16_t methodId, uint16_t literalId, JSTaggedValue module); 167 static JSTaggedValue SetClassConstructorLength(JSThread *thread, JSTaggedValue ctor, JSTaggedValue length); 168 static JSTaggedValue GetModuleNamespace(JSThread *thread, JSTaggedValue localName); 169 static JSTaggedValue GetModuleNamespace(JSThread *thread, int32_t index); 170 static JSTaggedValue LdBigInt(JSThread *thread, JSTaggedValue numberBigInt); 171 static JSTaggedValue ThrowTypeError(JSThread *thread, const char *message); 172 static JSTaggedValue SetClassInheritanceRelationship(JSThread *thread, JSTaggedValue ctor, JSTaggedValue base); 173 174 static JSTaggedValue AsyncGeneratorResolve(JSThread *thread, JSTaggedValue asyncFuncObj, 175 const JSTaggedValue value, JSTaggedValue flag); 176 static JSTaggedValue AsyncGeneratorReject(JSThread *thread, JSTaggedValue asyncFuncObj, 177 const JSTaggedValue value); 178 static JSTaggedValue CreateAsyncGeneratorObj(JSThread *thread, JSTaggedValue genFunc); 179 180 static JSTaggedValue LdPatchVar(JSThread *thread, uint32_t index); 181 static JSTaggedValue StPatchVar(JSThread *thread, uint32_t index, JSTaggedValue value); 182 183 static JSTaggedValue NotifyConcurrentResult(JSThread *thread, JSTaggedValue result, JSTaggedValue hint); 184 185 private: 186 static JSTaggedValue ThrowSyntaxError(JSThread *thread, const char *message); 187 static JSTaggedValue GetCallSpreadArgs(JSThread *thread, JSTaggedValue array); 188 }; 189 } // namespace panda::ecmascript 190 #endif // ECMASCRIPT_INTERPRETER_SLOW_RUNTIME_STUB_H 191