diff options
Diffstat (limited to 'Source/JavaScriptCore/bytecode/VirtualRegister.h')
-rw-r--r-- | Source/JavaScriptCore/bytecode/VirtualRegister.h | 102 |
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 |