#include "config.h"
#include "B3AtomicValue.h"
#if ENABLE(B3_JIT)
namespace JSC { namespace B3 {
AtomicValue::~AtomicValue()
{
}
void AtomicValue::dumpMeta(CommaPrinter& comma, PrintStream& out) const
{
out.print(comma, "width = ", m_width);
MemoryValue::dumpMeta(comma, out);
}
Value* AtomicValue::cloneImpl() const
{
return new AtomicValue(*this);
}
AtomicValue::AtomicValue(AtomicValue::AtomicValueRMW, Kind kind, Origin origin, Width width, Value* operand, Value* pointer, MemoryValue::OffsetType offset, HeapRange range, HeapRange fenceRange)
: MemoryValue(CheckedOpcode, kind, operand->type(), origin, offset, range, fenceRange, operand, pointer)
, m_width(width)
{
ASSERT(bestType(GP, accessWidth()) == accessType());
switch (kind.opcode()) {
case AtomicXchgAdd:
case AtomicXchgAnd:
case AtomicXchgOr:
case AtomicXchgSub:
case AtomicXchgXor:
case AtomicXchg:
break;
default:
ASSERT_NOT_REACHED();
}
}
AtomicValue::AtomicValue(AtomicValue::AtomicValueCAS, Kind kind, Origin origin, Width width, Value* expectedValue, Value* newValue, Value* pointer, MemoryValue::OffsetType offset, HeapRange range, HeapRange fenceRange)
: MemoryValue(CheckedOpcode, kind, kind.opcode() == AtomicWeakCAS ? Int32 : expectedValue->type(), origin, offset, range, fenceRange, expectedValue, newValue, pointer)
, m_width(width)
{
ASSERT(bestType(GP, accessWidth()) == accessType());
switch (kind.opcode()) {
case AtomicWeakCAS:
case AtomicStrongCAS:
break;
default:
ASSERT_NOT_REACHED();
}
}
} }
#endif // ENABLE(B3_JIT)