OpCodeMov64.cs 913 B

123456789101112131415161718192021222324252627282930313233343536
  1. using ChocolArm64.Instructions;
  2. using ChocolArm64.State;
  3. namespace ChocolArm64.Decoders
  4. {
  5. class OpCodeMov64 : OpCode64
  6. {
  7. public int Rd { get; private set; }
  8. public long Imm { get; private set; }
  9. public int Pos { get; private set; }
  10. public OpCodeMov64(Inst inst, long position, int opCode) : base(inst, position, opCode)
  11. {
  12. int p1 = (opCode >> 22) & 1;
  13. int sf = (opCode >> 31) & 1;
  14. if (sf == 0 && p1 != 0)
  15. {
  16. Emitter = InstEmit.Und;
  17. return;
  18. }
  19. Rd = (opCode >> 0) & 0x1f;
  20. Imm = (opCode >> 5) & 0xffff;
  21. Pos = (opCode >> 21) & 0x3;
  22. Pos <<= 4;
  23. Imm <<= Pos;
  24. RegisterSize = (opCode >> 31) != 0
  25. ? State.RegisterSize.Int64
  26. : State.RegisterSize.Int32;
  27. }
  28. }
  29. }