2018-02-05 00:08:20 +01:00
|
|
|
using ChocolArm64.Instruction;
|
|
|
|
|
|
|
|
namespace ChocolArm64.Decoder
|
|
|
|
{
|
2018-02-15 05:32:25 +01:00
|
|
|
class AOpCodeSimdRegElem : AOpCodeSimdReg
|
2018-02-05 00:08:20 +01:00
|
|
|
{
|
|
|
|
public int Index { get; private set; }
|
|
|
|
|
|
|
|
public AOpCodeSimdRegElem(AInst Inst, long Position, int OpCode) : base(Inst, Position, OpCode)
|
|
|
|
{
|
2018-03-05 20:18:37 +01:00
|
|
|
switch (Size)
|
2018-02-05 00:08:20 +01:00
|
|
|
{
|
2018-03-05 20:18:37 +01:00
|
|
|
case 1:
|
2018-03-16 02:36:47 +01:00
|
|
|
Index = (OpCode >> 20) & 3 |
|
|
|
|
(OpCode >> 9) & 4;
|
2018-03-05 20:18:37 +01:00
|
|
|
|
|
|
|
Rm &= 0xf;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
Index = (OpCode >> 21) & 1 |
|
|
|
|
(OpCode >> 10) & 2;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
default: Emitter = AInstEmit.Und; return;
|
2018-02-05 00:08:20 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|