mirror of
https://github.com/danbulant/Cosmos
synced 2026-06-02 06:10:13 +00:00
61 lines
No EOL
2.6 KiB
C#
61 lines
No EOL
2.6 KiB
C#
using System;
|
|
using System.IO;
|
|
using CPU = Indy.IL2CPU.Assembler;
|
|
using Indy.IL2CPU.Assembler;
|
|
using CPUx86 = Indy.IL2CPU.Assembler.X86;
|
|
|
|
namespace Indy.IL2CPU.IL.X86 {
|
|
[OpCode(OpCodeEnum.Conv_Ovf_I_Un)]
|
|
public class Conv_Ovf_I_Un : Op {
|
|
private readonly string NextInstructionLabel;
|
|
private string mNextLabel;
|
|
private string mCurLabel;
|
|
private uint mCurOffset;
|
|
private MethodInformation mMethodInformation;
|
|
|
|
public Conv_Ovf_I_Un(ILReader aReader,
|
|
MethodInformation aMethodInfo)
|
|
: base(aReader,
|
|
aMethodInfo) {
|
|
mMethodInformation = aMethodInfo;
|
|
mCurOffset = aReader.Position;
|
|
mCurLabel = IL.Op.GetInstructionLabel(aReader);
|
|
mNextLabel = IL.Op.GetInstructionLabel(aReader.NextPosition);
|
|
NextInstructionLabel = GetInstructionLabel(aReader.NextPosition);
|
|
}
|
|
|
|
public override void DoAssemble() {
|
|
var xSource = Assembler.StackContents.Pop();
|
|
switch (xSource.Size) {
|
|
case 1:
|
|
case 2:
|
|
case 4: {
|
|
break;
|
|
}
|
|
case 8: {
|
|
new CPUx86.Pop { DestinationReg = CPUx86.Registers.EAX };
|
|
new CPUx86.Add { DestinationReg = CPUx86.Registers.ESP, SourceValue = 4 };
|
|
new CPUx86.Push { DestinationReg = CPUx86.Registers.EAX };
|
|
//new CPUx86.Pop(CPUx86.Registers_Old.EAX);
|
|
//new CPUx86.SignExtendAX(4);
|
|
////all bits of EDX == sign (EAX)
|
|
//new CPUx86.Pop("EBX");
|
|
////must be equal to EDX
|
|
//new CPUx86.Xor("EBX",
|
|
// "EDX");
|
|
//new CPUx86.JumpIfZero(NextInstructionLabel);
|
|
////equals
|
|
//new CPUx86.Interrupt(CPUx86.Interrupt.INTO);
|
|
break;
|
|
}
|
|
default:
|
|
EmitNotImplementedException(Assembler, GetServiceProvider(), "Conv_Ovf_I_Un: SourceSize " + xSource + " not supported!", mCurLabel, mMethodInformation, mCurOffset, mNextLabel);
|
|
break;
|
|
}
|
|
Assembler.StackContents.Push(new StackContent(4,
|
|
true,
|
|
false,
|
|
false));
|
|
}
|
|
}
|
|
} |