Cosmos/source/Indy.IL2CPU/Assembler/x86/Pop.cs
mterwoord_cp 8b8be0c28d
2008-11-29 17:26:44 +00:00

26 lines
No EOL
1 KiB
C#

using System;
using System.Linq;
namespace Indy.IL2CPU.Assembler.X86 {
[OpCode("pop")]
public class Pop: InstructionWithDestinationAndSize{
public static void InitializeEncodingData(Instruction.InstructionData aData) {
aData.EncodingOptions.Add(new InstructionData.InstructionEncodingOption {
AllowedSizes = InstructionSizes.DWord | InstructionSizes.Word,
OpCode = new byte[] { 0x58 },
NeedsModRMByte = false,
DestinationReg = Guid.Empty,
DefaultSize=InstructionSize.DWord,
DestinationRegByte = 0
}); // pop to register
aData.EncodingOptions.Add(new InstructionData.InstructionEncodingOption {
AllowedSizes = InstructionSizes.DWord | InstructionSizes.Word,
OpCode = new byte[]{0x8F},
NeedsModRMByte=true,
DestinationMemory=true,
DefaultSize = InstructionSize.DWord
}); // pop to memory
}
}
}