mirror of
https://github.com/danbulant/Cosmos
synced 2026-05-19 20:39:01 +00:00
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.
45 lines
1.3 KiB
C#
45 lines
1.3 KiB
C#
using System;
|
|
|
|
using Cosmos.IL2CPU.ILOpCodes;
|
|
using XSharp.Compiler;
|
|
|
|
namespace Cosmos.IL2CPU.X86.IL
|
|
{
|
|
[Cosmos.IL2CPU.OpCode( ILOpCode.Code.Ldc_R4 )]
|
|
public class Ldc_R4 : ILOp
|
|
{
|
|
public Ldc_R4( Cosmos.Assembler.Assembler aAsmblr )
|
|
: base( aAsmblr )
|
|
{
|
|
}
|
|
|
|
public override void Execute(MethodInfo aMethod, ILOpCode aOpCode)
|
|
{
|
|
OpSingle xOp = (OpSingle)aOpCode;
|
|
XS.Push(BitConverter.ToUInt32(BitConverter.GetBytes(xOp.Value), 0));
|
|
}
|
|
|
|
|
|
// using System;
|
|
// using System.Linq;
|
|
//
|
|
// using CPU = Cosmos.Assembler.x86;
|
|
// using Cosmos.IL2CPU.X86;
|
|
//
|
|
// namespace Cosmos.IL2CPU.IL.X86 {
|
|
// [Cosmos.Assembler.OpCode(OpCodeEnum.Ldc_R4)]
|
|
// public class Ldc_R4: Op {
|
|
// private Single mValue;
|
|
// public Ldc_R4(ILReader aReader, MethodInformation aMethodInfo)
|
|
// : base(aReader, aMethodInfo) {
|
|
// mValue = aReader.OperandValueSingle;
|
|
// }
|
|
// public override void DoAssemble() {
|
|
// new CPU.Push{DestinationValue=BitConverter.ToUInt32(BitConverter.GetBytes(mValue), 0)};
|
|
// Assembler.Stack.Push(new StackContent(4, typeof(Single)));
|
|
// }
|
|
// }
|
|
// }
|
|
|
|
}
|
|
}
|