Arm64Emitter: Add ArithOption with ExtendSpecifier

ARM64 can do perform various types of sign and zero extension on a
register value before using it. The Arm64Emitter already had support for
this, but it was kinda hidden away.

This commit exposes the functionality by making the ExtendSpecifier enum
available everywhere and adding a new ArithOption constructor.
This commit is contained in:
Bram Speeckaert 2022-11-01 12:15:56 +01:00
parent 82f22cdfa1
commit ae6ce1df48

View File

@ -309,6 +309,18 @@ enum class ShiftType
ROR = 3, ROR = 3,
}; };
enum class ExtendSpecifier
{
UXTB = 0x0,
UXTH = 0x1,
UXTW = 0x2, /* Also LSL on 32bit width */
UXTX = 0x3, /* Also LSL on 64bit width */
SXTB = 0x4,
SXTH = 0x5,
SXTW = 0x6,
SXTX = 0x7,
};
enum class IndexType enum class IndexType
{ {
Unsigned, Unsigned,
@ -405,18 +417,6 @@ private:
Width64Bit, Width64Bit,
}; };
enum class ExtendSpecifier
{
UXTB = 0x0,
UXTH = 0x1,
UXTW = 0x2, /* Also LSL on 32bit width */
UXTX = 0x3, /* Also LSL on 64bit width */
SXTB = 0x4,
SXTH = 0x5,
SXTW = 0x6,
SXTX = 0x7,
};
enum class TypeSpecifier enum class TypeSpecifier
{ {
ExtendedReg, ExtendedReg,
@ -463,6 +463,15 @@ public:
} }
m_shifttype = ShiftType::LSL; m_shifttype = ShiftType::LSL;
} }
ArithOption(ARM64Reg Rd, ExtendSpecifier extend_type, u32 shift = 0)
{
m_destReg = Rd;
m_width = Is64Bit(Rd) ? WidthSpecifier::Width64Bit : WidthSpecifier::Width32Bit;
m_extend = extend_type;
m_type = TypeSpecifier::ExtendedReg;
m_shifttype = ShiftType::LSL;
m_shift = shift;
}
ArithOption(ARM64Reg Rd, ShiftType shift_type, u32 shift) ArithOption(ARM64Reg Rd, ShiftType shift_type, u32 shift)
{ {
m_destReg = Rd; m_destReg = Rd;