Cosmos/source/Cosmos.IL2CPU/IL/Ldind_R8.cs
José Pedro f8e18e3fbc Fixed StringHelper.GetNumberString().
Changes in Conv*, Ld* and St* opcodes so that values with size < 4 bytes are extended to 4 bytes.
Implemented Not and Xor for values with size 8 bytes.
Added tests for bitwise operations, arithmetic operations and Conv* opcodes.
2017-01-24 20:54:07 +00:00

45 lines
1.5 KiB
C#

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