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