]> git.saurik.com Git - apple/javascriptcore.git/blobdiff - dfg/DFGVariableEvent.h
JavaScriptCore-7600.1.4.15.12.tar.gz
[apple/javascriptcore.git] / dfg / DFGVariableEvent.h
index 1605f79b867fff9b5771a95d51d5d56a1b913eac..9e76e558e68a4f82518541af828c5e74508ff800 100644 (file)
@@ -26,8 +26,6 @@
 #ifndef DFGVariableEvent_h
 #define DFGVariableEvent_h
 
 #ifndef DFGVariableEvent_h
 #define DFGVariableEvent_h
 
-#include <wtf/Platform.h>
-
 #if ENABLE(DFG_JIT)
 
 #include "DFGCommon.h"
 #if ENABLE(DFG_JIT)
 
 #include "DFGCommon.h"
@@ -61,8 +59,7 @@ enum VariableEventKind {
     // but that it has not been stored into that operand.
     MovHintEvent,
     
     // but that it has not been stored into that operand.
     MovHintEvent,
     
-    // A SetLocalEvent means that a node's value has actually been stored into the
-    // bytecode operand that it's associated with.
+    // A SetLocalEvent means that a node's value has been stored into the stack.
     SetLocalEvent,
     
     // Used to indicate an uninitialized VariableEvent. Don't use for other
     SetLocalEvent,
     
     // Used to indicate an uninitialized VariableEvent. Don't use for other
@@ -104,8 +101,8 @@ public:
         ASSERT(!(dataFormat & DataFormatJS));
 #endif
         VariableEvent event;
         ASSERT(!(dataFormat & DataFormatJS));
 #endif
         VariableEvent event;
-        event.m_id = id;
-        event.u.gpr = gpr;
+        event.m_which.id = id.bits();
+        event.m_representation.gpr = gpr;
         event.m_kind = kind;
         event.m_dataFormat = dataFormat;
         return event;
         event.m_kind = kind;
         event.m_dataFormat = dataFormat;
         return event;
@@ -116,9 +113,9 @@ public:
     {
         ASSERT(kind == BirthToFill || kind == Fill);
         VariableEvent event;
     {
         ASSERT(kind == BirthToFill || kind == Fill);
         VariableEvent event;
-        event.m_id = id;
-        event.u.pair.tagGPR = tagGPR;
-        event.u.pair.payloadGPR = payloadGPR;
+        event.m_which.id = id.bits();
+        event.m_representation.pair.tagGPR = tagGPR;
+        event.m_representation.pair.payloadGPR = payloadGPR;
         event.m_kind = kind;
         event.m_dataFormat = DataFormatJS;
         return event;
         event.m_kind = kind;
         event.m_dataFormat = DataFormatJS;
         return event;
@@ -129,8 +126,8 @@ public:
     {
         ASSERT(kind == BirthToFill || kind == Fill);
         VariableEvent event;
     {
         ASSERT(kind == BirthToFill || kind == Fill);
         VariableEvent event;
-        event.m_id = id;
-        event.u.fpr = fpr;
+        event.m_which.id = id.bits();
+        event.m_representation.fpr = fpr;
         event.m_kind = kind;
         event.m_dataFormat = DataFormatDouble;
         return event;
         event.m_kind = kind;
         event.m_dataFormat = DataFormatDouble;
         return event;
@@ -140,8 +137,8 @@ public:
     {
         ASSERT(kind == BirthToSpill || kind == Spill);
         VariableEvent event;
     {
         ASSERT(kind == BirthToSpill || kind == Spill);
         VariableEvent event;
-        event.m_id = id;
-        event.u.virtualReg = virtualRegister;
+        event.m_which.id = id.bits();
+        event.m_representation.virtualReg = virtualRegister.offset();
         event.m_kind = kind;
         event.m_dataFormat = format;
         return event;
         event.m_kind = kind;
         event.m_dataFormat = format;
         return event;
@@ -150,25 +147,27 @@ public:
     static VariableEvent death(MinifiedID id)
     {
         VariableEvent event;
     static VariableEvent death(MinifiedID id)
     {
         VariableEvent event;
-        event.m_id = id;
+        event.m_which.id = id.bits();
         event.m_kind = Death;
         return event;
     }
     
         event.m_kind = Death;
         return event;
     }
     
-    static VariableEvent setLocal(int operand, DataFormat format)
+    static VariableEvent setLocal(
+        VirtualRegister bytecodeReg, VirtualRegister machineReg, DataFormat format)
     {
         VariableEvent event;
     {
         VariableEvent event;
-        event.u.virtualReg = operand;
+        event.m_which.virtualReg = machineReg.offset();
+        event.m_representation.virtualReg = bytecodeReg.offset();
         event.m_kind = SetLocalEvent;
         event.m_dataFormat = format;
         return event;
     }
     
         event.m_kind = SetLocalEvent;
         event.m_dataFormat = format;
         return event;
     }
     
-    static VariableEvent movHint(MinifiedID id, int operand)
+    static VariableEvent movHint(MinifiedID id, VirtualRegister bytecodeReg)
     {
         VariableEvent event;
     {
         VariableEvent event;
-        event.m_id = id;
-        event.u.virtualReg = operand;
+        event.m_which.id = id.bits();
+        event.m_representation.virtualReg = bytecodeReg.offset();
         event.m_kind = MovHintEvent;
         return event;
     }
         event.m_kind = MovHintEvent;
         return event;
     }
@@ -183,7 +182,7 @@ public:
         ASSERT(m_kind == BirthToFill || m_kind == Fill
                || m_kind == BirthToSpill || m_kind == Spill
                || m_kind == Death || m_kind == MovHintEvent);
         ASSERT(m_kind == BirthToFill || m_kind == Fill
                || m_kind == BirthToSpill || m_kind == Spill
                || m_kind == Death || m_kind == MovHintEvent);
-        return m_id;
+        return MinifiedID::fromBits(m_which.id);
     }
     
     DataFormat dataFormat() const
     }
     
     DataFormat dataFormat() const
@@ -202,7 +201,7 @@ public:
 #if USE(JSVALUE32_64)
         ASSERT(!(m_dataFormat & DataFormatJS));
 #endif
 #if USE(JSVALUE32_64)
         ASSERT(!(m_dataFormat & DataFormatJS));
 #endif
-        return u.gpr;
+        return m_representation.gpr;
     }
     
 #if USE(JSVALUE32_64)
     }
     
 #if USE(JSVALUE32_64)
@@ -210,13 +209,13 @@ public:
     {
         ASSERT(m_kind == BirthToFill || m_kind == Fill);
         ASSERT(m_dataFormat & DataFormatJS);
     {
         ASSERT(m_kind == BirthToFill || m_kind == Fill);
         ASSERT(m_dataFormat & DataFormatJS);
-        return u.pair.tagGPR;
+        return m_representation.pair.tagGPR;
     }
     MacroAssembler::RegisterID payloadGPR() const
     {
         ASSERT(m_kind == BirthToFill || m_kind == Fill);
         ASSERT(m_dataFormat & DataFormatJS);
     }
     MacroAssembler::RegisterID payloadGPR() const
     {
         ASSERT(m_kind == BirthToFill || m_kind == Fill);
         ASSERT(m_dataFormat & DataFormatJS);
-        return u.pair.payloadGPR;
+        return m_representation.pair.payloadGPR;
     }
 #endif // USE(JSVALUE32_64)
     
     }
 #endif // USE(JSVALUE32_64)
     
@@ -224,22 +223,28 @@ public:
     {
         ASSERT(m_kind == BirthToFill || m_kind == Fill);
         ASSERT(m_dataFormat == DataFormatDouble);
     {
         ASSERT(m_kind == BirthToFill || m_kind == Fill);
         ASSERT(m_dataFormat == DataFormatDouble);
-        return u.fpr;
+        return m_representation.fpr;
     }
     
     }
     
-    VirtualRegister virtualRegister() const
+    VirtualRegister spillRegister() const
     {
         ASSERT(m_kind == BirthToSpill || m_kind == Spill);
     {
         ASSERT(m_kind == BirthToSpill || m_kind == Spill);
-        return static_cast<VirtualRegister>(u.virtualReg);
+        return VirtualRegister(m_representation.virtualReg);
     }
     
     }
     
-    int operand() const
+    VirtualRegister bytecodeRegister() const
     {
         ASSERT(m_kind == SetLocalEvent || m_kind == MovHintEvent);
     {
         ASSERT(m_kind == SetLocalEvent || m_kind == MovHintEvent);
-        return u.virtualReg;
+        return VirtualRegister(m_representation.virtualReg);
+    }
+    
+    VirtualRegister machineRegister() const
+    {
+        ASSERT(m_kind == SetLocalEvent);
+        return VirtualRegister(m_which.virtualReg);
     }
     
     }
     
-    const VariableRepresentation& variableRepresentation() const { return u; }
+    const VariableRepresentation& variableRepresentation() const { return m_representation; }
     
     void dump(PrintStream&) const;
     
     
     void dump(PrintStream&) const;
     
@@ -247,7 +252,10 @@ private:
     void dumpFillInfo(const char* name, PrintStream&) const;
     void dumpSpillInfo(const char* name, PrintStream&) const;
     
     void dumpFillInfo(const char* name, PrintStream&) const;
     void dumpSpillInfo(const char* name, PrintStream&) const;
     
-    MinifiedID m_id;
+    union {
+        int virtualReg;
+        uintptr_t id;
+    } m_which;
     
     // For BirthToFill, Fill:
     //   - The GPR or FPR, or a GPR pair.
     
     // For BirthToFill, Fill:
     //   - The GPR or FPR, or a GPR pair.
@@ -257,7 +265,7 @@ private:
     //   - The bytecode operand.
     // For Death:
     //   - Unused.
     //   - The bytecode operand.
     // For Death:
     //   - Unused.
-    VariableRepresentation u;
+    VariableRepresentation m_representation;
     
     int8_t m_kind;
     int8_t m_dataFormat;
     
     int8_t m_kind;
     int8_t m_dataFormat;