public final class MIR_CompareExchange extends ArchInstructionFormat
Instruction
contains
an explanation of the role of InstructionFormats in the
opt compiler's IR.MIR_BinaryAcc_format, MIR_BinaryAcc_traits, MIR_Branch_format, MIR_Branch_traits, MIR_CacheOp_format, MIR_CacheOp_traits, MIR_Call_format, MIR_Call_traits, MIR_CaseLabel_format, MIR_CaseLabel_traits, MIR_Compare_format, MIR_Compare_traits, MIR_CompareExchange_format, MIR_CompareExchange_traits, MIR_CompareExchange8B_format, MIR_CompareExchange8B_traits, MIR_CondBranch_format, MIR_CondBranch_traits, MIR_CondBranch2_format, MIR_CondBranch2_traits, MIR_CondMove_format, MIR_CondMove_traits, MIR_ConvertDW2QW_format, MIR_ConvertDW2QW_traits, MIR_Divide_format, MIR_Divide_traits, MIR_DoubleShift_format, MIR_DoubleShift_traits, MIR_Empty_format, MIR_Empty_traits, MIR_FSave_format, MIR_FSave_traits, MIR_Lea_format, MIR_Lea_traits, MIR_LowTableSwitch_format, MIR_LowTableSwitch_traits, MIR_Move_format, MIR_Move_traits, MIR_Multiply_format, MIR_Multiply_traits, MIR_Nullary_format, MIR_Nullary_traits, MIR_RDTSC_format, MIR_RDTSC_traits, MIR_Return_format, MIR_Return_traits, MIR_Set_format, MIR_Set_traits, MIR_Test_format, MIR_Test_traits, MIR_Trap_format, MIR_Trap_traits, MIR_TrapIf_format, MIR_TrapIf_traits, MIR_Unary_format, MIR_Unary_traits, MIR_UnaryAcc_format, MIR_UnaryAcc_traits, MIR_UnaryNoRes_format, MIR_UnaryNoRes_traits, MIR_XChng_format, MIR_XChng_traits
ALoad_format, ALoad_traits, ARCH_INDEPENDENT_INSTR_FORMAT_END_format, AStore_format, AStore_traits, Athrow_format, Athrow_traits, Attempt_format, Attempt_traits, BBend_format, BBend_traits, Binary_format, Binary_traits, BooleanCmp_format, BooleanCmp_traits, BoundsCheck_format, BoundsCheck_traits, CacheOp_format, CacheOp_traits, Call_format, Call_traits, CondMove_format, CondMove_traits, Empty_format, Empty_traits, GetField_format, GetField_traits, GetStatic_format, GetStatic_traits, Goto_format, Goto_traits, GuardedBinary_format, GuardedBinary_traits, GuardedSet_format, GuardedSet_traits, GuardedUnary_format, GuardedUnary_traits, IfCmp_format, IfCmp_traits, IfCmp2_format, IfCmp2_traits, InlineGuard_format, InlineGuard_traits, InstanceOf_format, InstanceOf_traits, InstrumentedCounter_format, InstrumentedCounter_traits, Label_format, Label_traits, Load_format, Load_traits, LookupSwitch_format, LookupSwitch_traits, LowTableSwitch_format, LowTableSwitch_traits, MIN_OPERAND_ARRAY_LENGTH, MonitorOp_format, MonitorOp_traits, Move_format, Move_traits, Multianewarray_format, Multianewarray_traits, New_format, New_traits, NewArray_format, NewArray_traits, Nullary_format, Nullary_traits, NullCheck_format, NullCheck_traits, OsrBarrier_format, OsrBarrier_traits, OsrPoint_format, OsrPoint_traits, Phi_format, Phi_traits, Prepare_format, Prepare_traits, Prologue_format, Prologue_traits, PutField_format, PutField_traits, PutStatic_format, PutStatic_traits, Return_format, Return_traits, Store_format, Store_traits, StoreCheck_format, StoreCheck_traits, TableSwitch_format, TableSwitch_traits, Trap_format, Trap_traits, TrapIf_format, TrapIf_traits, TypeCheck_format, TypeCheck_traits, Unary_format, Unary_traits, Unassigned_format, ZeroCheck_format, ZeroCheck_traits
Constructor and Description |
---|
MIR_CompareExchange() |
Modifier and Type | Method and Description |
---|---|
static boolean |
conforms(Instruction i)
InstructionFormat identification method for MIR_CompareExchange.
|
static boolean |
conforms(Operator o)
InstructionFormat identification method for MIR_CompareExchange.
|
static Instruction |
create(Operator o,
RegisterOperand OldValue,
MemoryOperand MemAddr,
RegisterOperand NewValue)
Create an instruction of the MIR_CompareExchange instruction format.
|
static MemoryOperand |
getClearMemAddr(Instruction i)
Get the operand called MemAddr from the argument
instruction clearing its instruction pointer.
|
static RegisterOperand |
getClearNewValue(Instruction i)
Get the operand called NewValue from the argument
instruction clearing its instruction pointer.
|
static RegisterOperand |
getClearOldValue(Instruction i)
Get the operand called OldValue from the argument
instruction clearing its instruction pointer.
|
static MemoryOperand |
getMemAddr(Instruction i)
Get the operand called MemAddr from the
argument instruction.
|
static RegisterOperand |
getNewValue(Instruction i)
Get the operand called NewValue from the
argument instruction.
|
static RegisterOperand |
getOldValue(Instruction i)
Get the operand called OldValue from the
argument instruction.
|
static boolean |
hasMemAddr(Instruction i)
Does the argument instruction have a non-null
operand named MemAddr?
|
static boolean |
hasNewValue(Instruction i)
Does the argument instruction have a non-null
operand named NewValue?
|
static boolean |
hasOldValue(Instruction i)
Does the argument instruction have a non-null
operand named OldValue?
|
static int |
indexOfMemAddr(Instruction i)
Return the index of the operand called MemAddr
in the argument instruction.
|
static int |
indexOfNewValue(Instruction i)
Return the index of the operand called NewValue
in the argument instruction.
|
static int |
indexOfOldValue(Instruction i)
Return the index of the operand called OldValue
in the argument instruction.
|
static Instruction |
mutate(Instruction i,
Operator o,
RegisterOperand OldValue,
MemoryOperand MemAddr,
RegisterOperand NewValue)
Mutate the argument instruction into an instruction of the
MIR_CompareExchange instruction format having the specified
operator and operands.
|
static void |
setMemAddr(Instruction i,
MemoryOperand MemAddr)
Set the operand called MemAddr in the argument
instruction to the argument operand.
|
static void |
setNewValue(Instruction i,
RegisterOperand NewValue)
Set the operand called NewValue in the argument
instruction to the argument operand.
|
static void |
setOldValue(Instruction i,
RegisterOperand OldValue)
Set the operand called OldValue in the argument
instruction to the argument operand.
|
fail, fail
public MIR_CompareExchange()
public static boolean conforms(Instruction i)
i
- an instructiontrue
if the InstructionFormat of the argument
instruction is MIR_CompareExchange or false
if it is not.public static boolean conforms(Operator o)
o
- an instructiontrue
if the InstructionFormat of the argument
operator is MIR_CompareExchange or false
if it is not.public static RegisterOperand getOldValue(Instruction i)
i
- the instruction to fetch the operand frompublic static RegisterOperand getClearOldValue(Instruction i)
i
- the instruction to fetch the operand frompublic static void setOldValue(Instruction i, RegisterOperand OldValue)
i
- the instruction in which to store the operandOldValue
- the operand to storepublic static int indexOfOldValue(Instruction i)
i
- the instruction to access.public static boolean hasOldValue(Instruction i)
i
- the instruction to access.true
if the instruction has an non-null
operand named OldValue or false
if it does not.public static MemoryOperand getMemAddr(Instruction i)
i
- the instruction to fetch the operand frompublic static MemoryOperand getClearMemAddr(Instruction i)
i
- the instruction to fetch the operand frompublic static void setMemAddr(Instruction i, MemoryOperand MemAddr)
i
- the instruction in which to store the operandMemAddr
- the operand to storepublic static int indexOfMemAddr(Instruction i)
i
- the instruction to access.public static boolean hasMemAddr(Instruction i)
i
- the instruction to access.true
if the instruction has an non-null
operand named MemAddr or false
if it does not.public static RegisterOperand getNewValue(Instruction i)
i
- the instruction to fetch the operand frompublic static RegisterOperand getClearNewValue(Instruction i)
i
- the instruction to fetch the operand frompublic static void setNewValue(Instruction i, RegisterOperand NewValue)
i
- the instruction in which to store the operandNewValue
- the operand to storepublic static int indexOfNewValue(Instruction i)
i
- the instruction to access.public static boolean hasNewValue(Instruction i)
i
- the instruction to access.true
if the instruction has an non-null
operand named NewValue or false
if it does not.public static Instruction create(Operator o, RegisterOperand OldValue, MemoryOperand MemAddr, RegisterOperand NewValue)
o
- the instruction's operatorOldValue
- the instruction's OldValue operandMemAddr
- the instruction's MemAddr operandNewValue
- the instruction's NewValue operandpublic static Instruction mutate(Instruction i, Operator o, RegisterOperand OldValue, MemoryOperand MemAddr, RegisterOperand NewValue)
i
- the instruction to mutateo
- the instruction's operatorOldValue
- the instruction's OldValue operandMemAddr
- the instruction's MemAddr operandNewValue
- the instruction's NewValue operand