OpCode32SimdImm44.cs 1.1 KB

123456789101112131415161718192021222324252627282930313233343536
  1. namespace ARMeilleure.Decoders
  2. {
  3. class OpCode32SimdImm44 : OpCode32, IOpCode32SimdImm
  4. {
  5. public int Vd { get; private set; }
  6. public long Immediate { get; private set; }
  7. public int Size { get; private set; }
  8. public int Elems { get; private set; }
  9. public OpCode32SimdImm44(InstDescriptor inst, ulong address, int opCode) : base(inst, address, opCode)
  10. {
  11. Size = (opCode >> 8) & 0x3;
  12. bool single = Size != 3;
  13. if (single)
  14. {
  15. Vd = ((opCode >> 22) & 0x1) | ((opCode >> 11) & 0x1e);
  16. }
  17. else
  18. {
  19. Vd = ((opCode >> 18) & 0x10) | ((opCode >> 12) & 0xf);
  20. }
  21. long imm;
  22. imm = ((uint)opCode >> 0) & 0xf;
  23. imm |= ((uint)opCode >> 12) & 0xf0;
  24. Immediate = (Size == 3) ? (long)DecoderHelper.Imm8ToFP64Table[(int)imm] : DecoderHelper.Imm8ToFP32Table[(int)imm];
  25. RegisterSize = (!single) ? RegisterSize.Int64 : RegisterSize.Int32;
  26. Elems = 1;
  27. }
  28. }
  29. }