mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 1 | /* |
fpizlo@apple.com | bcfd39e | 2015-02-10 23:16:36 +0000 | [diff] [blame] | 2 | * Copyright (C) 2008, 2013, 2015 Apple Inc. All rights reserved. |
commit-queue@webkit.org | d106bf2 | 2012-07-04 21:36:52 +0000 | [diff] [blame] | 3 | * Copyright (C) 2012 Research In Motion Limited. All rights reserved. |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 4 | * |
| 5 | * Redistribution and use in source and binary forms, with or without |
| 6 | * modification, are permitted provided that the following conditions |
| 7 | * are met: |
| 8 | * |
| 9 | * 1. Redistributions of source code must retain the above copyright |
| 10 | * notice, this list of conditions and the following disclaimer. |
| 11 | * 2. Redistributions in binary form must reproduce the above copyright |
| 12 | * notice, this list of conditions and the following disclaimer in the |
| 13 | * documentation and/or other materials provided with the distribution. |
mjs@apple.com | 9204733 | 2014-03-15 04:08:27 +0000 | [diff] [blame] | 14 | * 3. Neither the name of Apple Inc. ("Apple") nor the names of |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 15 | * its contributors may be used to endorse or promote products derived |
| 16 | * from this software without specific prior written permission. |
| 17 | * |
| 18 | * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY |
| 19 | * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
| 20 | * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
| 21 | * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY |
| 22 | * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
| 23 | * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
| 24 | * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
| 25 | * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 26 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
| 27 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 28 | */ |
weinig@apple.com | a963b96 | 2008-06-05 05:36:55 +0000 | [diff] [blame] | 29 | |
ggaren@apple.com | 901a8a2 | 2008-11-17 20:57:18 +0000 | [diff] [blame] | 30 | #ifndef Interpreter_h |
| 31 | #define Interpreter_h |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 32 | |
weinig@apple.com | 49b3250 | 2008-07-06 00:10:04 +0000 | [diff] [blame] | 33 | #include "ArgList.h" |
commit-queue@webkit.org | a4201b0 | 2015-08-17 22:24:20 +0000 | [diff] [blame] | 34 | #include "JSArrowFunction.h" |
mhahnenberg@apple.com | c1bc9d3 | 2013-01-24 21:39:55 +0000 | [diff] [blame] | 35 | #include "JSCJSValue.h" |
ggaren@apple.com | 1d72f77 | 2008-07-03 00:47:00 +0000 | [diff] [blame] | 36 | #include "JSCell.h" |
ggaren@apple.com | bb63926 | 2009-02-20 06:04:21 +0000 | [diff] [blame] | 37 | #include "JSObject.h" |
mark.lam@apple.com | 4fbb9c3 | 2012-10-09 07:12:56 +0000 | [diff] [blame] | 38 | #include "JSStack.h" |
fpizlo@apple.com | 7bbcaab | 2012-02-22 05:23:19 +0000 | [diff] [blame] | 39 | #include "LLIntData.h" |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 40 | #include "Opcode.h" |
commit-queue@webkit.org | 3f922f9 | 2013-08-29 00:28:42 +0000 | [diff] [blame] | 41 | #include "SourceProvider.h" |
fpizlo@apple.com | bcfd39e | 2015-02-10 23:16:36 +0000 | [diff] [blame] | 42 | #include "StackAlignment.h" |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 43 | |
hausmann@webkit.org | f71db05 | 2009-07-15 15:14:15 +0000 | [diff] [blame] | 44 | #include <wtf/HashMap.h> |
commit-queue@webkit.org | d106bf2 | 2012-07-04 21:36:52 +0000 | [diff] [blame] | 45 | #include <wtf/text/StringBuilder.h> |
hausmann@webkit.org | f71db05 | 2009-07-15 15:14:15 +0000 | [diff] [blame] | 46 | |
cwzwarich@webkit.org | 3f782f6 | 2008-09-08 01:28:33 +0000 | [diff] [blame] | 47 | namespace JSC { |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 48 | |
| 49 | class CodeBlock; |
barraclough@apple.com | 83651156 | 2009-08-15 01:14:00 +0000 | [diff] [blame] | 50 | class EvalExecutable; |
oliver@apple.com | ddf4b48 | 2012-02-17 21:17:59 +0000 | [diff] [blame] | 51 | class ExecutableBase; |
barraclough@apple.com | 306bb12 | 2009-08-18 05:34:52 +0000 | [diff] [blame] | 52 | class FunctionExecutable; |
ggaren@apple.com | 9a9a4b5 | 2013-04-18 19:32:17 +0000 | [diff] [blame] | 53 | class VM; |
commit-queue@webkit.org | a4201b0 | 2015-08-17 22:24:20 +0000 | [diff] [blame] | 54 | class JSArrowFunction; |
fpizlo@apple.com | 3a2fa4c | 2015-04-13 22:13:12 +0000 | [diff] [blame] | 55 | class JSFunction; |
oliver@apple.com | c8f3a75 | 2008-06-28 04:02:03 +0000 | [diff] [blame] | 56 | class JSGlobalObject; |
utatane.tea@gmail.com | 6c38958 | 2015-09-04 04:29:04 +0000 | [diff] [blame] | 57 | class JSModuleEnvironment; |
utatane.tea@gmail.com | a8309d9 | 2015-09-01 02:05:30 +0000 | [diff] [blame] | 58 | class JSModuleRecord; |
fpizlo@apple.com | 7bbcaab | 2012-02-22 05:23:19 +0000 | [diff] [blame] | 59 | class LLIntOffsetsExtractor; |
barraclough@apple.com | 83651156 | 2009-08-15 01:14:00 +0000 | [diff] [blame] | 60 | class ProgramExecutable; |
utatane.tea@gmail.com | a8309d9 | 2015-09-01 02:05:30 +0000 | [diff] [blame] | 61 | class ModuleProgramExecutable; |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 62 | class Register; |
ggaren@apple.com | b11e787 | 2012-08-30 22:50:00 +0000 | [diff] [blame] | 63 | class JSScope; |
barraclough@apple.com | eb51bd9 | 2008-07-30 17:38:35 +0000 | [diff] [blame] | 64 | class SamplingTool; |
oliver@apple.com | ef1f5ce | 2009-04-15 07:31:48 +0000 | [diff] [blame] | 65 | struct CallFrameClosure; |
weinig@apple.com | 18064e7 | 2008-12-10 00:26:13 +0000 | [diff] [blame] | 66 | struct HandlerInfo; |
levin@chromium.org | 93604aa | 2009-07-29 08:04:19 +0000 | [diff] [blame] | 67 | struct Instruction; |
msaboff@apple.com | 6f0b31a | 2013-12-04 16:40:17 +0000 | [diff] [blame] | 68 | struct ProtoCallFrame; |
| 69 | |
mark.lam@apple.com | 4348a43 | 2015-09-07 05:19:28 +0000 | [diff] [blame] | 70 | enum UnwindStart { UnwindFromCurrentFrame, UnwindFromCallerFrame }; |
| 71 | |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 72 | enum DebugHookID { |
ggaren@apple.com | d0740c8 | 2008-05-28 20:47:13 +0000 | [diff] [blame] | 73 | WillExecuteProgram, |
| 74 | DidExecuteProgram, |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 75 | DidEnterCallFrame, |
oliver@apple.com | 139b529 | 2008-06-03 22:48:52 +0000 | [diff] [blame] | 76 | DidReachBreakpoint, |
ggaren@apple.com | d0740c8 | 2008-05-28 20:47:13 +0000 | [diff] [blame] | 77 | WillLeaveCallFrame, |
| 78 | WillExecuteStatement |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 79 | }; |
| 80 | |
oliver@apple.com | ddf4b48 | 2012-02-17 21:17:59 +0000 | [diff] [blame] | 81 | enum StackFrameCodeType { |
| 82 | StackFrameGlobalCode, |
| 83 | StackFrameEvalCode, |
utatane.tea@gmail.com | a8309d9 | 2015-09-01 02:05:30 +0000 | [diff] [blame] | 84 | StackFrameModuleCode, |
oliver@apple.com | ddf4b48 | 2012-02-17 21:17:59 +0000 | [diff] [blame] | 85 | StackFrameFunctionCode, |
| 86 | StackFrameNativeCode |
| 87 | }; |
| 88 | |
| 89 | struct StackFrame { |
| 90 | Strong<JSObject> callee; |
| 91 | StackFrameCodeType codeType; |
ggaren@apple.com | 7a6a0f6 | 2015-03-26 23:12:39 +0000 | [diff] [blame] | 92 | Strong<ScriptExecutable> executable; |
oliver@apple.com | e47f99d | 2013-04-06 22:47:56 +0000 | [diff] [blame] | 93 | Strong<UnlinkedCodeBlock> codeBlock; |
| 94 | RefPtr<SourceProvider> code; |
| 95 | int lineOffset; |
mark.lam@apple.com | 5b45f90 | 2013-07-09 16:15:12 +0000 | [diff] [blame] | 96 | unsigned firstLineColumnOffset; |
oliver@apple.com | e47f99d | 2013-04-06 22:47:56 +0000 | [diff] [blame] | 97 | unsigned characterOffset; |
| 98 | unsigned bytecodeOffset; |
benjamin@webkit.org | cff06e4 | 2012-08-30 21:23:51 +0000 | [diff] [blame] | 99 | String sourceURL; |
oliver@apple.com | e47f99d | 2013-04-06 22:47:56 +0000 | [diff] [blame] | 100 | JS_EXPORT_PRIVATE String toString(CallFrame*); |
fpizlo@apple.com | 3a2fa4c | 2015-04-13 22:13:12 +0000 | [diff] [blame] | 101 | String friendlySourceURL() const; |
| 102 | String friendlyFunctionName(CallFrame*) const; |
mark.lam@apple.com | 5b45f90 | 2013-07-09 16:15:12 +0000 | [diff] [blame] | 103 | JS_EXPORT_PRIVATE void computeLineAndColumn(unsigned& line, unsigned& column); |
| 104 | |
| 105 | private: |
| 106 | void expressionInfo(int& divot, int& startOffset, int& endOffset, unsigned& line, unsigned& column); |
oliver@apple.com | ddf4b48 | 2012-02-17 21:17:59 +0000 | [diff] [blame] | 107 | }; |
| 108 | |
mark.lam@apple.com | 6ed0827 | 2015-06-05 18:52:12 +0000 | [diff] [blame] | 109 | class SuspendExceptionScope { |
commit-queue@webkit.org | 3f922f9 | 2013-08-29 00:28:42 +0000 | [diff] [blame] | 110 | public: |
mark.lam@apple.com | 6ed0827 | 2015-06-05 18:52:12 +0000 | [diff] [blame] | 111 | SuspendExceptionScope(VM* vm) |
| 112 | : m_vm(vm) |
commit-queue@webkit.org | 3f922f9 | 2013-08-29 00:28:42 +0000 | [diff] [blame] | 113 | { |
mark.lam@apple.com | 6ed0827 | 2015-06-05 18:52:12 +0000 | [diff] [blame] | 114 | oldException = vm->exception(); |
commit-queue@webkit.org | 3f922f9 | 2013-08-29 00:28:42 +0000 | [diff] [blame] | 115 | vm->clearException(); |
| 116 | } |
mark.lam@apple.com | 6ed0827 | 2015-06-05 18:52:12 +0000 | [diff] [blame] | 117 | ~SuspendExceptionScope() |
commit-queue@webkit.org | 3f922f9 | 2013-08-29 00:28:42 +0000 | [diff] [blame] | 118 | { |
saambarati1@gmail.com | 284319e | 2015-09-17 18:30:04 +0000 | [diff] [blame] | 119 | m_vm->restorePreviousException(oldException); |
commit-queue@webkit.org | 3f922f9 | 2013-08-29 00:28:42 +0000 | [diff] [blame] | 120 | } |
| 121 | private: |
mark.lam@apple.com | 6ed0827 | 2015-06-05 18:52:12 +0000 | [diff] [blame] | 122 | Exception* oldException; |
commit-queue@webkit.org | 3f922f9 | 2013-08-29 00:28:42 +0000 | [diff] [blame] | 123 | VM* m_vm; |
| 124 | }; |
| 125 | |
commit-queue@webkit.org | 8481462 | 2011-08-25 01:25:38 +0000 | [diff] [blame] | 126 | class TopCallFrameSetter { |
| 127 | public: |
mark.lam@apple.com | 315b982 | 2013-08-16 01:47:41 +0000 | [diff] [blame] | 128 | TopCallFrameSetter(VM& currentVM, CallFrame* callFrame) |
| 129 | : vm(currentVM) |
| 130 | , oldCallFrame(currentVM.topCallFrame) |
commit-queue@webkit.org | 8481462 | 2011-08-25 01:25:38 +0000 | [diff] [blame] | 131 | { |
mark.lam@apple.com | 315b982 | 2013-08-16 01:47:41 +0000 | [diff] [blame] | 132 | currentVM.topCallFrame = callFrame; |
commit-queue@webkit.org | 8481462 | 2011-08-25 01:25:38 +0000 | [diff] [blame] | 133 | } |
| 134 | |
| 135 | ~TopCallFrameSetter() |
| 136 | { |
ggaren@apple.com | 9a9a4b5 | 2013-04-18 19:32:17 +0000 | [diff] [blame] | 137 | vm.topCallFrame = oldCallFrame; |
commit-queue@webkit.org | 8481462 | 2011-08-25 01:25:38 +0000 | [diff] [blame] | 138 | } |
| 139 | private: |
ggaren@apple.com | 9a9a4b5 | 2013-04-18 19:32:17 +0000 | [diff] [blame] | 140 | VM& vm; |
commit-queue@webkit.org | 8481462 | 2011-08-25 01:25:38 +0000 | [diff] [blame] | 141 | CallFrame* oldCallFrame; |
| 142 | }; |
oliver@apple.com | e07a459 | 2012-01-25 19:43:06 +0000 | [diff] [blame] | 143 | |
| 144 | class NativeCallFrameTracer { |
| 145 | public: |
mark.lam@apple.com | 315b982 | 2013-08-16 01:47:41 +0000 | [diff] [blame] | 146 | ALWAYS_INLINE NativeCallFrameTracer(VM* vm, CallFrame* callFrame) |
oliver@apple.com | e07a459 | 2012-01-25 19:43:06 +0000 | [diff] [blame] | 147 | { |
mark.lam@apple.com | 315b982 | 2013-08-16 01:47:41 +0000 | [diff] [blame] | 148 | ASSERT(vm); |
oliver@apple.com | e07a459 | 2012-01-25 19:43:06 +0000 | [diff] [blame] | 149 | ASSERT(callFrame); |
mark.lam@apple.com | 4348a43 | 2015-09-07 05:19:28 +0000 | [diff] [blame] | 150 | ASSERT(callFrame < vm->topVMEntryFrame); |
msaboff@apple.com | 5997904 | 2014-08-20 00:36:13 +0000 | [diff] [blame] | 151 | vm->topCallFrame = callFrame; |
| 152 | } |
msaboff@apple.com | 0576b24 | 2014-08-22 19:54:30 +0000 | [diff] [blame] | 153 | }; |
msaboff@apple.com | 5997904 | 2014-08-20 00:36:13 +0000 | [diff] [blame] | 154 | |
msaboff@apple.com | 0576b24 | 2014-08-22 19:54:30 +0000 | [diff] [blame] | 155 | class NativeCallFrameTracerWithRestore { |
| 156 | public: |
| 157 | ALWAYS_INLINE NativeCallFrameTracerWithRestore(VM* vm, VMEntryFrame* vmEntryFrame, CallFrame* callFrame) |
| 158 | : m_vm(vm) |
msaboff@apple.com | 5997904 | 2014-08-20 00:36:13 +0000 | [diff] [blame] | 159 | { |
| 160 | ASSERT(vm); |
| 161 | ASSERT(callFrame); |
msaboff@apple.com | 0576b24 | 2014-08-22 19:54:30 +0000 | [diff] [blame] | 162 | m_savedTopVMEntryFrame = vm->topVMEntryFrame; |
| 163 | m_savedTopCallFrame = vm->topCallFrame; |
msaboff@apple.com | 5997904 | 2014-08-20 00:36:13 +0000 | [diff] [blame] | 164 | vm->topVMEntryFrame = vmEntryFrame; |
mark.lam@apple.com | 315b982 | 2013-08-16 01:47:41 +0000 | [diff] [blame] | 165 | vm->topCallFrame = callFrame; |
oliver@apple.com | e07a459 | 2012-01-25 19:43:06 +0000 | [diff] [blame] | 166 | } |
msaboff@apple.com | 0576b24 | 2014-08-22 19:54:30 +0000 | [diff] [blame] | 167 | |
| 168 | ALWAYS_INLINE ~NativeCallFrameTracerWithRestore() |
| 169 | { |
| 170 | m_vm->topVMEntryFrame = m_savedTopVMEntryFrame; |
| 171 | m_vm->topCallFrame = m_savedTopCallFrame; |
| 172 | } |
| 173 | |
| 174 | private: |
| 175 | VM* m_vm; |
| 176 | VMEntryFrame* m_savedTopVMEntryFrame; |
| 177 | CallFrame* m_savedTopCallFrame; |
oliver@apple.com | e07a459 | 2012-01-25 19:43:06 +0000 | [diff] [blame] | 178 | }; |
commit-queue@webkit.org | 8481462 | 2011-08-25 01:25:38 +0000 | [diff] [blame] | 179 | |
ossy@webkit.org | 95c1bc4 | 2011-01-20 16:30:54 +0000 | [diff] [blame] | 180 | class Interpreter { |
| 181 | WTF_MAKE_FAST_ALLOCATED; |
aroben@apple.com | e089d62 | 2012-02-21 16:26:12 +0000 | [diff] [blame] | 182 | friend class CachedCall; |
fpizlo@apple.com | 7bbcaab | 2012-02-22 05:23:19 +0000 | [diff] [blame] | 183 | friend class LLIntOffsetsExtractor; |
| 184 | friend class JIT; |
commit-queue@webkit.org | 3f922f9 | 2013-08-29 00:28:42 +0000 | [diff] [blame] | 185 | friend class VM; |
mark.lam@apple.com | 8b97fde | 2012-10-22 22:09:58 +0000 | [diff] [blame] | 186 | |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 187 | public: |
ggaren@apple.com | 9a9a4b5 | 2013-04-18 19:32:17 +0000 | [diff] [blame] | 188 | Interpreter(VM &); |
fpizlo@apple.com | 7bbcaab | 2012-02-22 05:23:19 +0000 | [diff] [blame] | 189 | ~Interpreter(); |
fpizlo@apple.com | 0afe966 | 2011-12-20 02:42:06 +0000 | [diff] [blame] | 190 | |
mark.lam@apple.com | a6f900b | 2015-08-18 17:37:21 +0000 | [diff] [blame] | 191 | void initialize(); |
barraclough@apple.com | 7c876fc | 2008-11-11 05:09:46 +0000 | [diff] [blame] | 192 | |
mark.lam@apple.com | 4fbb9c3 | 2012-10-09 07:12:56 +0000 | [diff] [blame] | 193 | JSStack& stack() { return m_stack; } |
ggaren@apple.com | 82a62d0 | 2008-06-27 22:35:33 +0000 | [diff] [blame] | 194 | |
ggaren@apple.com | 47d3f05 | 2008-11-15 21:37:49 +0000 | [diff] [blame] | 195 | Opcode getOpcode(OpcodeID id) |
ggaren@apple.com | e5af6d5 | 2008-09-26 22:43:16 +0000 | [diff] [blame] | 196 | { |
fpizlo@apple.com | 0afe966 | 2011-12-20 02:42:06 +0000 | [diff] [blame] | 197 | ASSERT(m_initialized); |
commit-queue@webkit.org | b841948 | 2012-08-30 22:21:48 +0000 | [diff] [blame] | 198 | #if ENABLE(COMPUTED_GOTO_OPCODES) |
fpizlo@apple.com | 0afe966 | 2011-12-20 02:42:06 +0000 | [diff] [blame] | 199 | return m_opcodeTable[id]; |
| 200 | #else |
| 201 | return id; |
| 202 | #endif |
ggaren@apple.com | e5af6d5 | 2008-09-26 22:43:16 +0000 | [diff] [blame] | 203 | } |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 204 | |
ggaren@apple.com | 47d3f05 | 2008-11-15 21:37:49 +0000 | [diff] [blame] | 205 | OpcodeID getOpcodeID(Opcode opcode) |
weinig@apple.com | a963b96 | 2008-06-05 05:36:55 +0000 | [diff] [blame] | 206 | { |
fpizlo@apple.com | 0afe966 | 2011-12-20 02:42:06 +0000 | [diff] [blame] | 207 | ASSERT(m_initialized); |
dbatyai.u-szeged@partner.samsung.com | 46f07e5 | 2014-06-19 16:32:31 +0000 | [diff] [blame] | 208 | #if ENABLE(COMPUTED_GOTO_OPCODES) |
fpizlo@apple.com | 0afe966 | 2011-12-20 02:42:06 +0000 | [diff] [blame] | 209 | ASSERT(isOpcode(opcode)); |
fpizlo@apple.com | 7bbcaab | 2012-02-22 05:23:19 +0000 | [diff] [blame] | 210 | return m_opcodeIDTable.get(opcode); |
mark.lam@apple.com | 74a9e83 | 2012-09-25 04:30:20 +0000 | [diff] [blame] | 211 | #else |
fpizlo@apple.com | 0afe966 | 2011-12-20 02:42:06 +0000 | [diff] [blame] | 212 | return opcode; |
mark.lam@apple.com | 74a9e83 | 2012-09-25 04:30:20 +0000 | [diff] [blame] | 213 | #endif |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 214 | } |
fpizlo@apple.com | 7bbcaab | 2012-02-22 05:23:19 +0000 | [diff] [blame] | 215 | |
ggaren@apple.com | 47d3f05 | 2008-11-15 21:37:49 +0000 | [diff] [blame] | 216 | bool isOpcode(Opcode); |
barraclough@apple.com | 2607dd0 | 2010-10-27 20:46:09 +0000 | [diff] [blame] | 217 | |
ggaren@apple.com | b11e787 | 2012-08-30 22:50:00 +0000 | [diff] [blame] | 218 | JSValue execute(ProgramExecutable*, CallFrame*, JSObject* thisObj); |
barraclough@apple.com | 2607dd0 | 2010-10-27 20:46:09 +0000 | [diff] [blame] | 219 | JSValue executeCall(CallFrame*, JSObject* function, CallType, const CallData&, JSValue thisValue, const ArgList&); |
utatane.tea@gmail.com | 221fbc4 | 2015-07-22 00:29:39 +0000 | [diff] [blame] | 220 | JSObject* executeConstruct(CallFrame*, JSObject* function, ConstructType, const ConstructData&, const ArgList&, JSValue newTarget); |
ggaren@apple.com | b11e787 | 2012-08-30 22:50:00 +0000 | [diff] [blame] | 221 | JSValue execute(EvalExecutable*, CallFrame*, JSValue thisValue, JSScope*); |
utatane.tea@gmail.com | 6c38958 | 2015-09-04 04:29:04 +0000 | [diff] [blame] | 222 | JSValue execute(ModuleProgramExecutable*, CallFrame*, JSModuleEnvironment*); |
weinig@apple.com | a963b96 | 2008-06-05 05:36:55 +0000 | [diff] [blame] | 223 | |
darin@apple.com | 8c2bac0 | 2008-10-09 00:40:43 +0000 | [diff] [blame] | 224 | void getArgumentsData(CallFrame*, JSFunction*&, ptrdiff_t& firstParameterIndex, Register*& argv, int& argc); |
oliver@apple.com | c8f3a75 | 2008-06-28 04:02:03 +0000 | [diff] [blame] | 225 | |
oliver@apple.com | ebd0b4c | 2009-09-29 21:48:52 +0000 | [diff] [blame] | 226 | SamplingTool* sampler() { return m_sampler.get(); } |
ggaren@apple.com | 82a62d0 | 2008-06-27 22:35:33 +0000 | [diff] [blame] | 227 | |
mark.lam@apple.com | 4348a43 | 2015-09-07 05:19:28 +0000 | [diff] [blame] | 228 | NEVER_INLINE HandlerInfo* unwind(VM&, CallFrame*&, Exception*, UnwindStart); |
saambarati1@gmail.com | 284319e | 2015-09-17 18:30:04 +0000 | [diff] [blame] | 229 | void notifyDebuggerOfExceptionToBeThrown(CallFrame*, Exception*); |
mark.lam@apple.com | e72693d | 2013-09-24 23:52:57 +0000 | [diff] [blame] | 230 | NEVER_INLINE void debug(CallFrame*, DebugHookID); |
commit-queue@webkit.org | 0fc0afa | 2013-07-30 04:33:35 +0000 | [diff] [blame] | 231 | JSString* stackTraceAsString(ExecState*, Vector<StackFrame>); |
barraclough@apple.com | 5b374fc | 2009-06-02 05:36:18 +0000 | [diff] [blame] | 232 | |
mark.lam@apple.com | b07f4c4 | 2013-08-08 16:38:31 +0000 | [diff] [blame] | 233 | static EncodedJSValue JSC_HOST_CALL constructWithErrorConstructor(ExecState*); |
| 234 | static EncodedJSValue JSC_HOST_CALL callErrorConstructor(ExecState*); |
| 235 | static EncodedJSValue JSC_HOST_CALL constructWithNativeErrorConstructor(ExecState*); |
| 236 | static EncodedJSValue JSC_HOST_CALL callNativeErrorConstructor(ExecState*); |
| 237 | |
oliver@apple.com | ebd0b4c | 2009-09-29 21:48:52 +0000 | [diff] [blame] | 238 | void dumpSampleData(ExecState* exec); |
| 239 | void startSampling(); |
| 240 | void stopSampling(); |
oliver@apple.com | a08210b | 2012-07-18 23:26:06 +0000 | [diff] [blame] | 241 | |
| 242 | JS_EXPORT_PRIVATE void dumpCallFrame(CallFrame*); |
| 243 | |
mmirman@apple.com | c35dac9 | 2015-04-07 21:34:05 +0000 | [diff] [blame] | 244 | void getStackTrace(Vector<StackFrame>& results, size_t maxStackSize = std::numeric_limits<size_t>::max()); |
| 245 | |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 246 | private: |
weinig@apple.com | a963b96 | 2008-06-05 05:36:55 +0000 | [diff] [blame] | 247 | enum ExecutionFlag { Normal, InitializeAndReturn }; |
oliver@apple.com | 9a4dea5 | 2009-04-15 07:13:25 +0000 | [diff] [blame] | 248 | |
msaboff@apple.com | 6f0b31a | 2013-12-04 16:40:17 +0000 | [diff] [blame] | 249 | CallFrameClosure prepareForRepeatCall(FunctionExecutable*, CallFrame*, ProtoCallFrame*, JSFunction*, int argumentCountIncludingThis, JSScope*, JSValue*); |
mark.lam@apple.com | afeead1 | 2013-12-05 20:33:35 +0000 | [diff] [blame] | 250 | |
barraclough@apple.com | 2607dd0 | 2010-10-27 20:46:09 +0000 | [diff] [blame] | 251 | JSValue execute(CallFrameClosure&); |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 252 | |
mmirman@apple.com | c35dac9 | 2015-04-07 21:34:05 +0000 | [diff] [blame] | 253 | |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 254 | |
ggaren@apple.com | 68313b0 | 2008-11-13 00:48:23 +0000 | [diff] [blame] | 255 | void dumpRegisters(CallFrame*); |
ggaren@apple.com | 4b8c0fb | 2008-10-20 16:48:30 +0000 | [diff] [blame] | 256 | |
msaboff@apple.com | c15ae7e | 2015-09-16 23:40:35 +0000 | [diff] [blame] | 257 | bool isCallBytecode(Opcode opcode) { return opcode == getOpcode(op_call) || opcode == getOpcode(op_construct) || opcode == getOpcode(op_call_eval) || opcode == getOpcode(op_tail_call); } |
mrowe@apple.com | f88a463 | 2008-09-07 05:44:58 +0000 | [diff] [blame] | 258 | |
oliver@apple.com | ebd0b4c | 2009-09-29 21:48:52 +0000 | [diff] [blame] | 259 | void enableSampler(); |
| 260 | int m_sampleEntryDepth; |
gyuyoung.kim@samsung.com | 2ddbadc | 2014-11-25 02:40:06 +0000 | [diff] [blame] | 261 | std::unique_ptr<SamplingTool> m_sampler; |
ggaren@apple.com | be95ccf | 2008-10-25 19:59:47 +0000 | [diff] [blame] | 262 | |
oliver@apple.com | e0b15ee | 2013-07-25 04:01:06 +0000 | [diff] [blame] | 263 | VM& m_vm; |
mark.lam@apple.com | 4fbb9c3 | 2012-10-09 07:12:56 +0000 | [diff] [blame] | 264 | JSStack m_stack; |
mark.lam@apple.com | 8b97fde | 2012-10-22 22:09:58 +0000 | [diff] [blame] | 265 | int m_errorHandlingModeReentry; |
ggaren@apple.com | 1d72f77 | 2008-07-03 00:47:00 +0000 | [diff] [blame] | 266 | |
dbatyai.u-szeged@partner.samsung.com | 46f07e5 | 2014-06-19 16:32:31 +0000 | [diff] [blame] | 267 | #if ENABLE(COMPUTED_GOTO_OPCODES) |
fpizlo@apple.com | 7bbcaab | 2012-02-22 05:23:19 +0000 | [diff] [blame] | 268 | Opcode* m_opcodeTable; // Maps OpcodeID => Opcode for compiling |
| 269 | HashMap<Opcode, OpcodeID> m_opcodeIDTable; // Maps Opcode => OpcodeID for decompiling |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 270 | #endif |
fpizlo@apple.com | 0afe966 | 2011-12-20 02:42:06 +0000 | [diff] [blame] | 271 | |
| 272 | #if !ASSERT_DISABLED |
| 273 | bool m_initialized; |
| 274 | #endif |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 275 | }; |
barraclough@apple.com | 19afece | 2011-07-15 19:51:49 +0000 | [diff] [blame] | 276 | |
ggaren@apple.com | 539d1bb | 2011-11-14 19:21:40 +0000 | [diff] [blame] | 277 | JSValue eval(CallFrame*); |
fpizlo@apple.com | bcfd39e | 2015-02-10 23:16:36 +0000 | [diff] [blame] | 278 | |
| 279 | inline CallFrame* calleeFrameForVarargs(CallFrame* callFrame, unsigned numUsedStackSlots, unsigned argumentCountIncludingThis) |
| 280 | { |
msaboff@apple.com | c15ae7e | 2015-09-16 23:40:35 +0000 | [diff] [blame] | 281 | // We want the new frame to be allocated on a stack aligned offset with a stack |
| 282 | // aligned size. Align the size here. |
| 283 | argumentCountIncludingThis = WTF::roundUpToMultipleOf( |
| 284 | stackAlignmentRegisters(), |
| 285 | argumentCountIncludingThis + JSStack::CallFrameHeaderSize) - JSStack::CallFrameHeaderSize; |
| 286 | |
| 287 | // Align the frame offset here. |
fpizlo@apple.com | bcfd39e | 2015-02-10 23:16:36 +0000 | [diff] [blame] | 288 | unsigned paddedCalleeFrameOffset = WTF::roundUpToMultipleOf( |
| 289 | stackAlignmentRegisters(), |
| 290 | numUsedStackSlots + argumentCountIncludingThis + JSStack::CallFrameHeaderSize); |
| 291 | return CallFrame::create(callFrame->registers() - paddedCalleeFrameOffset); |
| 292 | } |
| 293 | |
fpizlo@apple.com | 8fefdd3 | 2015-02-18 19:55:47 +0000 | [diff] [blame] | 294 | unsigned sizeOfVarargs(CallFrame* exec, JSValue arguments, uint32_t firstVarArgOffset); |
fpizlo@apple.com | da834ae | 2015-03-26 04:28:43 +0000 | [diff] [blame] | 295 | static const unsigned maxArguments = 0x10000; |
fpizlo@apple.com | bcfd39e | 2015-02-10 23:16:36 +0000 | [diff] [blame] | 296 | unsigned sizeFrameForVarargs(CallFrame* exec, JSStack*, JSValue arguments, unsigned numUsedStackSlots, uint32_t firstVarArgOffset); |
| 297 | void loadVarargs(CallFrame* execCaller, VirtualRegister firstElementDest, JSValue source, uint32_t offset, uint32_t length); |
| 298 | void setupVarargsFrame(CallFrame* execCaller, CallFrame* execCallee, JSValue arguments, uint32_t firstVarArgOffset, uint32_t length); |
| 299 | void setupVarargsFrameAndSetThis(CallFrame* execCaller, CallFrame* execCallee, JSValue thisValue, JSValue arguments, uint32_t firstVarArgOffset, uint32_t length); |
fpizlo@apple.com | 74485fb | 2015-02-10 03:27:43 +0000 | [diff] [blame] | 300 | |
cwzwarich@webkit.org | 3f782f6 | 2008-09-08 01:28:33 +0000 | [diff] [blame] | 301 | } // namespace JSC |
mrowe@apple.com | 2f6dfdf | 2008-05-22 01:20:45 +0000 | [diff] [blame] | 302 | |
ggaren@apple.com | 901a8a2 | 2008-11-17 20:57:18 +0000 | [diff] [blame] | 303 | #endif // Interpreter_h |