Cosmos/source/Indy.IL2CPU/IL/x86/And.cs
mterwoord_cp b13b8bcde9
2008-11-07 15:35:18 +00:00

43 lines
No EOL
1.7 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 { DestinationReg = CPU.Registers.EAX, SourceReg = CPU.Registers.EDX };
new CPU.And { DestinationReg = CPU.Registers.EBX, SourceReg = CPU.Registers.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 { DestinationReg = CPU.Registers.EAX, SourceReg = CPU.Registers.EDX };
new CPU.Push { DestinationReg = CPU.Registers.EAX };
}
Assembler.StackContents.Push(xStackContent);
}
}
}