OpCodeT16Adr.cs 566 B

12345678910111213141516171819
  1. namespace ARMeilleure.Decoders
  2. {
  3. class OpCodeT16Adr : OpCodeT16, IOpCode32Adr
  4. {
  5. public int Rd { get; }
  6. public int Immediate { get; }
  7. public new static OpCode Create(InstDescriptor inst, ulong address, int opCode) => new OpCodeT16Adr(inst, address, opCode);
  8. public OpCodeT16Adr(InstDescriptor inst, ulong address, int opCode) : base(inst, address, opCode)
  9. {
  10. Rd = (opCode >> 8) & 7;
  11. int imm = (opCode & 0xff) << 2;
  12. Immediate = (int)(GetPc() & 0xfffffffc) + imm;
  13. }
  14. }
  15. }