OpCodeBfm64.cs 734 B

1234567891011121314151617181920212223242526272829
  1. using ChocolArm64.Instructions;
  2. namespace ChocolArm64.Decoders
  3. {
  4. class OpCodeBfm64 : OpCodeAlu64
  5. {
  6. public long WMask { get; private set; }
  7. public long TMask { get; private set; }
  8. public int Pos { get; private set; }
  9. public int Shift { get; private set; }
  10. public OpCodeBfm64(Inst inst, long position, int opCode) : base(inst, position, opCode)
  11. {
  12. var bm = DecoderHelper.DecodeBitMask(opCode, false);
  13. if (bm.IsUndefined)
  14. {
  15. Emitter = InstEmit.Und;
  16. return;
  17. }
  18. WMask = bm.WMask;
  19. TMask = bm.TMask;
  20. Pos = bm.Pos;
  21. Shift = bm.Shift;
  22. }
  23. }
  24. }