Cosmos/source/Indy.IL2CPU/IL/x86/And.cs
mterwoord_cp 5928581f2f
2008-11-07 12:27:08 +00:00

43 lines
No EOL
1.5 KiB
C#

using System;
using System.IO;
using CPU = Indy.IL2CPU.Assembler.X86;
using Indy.IL2CPU.Assembler;
namespace Indy.IL2CPU.IL.X86 {
[OpCode(OpCodeEnum.And)]
public class And: Op {
public And(ILReader aReader, MethodInformation aMethodInfo)
: base(aReader, aMethodInfo) {
}
public override void DoAssemble() {
StackContent xStackContent = Assembler.StackContents.Peek();
if (xStackContent.IsFloat) {
throw new Exception("Floats not yet supported!");
}
int xSize = Math.Max(Assembler.StackContents.Pop().Size, Assembler.StackContents.Pop().Size);
if (xSize > 8) {
throw new Exception("StackSize>8 not supported");
}
if (xSize > 4)
{
new CPU.Pop { DestinationReg = CPU.Registers.EAX };
new CPU.Pop { DestinationReg = CPU.Registers.EBX };
new CPU.Pop { DestinationReg = CPU.Registers.EDX };
new CPU.Pop { DestinationReg = CPU.Registers.ECX };
new CPU.And(CPU.Registers_Old.EAX, CPU.Registers_Old.EDX);
new CPU.And("ebx", "ecx");
new CPU.Push { DestinationReg = CPU.Registers.EBX };
new CPU.Push { DestinationReg = CPU.Registers.EAX };
}else
{
new CPU.Pop { DestinationReg = CPU.Registers.EAX };
new CPU.Pop { DestinationReg = CPU.Registers.EDX };
new CPU.And(CPU.Registers_Old.EAX, CPU.Registers_Old.EDX);
new CPU.Push { DestinationReg = CPU.Registers.EAX };
}
Assembler.StackContents.Push(xStackContent);
}
}
}