OpCodeSimdFmov.cs 827 B

123456789101112131415161718192021222324252627282930
  1. namespace ARMeilleure.Decoders
  2. {
  3. class OpCodeSimdFmov : OpCode, IOpCodeSimd
  4. {
  5. public int Rd { get; private set; }
  6. public long Immediate { get; private set; }
  7. public int Size { get; private set; }
  8. public OpCodeSimdFmov(InstDescriptor inst, ulong address, int opCode) : base(inst, address, opCode)
  9. {
  10. int type = (opCode >> 22) & 0x3;
  11. Size = type;
  12. long imm;
  13. Rd = (opCode >> 0) & 0x1f;
  14. imm = (opCode >> 13) & 0xff;
  15. if (type == 0)
  16. {
  17. Immediate = (long)DecoderHelper.Imm8ToFP32Table[(int)imm];
  18. }
  19. else /* if (type == 1) */
  20. {
  21. Immediate = (long)DecoderHelper.Imm8ToFP64Table[(int)imm];
  22. }
  23. }
  24. }
  25. }