|
|
@ -200,6 +200,14 @@ enum class IMinMaxExchange : u64 { |
|
|
XHi = 3, |
|
|
XHi = 3, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
enum class XmadMode : u64 { |
|
|
|
|
|
None = 0, |
|
|
|
|
|
CLo = 1, |
|
|
|
|
|
CHi = 2, |
|
|
|
|
|
CSfu = 3, |
|
|
|
|
|
CBcc = 4, |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
enum class FlowCondition : u64 { |
|
|
enum class FlowCondition : u64 { |
|
|
Always = 0xF, |
|
|
Always = 0xF, |
|
|
Fcsm_Tr = 0x1C, // TODO(bunnei): What is this used for? |
|
|
Fcsm_Tr = 0x1C, // TODO(bunnei): What is this used for? |
|
|
@ -456,6 +464,18 @@ union Instruction { |
|
|
} |
|
|
} |
|
|
} bra; |
|
|
} bra; |
|
|
|
|
|
|
|
|
|
|
|
union { |
|
|
|
|
|
BitField<20, 16, u64> imm20_16; |
|
|
|
|
|
BitField<36, 1, u64> product_shift_left; |
|
|
|
|
|
BitField<37, 1, u64> merge_37; |
|
|
|
|
|
BitField<48, 1, u64> sign_a; |
|
|
|
|
|
BitField<49, 1, u64> sign_b; |
|
|
|
|
|
BitField<50, 3, XmadMode> mode; |
|
|
|
|
|
BitField<52, 1, u64> high_b; |
|
|
|
|
|
BitField<53, 1, u64> high_a; |
|
|
|
|
|
BitField<56, 1, u64> merge_56; |
|
|
|
|
|
} xmad; |
|
|
|
|
|
|
|
|
union { |
|
|
union { |
|
|
BitField<20, 14, u64> offset; |
|
|
BitField<20, 14, u64> offset; |
|
|
BitField<34, 5, u64> index; |
|
|
BitField<34, 5, u64> index; |
|
|
@ -593,6 +613,7 @@ public: |
|
|
IntegerSetPredicate, |
|
|
IntegerSetPredicate, |
|
|
PredicateSetPredicate, |
|
|
PredicateSetPredicate, |
|
|
Conversion, |
|
|
Conversion, |
|
|
|
|
|
Xmad, |
|
|
Unknown, |
|
|
Unknown, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
@ -782,10 +803,10 @@ private: |
|
|
INST("010010110101----", Id::ISET_C, Type::IntegerSet, "ISET_C"), |
|
|
INST("010010110101----", Id::ISET_C, Type::IntegerSet, "ISET_C"), |
|
|
INST("0011011-0101----", Id::ISET_IMM, Type::IntegerSet, "ISET_IMM"), |
|
|
INST("0011011-0101----", Id::ISET_IMM, Type::IntegerSet, "ISET_IMM"), |
|
|
INST("0101000010010---", Id::PSETP, Type::PredicateSetPredicate, "PSETP"), |
|
|
INST("0101000010010---", Id::PSETP, Type::PredicateSetPredicate, "PSETP"), |
|
|
INST("0011011-00------", Id::XMAD_IMM, Type::Arithmetic, "XMAD_IMM"), |
|
|
|
|
|
INST("0100111---------", Id::XMAD_CR, Type::Arithmetic, "XMAD_CR"), |
|
|
|
|
|
INST("010100010-------", Id::XMAD_RC, Type::Arithmetic, "XMAD_RC"), |
|
|
|
|
|
INST("0101101100------", Id::XMAD_RR, Type::Arithmetic, "XMAD_RR"), |
|
|
|
|
|
|
|
|
INST("0011011-00------", Id::XMAD_IMM, Type::Xmad, "XMAD_IMM"), |
|
|
|
|
|
INST("0100111---------", Id::XMAD_CR, Type::Xmad, "XMAD_CR"), |
|
|
|
|
|
INST("010100010-------", Id::XMAD_RC, Type::Xmad, "XMAD_RC"), |
|
|
|
|
|
INST("0101101100------", Id::XMAD_RR, Type::Xmad, "XMAD_RR"), |
|
|
}; |
|
|
}; |
|
|
#undef INST |
|
|
#undef INST |
|
|
std::stable_sort(table.begin(), table.end(), [](const auto& a, const auto& b) { |
|
|
std::stable_sort(table.begin(), table.end(), [](const auto& a, const auto& b) { |
|
|
|