summaryrefslogtreecommitdiff
path: root/Source/JavaScriptCore/ftl/FTLSlowPathCall.cpp
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2015-05-20 09:56:07 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2015-05-20 09:56:07 +0000
commit41386e9cb918eed93b3f13648cbef387e371e451 (patch)
treea97f9d7bd1d9d091833286085f72da9d83fd0606 /Source/JavaScriptCore/ftl/FTLSlowPathCall.cpp
parente15dd966d523731101f70ccf768bba12435a0208 (diff)
downloadWebKitGtk-tarball-41386e9cb918eed93b3f13648cbef387e371e451.tar.gz
webkitgtk-2.4.9webkitgtk-2.4.9
Diffstat (limited to 'Source/JavaScriptCore/ftl/FTLSlowPathCall.cpp')
-rw-r--r--Source/JavaScriptCore/ftl/FTLSlowPathCall.cpp220
1 files changed, 0 insertions, 220 deletions
diff --git a/Source/JavaScriptCore/ftl/FTLSlowPathCall.cpp b/Source/JavaScriptCore/ftl/FTLSlowPathCall.cpp
deleted file mode 100644
index ffbd474b6..000000000
--- a/Source/JavaScriptCore/ftl/FTLSlowPathCall.cpp
+++ /dev/null
@@ -1,220 +0,0 @@
-/*
- * Copyright (C) 2013, 2014 Apple Inc. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
- * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
- * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
- * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
- * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
- * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
- * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-#include "config.h"
-#include "FTLSlowPathCall.h"
-
-#if ENABLE(FTL_JIT)
-
-#include "CCallHelpers.h"
-#include "FTLState.h"
-#include "GPRInfo.h"
-#include "JSCInlines.h"
-
-namespace JSC { namespace FTL {
-
-namespace {
-
-// This code relies on us being 64-bit. FTL is currently always 64-bit.
-static const size_t wordSize = 8;
-
-// This will be an RAII thingy that will set up the necessary stack sizes and offsets and such.
-class CallContext {
-public:
- CallContext(
- State& state, const RegisterSet& usedRegisters, CCallHelpers& jit,
- unsigned numArgs, GPRReg returnRegister)
- : m_state(state)
- , m_usedRegisters(usedRegisters)
- , m_jit(jit)
- , m_numArgs(numArgs)
- , m_returnRegister(returnRegister)
- {
- // We don't care that you're using callee-save, stack, or hardware registers.
- m_usedRegisters.exclude(RegisterSet::stackRegisters());
- m_usedRegisters.exclude(RegisterSet::reservedHardwareRegisters());
- m_usedRegisters.exclude(RegisterSet::calleeSaveRegisters());
-
- // The return register doesn't need to be saved.
- if (m_returnRegister != InvalidGPRReg)
- m_usedRegisters.clear(m_returnRegister);
-
- size_t stackBytesNeededForReturnAddress = wordSize;
-
- m_offsetToSavingArea =
- (std::max(m_numArgs, NUMBER_OF_ARGUMENT_REGISTERS) - NUMBER_OF_ARGUMENT_REGISTERS) * wordSize;
-
- for (unsigned i = std::min(NUMBER_OF_ARGUMENT_REGISTERS, numArgs); i--;)
- m_argumentRegisters.set(GPRInfo::toArgumentRegister(i));
- m_callingConventionRegisters.merge(m_argumentRegisters);
- if (returnRegister != InvalidGPRReg)
- m_callingConventionRegisters.set(GPRInfo::returnValueGPR);
- m_callingConventionRegisters.filter(m_usedRegisters);
-
- unsigned numberOfCallingConventionRegisters =
- m_callingConventionRegisters.numberOfSetRegisters();
-
- size_t offsetToThunkSavingArea =
- m_offsetToSavingArea +
- numberOfCallingConventionRegisters * wordSize;
-
- m_stackBytesNeeded =
- offsetToThunkSavingArea +
- stackBytesNeededForReturnAddress +
- (m_usedRegisters.numberOfSetRegisters() - numberOfCallingConventionRegisters) * wordSize;
-
- m_stackBytesNeeded = (m_stackBytesNeeded + stackAlignmentBytes() - 1) & ~(stackAlignmentBytes() - 1);
-
- m_jit.subPtr(CCallHelpers::TrustedImm32(m_stackBytesNeeded), CCallHelpers::stackPointerRegister);
-
- m_thunkSaveSet = m_usedRegisters;
-
- // This relies on all calling convention registers also being temp registers.
- unsigned stackIndex = 0;
- for (unsigned i = GPRInfo::numberOfRegisters; i--;) {
- GPRReg reg = GPRInfo::toRegister(i);
- if (!m_callingConventionRegisters.get(reg))
- continue;
- m_jit.storePtr(reg, CCallHelpers::Address(CCallHelpers::stackPointerRegister, m_offsetToSavingArea + (stackIndex++) * wordSize));
- m_thunkSaveSet.clear(reg);
- }
-
- m_offset = offsetToThunkSavingArea;
- }
-
- ~CallContext()
- {
- if (m_returnRegister != InvalidGPRReg)
- m_jit.move(GPRInfo::returnValueGPR, m_returnRegister);
-
- unsigned stackIndex = 0;
- for (unsigned i = GPRInfo::numberOfRegisters; i--;) {
- GPRReg reg = GPRInfo::toRegister(i);
- if (!m_callingConventionRegisters.get(reg))
- continue;
- m_jit.loadPtr(CCallHelpers::Address(CCallHelpers::stackPointerRegister, m_offsetToSavingArea + (stackIndex++) * wordSize), reg);
- }
-
- m_jit.addPtr(CCallHelpers::TrustedImm32(m_stackBytesNeeded), CCallHelpers::stackPointerRegister);
- }
-
- RegisterSet usedRegisters() const
- {
- return m_thunkSaveSet;
- }
-
- ptrdiff_t offset() const
- {
- return m_offset;
- }
-
- SlowPathCallKey keyWithTarget(void* callTarget) const
- {
- return SlowPathCallKey(usedRegisters(), callTarget, m_argumentRegisters, offset());
- }
-
- MacroAssembler::Call makeCall(void* callTarget, MacroAssembler::JumpList* exceptionTarget)
- {
- MacroAssembler::Call result = m_jit.call();
- m_state.finalizer->slowPathCalls.append(SlowPathCall(
- result, keyWithTarget(callTarget)));
- if (exceptionTarget)
- exceptionTarget->append(m_jit.emitExceptionCheck());
- return result;
- }
-
-private:
- State& m_state;
- RegisterSet m_usedRegisters;
- RegisterSet m_argumentRegisters;
- RegisterSet m_callingConventionRegisters;
- CCallHelpers& m_jit;
- unsigned m_numArgs;
- GPRReg m_returnRegister;
- size_t m_offsetToSavingArea;
- size_t m_stackBytesNeeded;
- RegisterSet m_thunkSaveSet;
- ptrdiff_t m_offset;
-};
-
-} // anonymous namespace
-
-void storeCodeOrigin(State& state, CCallHelpers& jit, CodeOrigin codeOrigin)
-{
- if (!codeOrigin.isSet())
- return;
-
- unsigned index = state.jitCode->common.addCodeOrigin(codeOrigin);
- unsigned locationBits = CallFrame::Location::encodeAsCodeOriginIndex(index);
- jit.store32(
- CCallHelpers::TrustedImm32(locationBits),
- CCallHelpers::tagFor(static_cast<VirtualRegister>(JSStack::ArgumentCount)));
-}
-
-MacroAssembler::Call callOperation(
- State& state, const RegisterSet& usedRegisters, CCallHelpers& jit,
- CodeOrigin codeOrigin, MacroAssembler::JumpList* exceptionTarget,
- J_JITOperation_ESsiCI operation, GPRReg result, StructureStubInfo* stubInfo,
- GPRReg object, const UniquedStringImpl* uid)
-{
- storeCodeOrigin(state, jit, codeOrigin);
- CallContext context(state, usedRegisters, jit, 4, result);
- jit.setupArgumentsWithExecState(
- CCallHelpers::TrustedImmPtr(stubInfo), object, CCallHelpers::TrustedImmPtr(uid));
- return context.makeCall(bitwise_cast<void*>(operation), exceptionTarget);
-}
-
-MacroAssembler::Call callOperation(
- State& state, const RegisterSet& usedRegisters, CCallHelpers& jit,
- CodeOrigin codeOrigin, MacroAssembler::JumpList* exceptionTarget,
- J_JITOperation_ESsiJI operation, GPRReg result, StructureStubInfo* stubInfo,
- GPRReg object, UniquedStringImpl* uid)
-{
- storeCodeOrigin(state, jit, codeOrigin);
- CallContext context(state, usedRegisters, jit, 4, result);
- jit.setupArgumentsWithExecState(
- CCallHelpers::TrustedImmPtr(stubInfo), object,
- CCallHelpers::TrustedImmPtr(uid));
- return context.makeCall(bitwise_cast<void*>(operation), exceptionTarget);
-}
-
-MacroAssembler::Call callOperation(
- State& state, const RegisterSet& usedRegisters, CCallHelpers& jit,
- CodeOrigin codeOrigin, MacroAssembler::JumpList* exceptionTarget,
- V_JITOperation_ESsiJJI operation, StructureStubInfo* stubInfo, GPRReg value,
- GPRReg object, UniquedStringImpl* uid)
-{
- storeCodeOrigin(state, jit, codeOrigin);
- CallContext context(state, usedRegisters, jit, 5, InvalidGPRReg);
- jit.setupArgumentsWithExecState(
- CCallHelpers::TrustedImmPtr(stubInfo), value, object,
- CCallHelpers::TrustedImmPtr(uid));
- return context.makeCall(bitwise_cast<void*>(operation), exceptionTarget);
-}
-
-} } // namespace JSC::FTL
-
-#endif // ENABLE(FTL_JIT)
-