OpCodeImage.cs 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. using Ryujinx.Graphics.Shader.Instructions;
  2. namespace Ryujinx.Graphics.Shader.Decoders
  3. {
  4. class OpCodeImage : OpCode
  5. {
  6. public Register Ra { get; }
  7. public Register Rb { get; }
  8. public Register Rc { get; }
  9. public ImageComponents Components { get; }
  10. public IntegerSize Size { get; }
  11. public bool ByteAddress { get; }
  12. public ImageDimensions Dimensions { get; }
  13. public int Immediate { get; }
  14. public bool UseComponents { get; }
  15. public bool IsBindless { get; }
  16. public new static OpCode Create(InstEmitter emitter, ulong address, long opCode) => new OpCodeImage(emitter, address, opCode);
  17. public OpCodeImage(InstEmitter emitter, ulong address, long opCode) : base(emitter, address, opCode)
  18. {
  19. Ra = new Register(opCode.Extract(8, 8), RegisterType.Gpr);
  20. Rb = new Register(opCode.Extract(0, 8), RegisterType.Gpr);
  21. Rc = new Register(opCode.Extract(39, 8), RegisterType.Gpr);
  22. UseComponents = !opCode.Extract(52);
  23. if (UseComponents)
  24. {
  25. Components = (ImageComponents)opCode.Extract(20, 4);
  26. }
  27. else
  28. {
  29. Size = (IntegerSize)opCode.Extract(20, 4);
  30. }
  31. ByteAddress = opCode.Extract(23);
  32. Dimensions = (ImageDimensions)opCode.Extract(33, 3);
  33. Immediate = opCode.Extract(36, 13);
  34. IsBindless = !opCode.Extract(51);
  35. }
  36. }
  37. }