iced/Iced/Intel/OpKind.cs

166 lines
5.6 KiB
C#
Raw Normal View History

2018-09-05 23:29:23 +00:00
/*
Copyright (C) 2018 de4dot@gmail.com
This file is part of Iced.
Iced is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Iced is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with Iced. If not, see <https://www.gnu.org/licenses/>.
*/
namespace Iced.Intel {
/// <summary>
/// Instruction operand kind
/// </summary>
public enum OpKind {
/// <summary>
/// A register (<see cref="Intel.Register"/>).
///
/// This operand kind uses <see cref="Instruction.Op0Register"/>, <see cref="Instruction.Op1Register"/>,
/// <see cref="Instruction.Op2Register"/> or <see cref="Instruction.Op3Register"/> depending on operand number.
/// See also <see cref="Instruction.GetOpRegister(int)"/>.
/// </summary>
Register = 0,// Code assumes this is 0
/// <summary>
/// Near 16-bit branch. This operand kind uses <see cref="Instruction.NearBranch16Target"/>
/// </summary>
NearBranch16,
/// <summary>
/// Near 32-bit branch. This operand kind uses <see cref="Instruction.NearBranch32Target"/>
/// </summary>
NearBranch32,
/// <summary>
/// Near 64-bit branch. This operand kind uses <see cref="Instruction.NearBranch64Target"/>
/// </summary>
NearBranch64,
/// <summary>
/// Far 16-bit branch. This operand kind uses <see cref="Instruction.FarBranch16Target"/> and <see cref="Instruction.FarBranchSelector"/>
/// </summary>
FarBranch16,
/// <summary>
/// Far 32-bit branch. This operand kind uses <see cref="Instruction.FarBranch32Target"/> and <see cref="Instruction.FarBranchSelector"/>
/// </summary>
FarBranch32,
/// <summary>
/// 8-bit constant. This operand kind uses <see cref="Instruction.Immediate8"/>
/// </summary>
Immediate8,
/// <summary>
2018-09-10 23:06:13 +00:00
/// 8-bit constant used by the enter, extrq, insertq instructions. This operand kind uses <see cref="Instruction.Immediate8_2nd"/>
2018-09-05 23:29:23 +00:00
/// </summary>
2018-09-10 23:06:13 +00:00
Immediate8_2nd,
2018-09-05 23:29:23 +00:00
/// <summary>
/// 16-bit constant. This operand kind uses <see cref="Instruction.Immediate16"/>
/// </summary>
Immediate16,
/// <summary>
/// 32-bit constant. This operand kind uses <see cref="Instruction.Immediate32"/>
/// </summary>
Immediate32,
/// <summary>
/// 64-bit constant. This operand kind uses <see cref="Instruction.Immediate64"/>
/// </summary>
Immediate64,
/// <summary>
/// An 8-bit value sign extended to 16 bits. This operand kind uses <see cref="Instruction.Immediate8to16"/>
/// </summary>
Immediate8to16,
/// <summary>
/// An 8-bit value sign extended to 32 bits. This operand kind uses <see cref="Instruction.Immediate8to32"/>
/// </summary>
Immediate8to32,
/// <summary>
/// An 8-bit value sign extended to 64 bits. This operand kind uses <see cref="Instruction.Immediate8to64"/>
/// </summary>
Immediate8to64,
/// <summary>
/// A 32-bit value sign extended to 64 bits. This operand kind uses <see cref="Instruction.Immediate32to64"/>
/// </summary>
Immediate32to64,
/// <summary>
/// seg:[si]. This operand kind uses <see cref="Instruction.MemorySize"/>, <see cref="Instruction.MemorySegment"/>, <see cref="Instruction.PrefixSegment"/>
/// </summary>
MemorySegSI,
/// <summary>
/// seg:[esi]. This operand kind uses <see cref="Instruction.MemorySize"/>, <see cref="Instruction.MemorySegment"/>, <see cref="Instruction.PrefixSegment"/>
/// </summary>
MemorySegESI,
/// <summary>
/// seg:[rsi]. This operand kind uses <see cref="Instruction.MemorySize"/>, <see cref="Instruction.MemorySegment"/>, <see cref="Instruction.PrefixSegment"/>
/// </summary>
MemorySegRSI,
/// <summary>
/// seg:[di]. This operand kind uses <see cref="Instruction.MemorySize"/>, <see cref="Instruction.MemorySegment"/>, <see cref="Instruction.PrefixSegment"/>
/// </summary>
MemorySegDI,
/// <summary>
/// seg:[edi]. This operand kind uses <see cref="Instruction.MemorySize"/>, <see cref="Instruction.MemorySegment"/>, <see cref="Instruction.PrefixSegment"/>
/// </summary>
MemorySegEDI,
/// <summary>
/// seg:[rdi]. This operand kind uses <see cref="Instruction.MemorySize"/>, <see cref="Instruction.MemorySegment"/>, <see cref="Instruction.PrefixSegment"/>
/// </summary>
MemorySegRDI,
/// <summary>
/// es:[di]. This operand kind uses <see cref="Instruction.MemorySize"/>
/// </summary>
MemoryESDI,
/// <summary>
/// es:[edi]. This operand kind uses <see cref="Instruction.MemorySize"/>
/// </summary>
MemoryESEDI,
/// <summary>
/// es:[rdi]. This operand kind uses <see cref="Instruction.MemorySize"/>
/// </summary>
MemoryESRDI,
/// <summary>
/// 64-bit offset [xxxxxxxxxxxxxxxx]. This operand kind uses <see cref="Instruction.MemoryAddress64"/>,
/// <see cref="Instruction.MemorySegment"/>, <see cref="Instruction.PrefixSegment"/>, <see cref="Instruction.MemorySize"/>
/// </summary>
Memory64,
/// <summary>
/// Memory operand.
///
/// This operand kind uses <see cref="Instruction.MemoryDisplSize"/>, <see cref="Instruction.MemorySize"/>,
/// <see cref="Instruction.MemoryIndexScale"/>, <see cref="Instruction.MemoryDisplacement"/>,
/// <see cref="Instruction.MemoryBase"/>, <see cref="Instruction.MemoryIndex"/>, <see cref="Instruction.MemorySegment"/>,
/// <see cref="Instruction.PrefixSegment"/>
/// </summary>
Memory,
}
}