OpCode32SimdShImmLong.cs 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. namespace ARMeilleure.Decoders
  2. {
  3. class OpCode32SimdShImmLong : OpCode32Simd
  4. {
  5. public int Shift { get; }
  6. public new static OpCode Create(InstDescriptor inst, ulong address, int opCode) => new OpCode32SimdShImmLong(inst, address, opCode, false);
  7. public new static OpCode CreateT32(InstDescriptor inst, ulong address, int opCode) => new OpCode32SimdShImmLong(inst, address, opCode, true);
  8. public OpCode32SimdShImmLong(InstDescriptor inst, ulong address, int opCode, bool isThumb) : base(inst, address, opCode, isThumb)
  9. {
  10. Q = false;
  11. RegisterSize = RegisterSize.Simd64;
  12. int imm6 = (opCode >> 16) & 0x3f;
  13. if ((imm6 & 0x20) == 0b100000)
  14. {
  15. Size = 2;
  16. Shift = imm6 - 32;
  17. }
  18. else if ((imm6 & 0x30) == 0b010000)
  19. {
  20. Size = 1;
  21. Shift = imm6 - 16;
  22. }
  23. else if ((imm6 & 0x38) == 0b001000)
  24. {
  25. Size = 0;
  26. Shift = imm6 - 8;
  27. }
  28. else
  29. {
  30. Instruction = InstDescriptor.Undefined;
  31. }
  32. if (GetType() == typeof(OpCode32SimdShImmLong) && DecoderHelper.VectorArgumentsInvalid(true, Vd))
  33. {
  34. Instruction = InstDescriptor.Undefined;
  35. }
  36. }
  37. }
  38. }