Ryujinx/ChocolArm64/Decoder/AOpCode.cs

40 lines
1.1 KiB
C#
Raw Normal View History

2018-02-04 15:08:20 -08:00
using ChocolArm64.Instruction;
using ChocolArm64.State;
using System;
namespace ChocolArm64.Decoder
{
class AOpCode : IAOpCode
{
public long Position { get; private set; }
public int RawOpCode { get; private set; }
2018-02-04 15:08:20 -08:00
public AInstEmitter Emitter { get; protected set; }
public AInstInterpreter Interpreter { get; protected set; }
public ARegisterSize RegisterSize { get; protected set; }
2018-02-04 15:08:20 -08:00
public AOpCode(AInst Inst, long Position, int OpCode)
2018-02-04 15:08:20 -08:00
{
this.Position = Position;
this.RawOpCode = OpCode;
2018-02-04 15:08:20 -08:00
RegisterSize = ARegisterSize.Int64;
Emitter = Inst.Emitter;
Interpreter = Inst.Interpreter;
2018-02-04 15:08:20 -08:00
}
public int GetBitsCount()
{
switch (RegisterSize)
{
case ARegisterSize.Int32: return 32;
case ARegisterSize.Int64: return 64;
case ARegisterSize.SIMD64: return 64;
case ARegisterSize.SIMD128: return 128;
}
throw new InvalidOperationException();
}
}
}