OpCode32SimdShImmLong.cs 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  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);
  7. public OpCode32SimdShImmLong(InstDescriptor inst, ulong address, int opCode) : base(inst, address, opCode)
  8. {
  9. Q = false;
  10. RegisterSize = RegisterSize.Simd64;
  11. int imm6 = (opCode >> 16) & 0x3f;
  12. if ((imm6 & 0x20) == 0b100000)
  13. {
  14. Size = 2;
  15. Shift = imm6 - 32;
  16. }
  17. else if ((imm6 & 0x30) == 0b010000)
  18. {
  19. Size = 1;
  20. Shift = imm6 - 16;
  21. }
  22. else if ((imm6 & 0x38) == 0b001000)
  23. {
  24. Size = 0;
  25. Shift = imm6 - 8;
  26. }
  27. else
  28. {
  29. Instruction = InstDescriptor.Undefined;
  30. }
  31. if (GetType() == typeof(OpCode32SimdShImmLong) && DecoderHelper.VectorArgumentsInvalid(true, Vd))
  32. {
  33. Instruction = InstDescriptor.Undefined;
  34. }
  35. }
  36. }
  37. }