/* * Copyright (C) 2013-2021 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. */ #pragma once #if ENABLE(DFG_JIT) #include "BaselineJITCode.h" #include "CallLinkInfo.h" #include "CodeBlockJettisoningWatchpoint.h" #include "DFGAdaptiveInferredPropertyValueWatchpoint.h" #include "DFGAdaptiveStructureWatchpoint.h" #include "DFGCodeOriginPool.h" #include "DFGJumpReplacement.h" #include "DFGOSREntry.h" #include "InlineCallFrameSet.h" #include "JITMathIC.h" #include "JSCast.h" #include "PCToCodeOriginMap.h" #include "ProfilerCompilation.h" #include "RecordedStatuses.h" #include "StructureStubInfo.h" #include "YarrJIT.h" #include #include namespace JSC { class CodeBlock; class Identifier; class TrackedReferences; namespace DFG { struct Node; class Plan; // CommonData holds the set of data that both DFG and FTL code blocks need to know // about themselves. struct WeakReferenceTransition { WeakReferenceTransition() { } WeakReferenceTransition(VM& vm, JSCell* owner, JSCell* codeOrigin, JSCell* from, JSCell* to) : m_from(vm, owner, from) , m_to(vm, owner, to) { if (!!codeOrigin) m_codeOrigin.set(vm, owner, codeOrigin); } WriteBarrier m_codeOrigin; WriteBarrier m_from; WriteBarrier m_to; }; class CommonData : public MathICHolder { WTF_MAKE_NONCOPYABLE(CommonData); public: CommonData() : codeOrigins(CodeOriginPool::create()) { } ~CommonData(); void shrinkToFit(); bool invalidate(); // Returns true if we did invalidate, or false if the code block was already invalidated. bool hasInstalledVMTrapsBreakpoints() const { return isStillValid && hasVMTrapsBreakpointsInstalled; } void installVMTrapBreakpoints(CodeBlock* owner); bool isVMTrapBreakpoint(void* address); CatchEntrypointData* catchOSREntryDataForBytecodeIndex(BytecodeIndex bytecodeIndex) { return tryBinarySearch( m_catchEntrypoints, m_catchEntrypoints.size(), bytecodeIndex, [] (const CatchEntrypointData* item) { return item->bytecodeIndex; }); } void finalizeCatchEntrypoints(Vector&&); unsigned requiredRegisterCountForExecutionAndExit() const { return std::max(frameRegisterCount, requiredRegisterCountForExit); } void validateReferences(const TrackedReferences&); static ptrdiff_t frameRegisterCountOffset() { return OBJECT_OFFSETOF(CommonData, frameRegisterCount); } void clearWatchpoints(); OptimizingCallLinkInfo* addCallLinkInfo(CodeOrigin codeOrigin) { return m_callLinkInfos.add(codeOrigin); } RefPtr inlineCallFrames; Ref codeOrigins; FixedVector m_dfgIdentifiers; FixedVector m_transitions; FixedVector> m_weakReferences; FixedVector m_weakStructureReferences; FixedVector m_catchEntrypoints; FixedVector m_watchpoints; FixedVector m_adaptiveStructureWatchpoints; FixedVector m_adaptiveInferredPropertyValueWatchpoints; std::unique_ptr m_pcToCodeOriginMap; RecordedStatuses recordedStatuses; Vector m_jumpReplacements; Bag m_stubInfos; Bag m_callLinkInfos; Yarr::YarrBoyerMoyerData m_boyerMooreData; ScratchBuffer* catchOSREntryBuffer; RefPtr compilation; bool isStillValid { true }; bool hasVMTrapsBreakpointsInstalled { false }; #if USE(JSVALUE32_64) std::unique_ptr> doubleConstants; #endif unsigned frameRegisterCount { std::numeric_limits::max() }; unsigned requiredRegisterCountForExit { std::numeric_limits::max() }; }; CodeBlock* codeBlockForVMTrapPC(void* pc); } } // namespace JSC::DFG #endif // ENABLE(DFG_JIT)