Cosmos/source/Tests/MathTest/Lost/JIT/AMD64/Enumerations.cs
2008-03-21 13:11:43 +00:00

74 lines
2.2 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Lost.JIT.AMD64
{
[Flags]
enum Register: byte
{
Legacy = 0x07,
AX = 0x00,
BX = 0x03,
CX = 0x01,
DX = 0x02,
SP = 0x04,
BP = 0x05,
SI = 0x06,
DI = 0x07,
R8 = 0x08,
R9 = 0x09,
R10 = 0x0A,
R11 = 0x0B,
R12 = 0x0C,
R13 = 0x0D,
R14 = 0x0E,
R15 = 0x0F,
}
[Flags]
public enum Rex : byte
{
None = 0x40,
/// <summary>
/// Use 64-bit operand size
/// </summary>
/// <remarks>
/// Setting the REX.W bit to 1 specifies a 64-bit operand size. Like the
/// existing 66h operand-size prefix, the REX 64-bit operand-size override has no effect on byte
/// operations. For non-byte operations, the REX operand-size override takes precedence over the 66h
/// prefix. If a 66h prefix is used together with a REX prefix that has the REX.W bit set to 1, the 66h
/// prefix is ignored. However, if a 66h prefix is used together with a REX prefix that has the REX.W bit
/// cleared to 0, the 66h prefix is not ignored and the operand size becomes 16 bits.
///</remarks>
Wide = None | (1 << 3),
/// <summary>
/// Reg index from ModRM extension.
/// </summary>
/// <remarks>
/// The REX.R bit adds a 1-bit (high) extension to the ModRM reg field (page 17)
/// when that field encodes a GPR, XMM, control, or debug register. REX.R does not modify ModRM reg
/// when that field specifies other registers or opcodes. REX.R is ignored in such cases.
/// </remarks>
Reg = None | (1 << 2),
/// <summary>
/// SIB index register extension.
/// </summary>
Index = None | (1 << 1),
/// <summary>
/// SIB index register extension.
/// Use Index mnenonic instead.
/// </summary>
X = None | (1 << 1),
/// <summary>
/// Extension of the ModRM r/m field1, SIB base field, or opcode reg field,
/// </summary>
/// <remarks>
/// The REX.B bit adds a 1-bit (high) extension to either the ModRM r/m field to specify
/// a GPR or XMM register, or to the SIB base field to specify a GPR. (See Table 2-2 on page 40 for more
/// about the REX.B bit.)
/// </remarks>
B = None | (1 << 0),
}
}