AssemblyHelpers should not have a VM field
[WebKit.git] / Source / JavaScriptCore / ftl / FTLState.h
index 8a0679b..9df4b3d 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2013-2015 Apple Inc. All rights reserved.
+ * Copyright (C) 2013-2016 Apple Inc. All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions
  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
  */
 
-#ifndef FTLState_h
-#define FTLState_h
+#pragma once
 
 #if ENABLE(FTL_JIT)
 
+#include "B3Procedure.h"
 #include "DFGCommon.h"
 #include "DFGGraph.h"
-#include "FTLAbbreviations.h"
+#include "FTLAbbreviatedTypes.h"
 #include "FTLGeneratedFunction.h"
-#include "FTLInlineCacheDescriptor.h"
 #include "FTLJITCode.h"
 #include "FTLJITFinalizer.h"
-#include "FTLJSCall.h"
-#include "FTLJSCallVarargs.h"
-#include "FTLStackMaps.h"
-#include "FTLState.h"
+#include <wtf/Box.h>
 #include <wtf/Noncopyable.h>
 
-namespace JSC { namespace FTL {
+namespace JSC {
+
+namespace B3 {
+class PatchpointValue;
+class StackSlot;
+} // namespace B3
+
+namespace FTL {
+
+class PatchpointExceptionHandle;
 
 inline bool verboseCompilationEnabled()
 {
     return DFG::verboseCompilationEnabled(DFG::FTLMode);
 }
 
-inline bool shouldShowDisassembly()
+inline bool shouldDumpDisassembly()
 {
-    return DFG::shouldShowDisassembly(DFG::FTLMode);
+    return DFG::shouldDumpDisassembly(DFG::FTLMode);
 }
 
 class State {
@@ -59,45 +64,24 @@ class State {
 public:
     State(DFG::Graph& graph);
     ~State();
+
+    VM& vm() { return graph.m_vm; }
     
     // None of these things is owned by State. It is the responsibility of
     // FTL phases to properly manage the lifecycle of the module and function.
     DFG::Graph& graph;
-    LContext context;
-    LModule module;
-    LValue function;
-    bool allocationFailed { false }; // Throw out the compilation once LLVM returns.
+    std::unique_ptr<B3::Procedure> proc;
+    bool allocationFailed { false }; // Throw out the compilation once B3 returns.
     RefPtr<JITCode> jitCode;
     GeneratedFunction generatedFunction;
     JITFinalizer* finalizer;
-    unsigned handleStackOverflowExceptionStackmapID;
-    unsigned handleExceptionStackmapID;
-    unsigned capturedStackmapID;
-    unsigned varargsSpillSlotsStackmapID;
-    SegmentedVector<GetByIdDescriptor> getByIds;
-    SegmentedVector<PutByIdDescriptor> putByIds;
-    SegmentedVector<CheckInDescriptor> checkIns;
-    Vector<JSCall> jsCalls;
-    Vector<JSCallVarargs> jsCallVarargses;
-    Vector<CString> codeSectionNames;
-    Vector<CString> dataSectionNames;
-    void* unwindDataSection;
-    size_t unwindDataSectionSize;
-    RefPtr<DataSection> stackmapsSection;
-    
-    void dumpState(const char* when);
-    void dumpState(LModule, const char* when);
-
-    HashSet<CString> nativeLoadedLibraries;
-
-#if ENABLE(FTL_NATIVE_CALL_INLINING)
-    HashMap<CString, CString> symbolTable;
-#endif
+    // Top-level exception handler. Jump here if you know that you have to genericUnwind() and there
+    // are no applicable catch blocks anywhere in the Graph.
+    RefPtr<PatchpointExceptionHandle> defaultExceptionHandle;
+    Box<CCallHelpers::Label> exceptionHandler { Box<CCallHelpers::Label>::create() };
+    B3::StackSlot* capturedValue { nullptr };
 };
 
 } } // namespace JSC::FTL
 
 #endif // ENABLE(FTL_JIT)
-
-#endif // FTLState_h
-