diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-10-15 09:45:50 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-10-15 09:45:50 +0000 |
commit | e15dd966d523731101f70ccf768bba12435a0208 (patch) | |
tree | ae9cb828a24ded2585a41af3f21411523b47897d /Source/JavaScriptCore/ftl/FTLJITCode.cpp | |
download | WebKitGtk-tarball-e15dd966d523731101f70ccf768bba12435a0208.tar.gz |
webkitgtk-2.10.2webkitgtk-2.10.2
Diffstat (limited to 'Source/JavaScriptCore/ftl/FTLJITCode.cpp')
-rw-r--r-- | Source/JavaScriptCore/ftl/FTLJITCode.cpp | 150 |
1 files changed, 150 insertions, 0 deletions
diff --git a/Source/JavaScriptCore/ftl/FTLJITCode.cpp b/Source/JavaScriptCore/ftl/FTLJITCode.cpp new file mode 100644 index 000000000..66d38de6c --- /dev/null +++ b/Source/JavaScriptCore/ftl/FTLJITCode.cpp @@ -0,0 +1,150 @@ +/* + * Copyright (C) 2013, 2015 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 "FTLJITCode.h" + +#if ENABLE(FTL_JIT) + +#include "FTLState.h" + +namespace JSC { namespace FTL { + +JITCode::JITCode() + : JSC::JITCode(FTLJIT) +{ +} + +JITCode::~JITCode() +{ + if (FTL::shouldShowDisassembly()) { + dataLog("Destroying FTL JIT code at "); + CommaPrinter comma; + for (auto& handle : m_handles) + dataLog(comma, pointerDump(handle.get())); + dataLog(comma, pointerDump(m_arityCheckEntrypoint.executableMemory())); + dataLog(comma, pointerDump(m_exitThunks.executableMemory())); + dataLog("\n"); + } +} + +void JITCode::initializeExitThunks(CodeRef exitThunks) +{ + m_exitThunks = exitThunks; +} + +void JITCode::addHandle(PassRefPtr<ExecutableMemoryHandle> handle) +{ + m_handles.append(handle); +} + +void JITCode::addDataSection(PassRefPtr<DataSection> dataSection) +{ + m_dataSections.append(dataSection); +} + +void JITCode::initializeArityCheckEntrypoint(CodeRef entrypoint) +{ + m_arityCheckEntrypoint = entrypoint; +} + +void JITCode::initializeAddressForCall(CodePtr address) +{ + m_addressForCall = address; +} + +JITCode::CodePtr JITCode::addressForCall(VM&, ExecutableBase*, ArityCheckMode arityCheck, RegisterPreservationMode) +{ + switch (arityCheck) { + case ArityCheckNotRequired: + return m_addressForCall; + case MustCheckArity: + return m_arityCheckEntrypoint.code(); + } + RELEASE_ASSERT_NOT_REACHED(); + return CodePtr(); +} + +void* JITCode::executableAddressAtOffset(size_t offset) +{ + return reinterpret_cast<char*>(m_addressForCall.executableAddress()) + offset; +} + +void* JITCode::dataAddressAtOffset(size_t) +{ + // We can't patch FTL code, yet. Even if we did, it's not clear that we would do so + // through this API. + RELEASE_ASSERT_NOT_REACHED(); + return 0; +} + +unsigned JITCode::offsetOf(void*) +{ + // We currently don't have visibility into the FTL code. + RELEASE_ASSERT_NOT_REACHED(); + return 0; +} + +size_t JITCode::size() +{ + // We don't know the size of FTL code, yet. Make a wild guess. This is mostly used for + // GC load estimates. + return 1000; +} + +bool JITCode::contains(void*) +{ + // We have no idea what addresses the FTL code contains, yet. + RELEASE_ASSERT_NOT_REACHED(); + return false; +} + +JITCode::CodePtr JITCode::exitThunks() +{ + return m_exitThunks.code(); +} + +JITCode* JITCode::ftl() +{ + return this; +} + +DFG::CommonData* JITCode::dfgCommon() +{ + return &common; +} + +void JITCode::validateReferences(const TrackedReferences& trackedReferences) +{ + common.validateReferences(trackedReferences); + + for (OSRExit& exit : osrExit) + exit.validateReferences(trackedReferences); +} + +} } // namespace JSC::FTL + +#endif // ENABLE(FTL_JIT) + |