using System; using CPUx86 = Cosmos.IL2CPU.X86; namespace Cosmos.IL2CPU.X86.IL { [Cosmos.IL2CPU.OpCode( ILOpCode.Code.Ldind_R8 )] public class Ldind_R8 : ILOp { public Ldind_R8( Cosmos.IL2CPU.Assembler aAsmblr ) : base( aAsmblr ) { } public override void Execute( MethodInfo aMethod, ILOpCode aOpCode ) { new CPUx86.Pop { DestinationReg = CPUx86.Registers.EAX }; Assembler.Stack.Pop(); new CPUx86.Push { DestinationReg = CPUx86.Registers.EAX, DestinationIsIndirect = true, DestinationDisplacement = 4 }; new CPUx86.Push { DestinationReg = CPUx86.Registers.EAX, DestinationIsIndirect = true }; Assembler.Stack.Push( 8, typeof( Double ) ); } // using System; // // using CPUx86 = Cosmos.IL2CPU.X86; // using Cosmos.IL2CPU.X86; // // namespace Cosmos.IL2CPU.IL.X86 { // [OpCode(OpCodeEnum.Ldind_R8)] // public class Ldind_R8: Op { // public Ldind_R8(ILReader aReader, MethodInformation aMethodInfo) // : base(aReader, aMethodInfo) { // } // public override void DoAssemble() { // new CPUx86.Pop{DestinationReg=CPUx86.Registers.EAX}; // Assembler.Stack.Pop(); // new CPUx86.Push { DestinationReg = CPUx86.Registers.EAX, DestinationIsIndirect = true, DestinationDisplacement = 4 }; // new CPUx86.Push { DestinationReg = CPUx86.Registers.EAX, DestinationIsIndirect = true}; // Assembler.Stack.Push(new StackContent(8, typeof(Double))); // } // } // } } }