OpCodeMov64.cs 888 B

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