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