summaryrefslogtreecommitdiff
path: root/Source/JavaScriptCore/bytecode/VirtualRegister.h
diff options
context:
space:
mode:
Diffstat (limited to 'Source/JavaScriptCore/bytecode/VirtualRegister.h')
-rw-r--r--Source/JavaScriptCore/bytecode/VirtualRegister.h102
1 files changed, 91 insertions, 11 deletions
diff --git a/Source/JavaScriptCore/bytecode/VirtualRegister.h b/Source/JavaScriptCore/bytecode/VirtualRegister.h
index a6dc8d565..613088ef6 100644
--- a/Source/JavaScriptCore/bytecode/VirtualRegister.h
+++ b/Source/JavaScriptCore/bytecode/VirtualRegister.h
@@ -1,5 +1,5 @@
/*
- * Copyright (C) 2011 Apple Inc. All rights reserved.
+ * Copyright (C) 2011, 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
@@ -26,25 +26,105 @@
#ifndef VirtualRegister_h
#define VirtualRegister_h
-#include <wtf/Platform.h>
+#include "CallFrame.h"
+
#include <wtf/PrintStream.h>
namespace JSC {
-// Type for a virtual register number (spill location).
-// Using an enum to make this type-checked at compile time, to avert programmer errors.
-enum VirtualRegister { InvalidVirtualRegister = -1 };
-COMPILE_ASSERT(sizeof(VirtualRegister) == sizeof(int), VirtualRegister_is_32bit);
+inline bool operandIsLocal(int operand)
+{
+ return operand < 0;
+}
-} // namespace JSC
+inline bool operandIsArgument(int operand)
+{
+ return operand >= 0;
+}
+
+
+class VirtualRegister {
+public:
+ friend VirtualRegister virtualRegisterForLocal(int);
+ friend VirtualRegister virtualRegisterForArgument(int, int);
+
+ VirtualRegister()
+ : m_virtualRegister(s_invalidVirtualRegister)
+ { }
+
+ explicit VirtualRegister(int virtualRegister)
+ : m_virtualRegister(virtualRegister)
+ { }
-namespace WTF {
+ bool isValid() const { return (m_virtualRegister != s_invalidVirtualRegister); }
+ bool isLocal() const { return operandIsLocal(m_virtualRegister); }
+ bool isArgument() const { return operandIsArgument(m_virtualRegister); }
+ bool isHeader() const { return m_virtualRegister >= 0 && m_virtualRegister < JSStack::ThisArgument; }
+ bool isConstant() const { return m_virtualRegister >= s_firstConstantRegisterIndex; }
+ int toLocal() const { ASSERT(isLocal()); return operandToLocal(m_virtualRegister); }
+ int toArgument() const { ASSERT(isArgument()); return operandToArgument(m_virtualRegister); }
+ int toConstantIndex() const { ASSERT(isConstant()); return m_virtualRegister - s_firstConstantRegisterIndex; }
+ int offset() const { return m_virtualRegister; }
+ int offsetInBytes() const { return m_virtualRegister * sizeof(Register); }
-inline void printInternal(PrintStream& out, JSC::VirtualRegister value)
+ bool operator==(VirtualRegister other) const { return m_virtualRegister == other.m_virtualRegister; }
+ bool operator!=(VirtualRegister other) const { return m_virtualRegister != other.m_virtualRegister; }
+ bool operator<(VirtualRegister other) const { return m_virtualRegister < other.m_virtualRegister; }
+ bool operator>(VirtualRegister other) const { return m_virtualRegister > other.m_virtualRegister; }
+ bool operator<=(VirtualRegister other) const { return m_virtualRegister <= other.m_virtualRegister; }
+ bool operator>=(VirtualRegister other) const { return m_virtualRegister >= other.m_virtualRegister; }
+
+ VirtualRegister operator+(int value) const
+ {
+ return VirtualRegister(offset() + value);
+ }
+ VirtualRegister operator-(int value) const
+ {
+ return VirtualRegister(offset() - value);
+ }
+ VirtualRegister operator+(VirtualRegister value) const
+ {
+ return VirtualRegister(offset() + value.offset());
+ }
+ VirtualRegister operator-(VirtualRegister value) const
+ {
+ return VirtualRegister(offset() - value.offset());
+ }
+ VirtualRegister& operator+=(int value)
+ {
+ return *this = *this + value;
+ }
+ VirtualRegister& operator-=(int value)
+ {
+ return *this = *this - value;
+ }
+
+ void dump(PrintStream& out) const;
+
+private:
+ static const int s_invalidVirtualRegister = 0x3fffffff;
+ static const int s_firstConstantRegisterIndex = 0x40000000;
+
+ static int localToOperand(int local) { return -1 - local; }
+ static int operandToLocal(int operand) { return -1 - operand; }
+ static int operandToArgument(int operand) { return operand - CallFrame::thisArgumentOffset(); }
+ static int argumentToOperand(int argument) { return argument + CallFrame::thisArgumentOffset(); }
+
+ int m_virtualRegister;
+};
+
+COMPILE_ASSERT(sizeof(VirtualRegister) == sizeof(int), VirtualRegister_is_32bit);
+
+inline VirtualRegister virtualRegisterForLocal(int local)
{
- out.print(static_cast<int>(value));
+ return VirtualRegister(VirtualRegister::localToOperand(local));
}
-} // namespace WTF
+inline VirtualRegister virtualRegisterForArgument(int argument, int offset = 0)
+{
+ return VirtualRegister(VirtualRegister::argumentToOperand(argument) + offset);
+}
+
+} // namespace JSC
#endif // VirtualRegister_h