mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 13:12:25 -07:00 
			
		
		
		
	
		
			
				
	
	
		
			30 lines
		
	
	
		
			871 B
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			871 B
		
	
	
	
		
			C#
		
	
	
	
	
	
| using Ryujinx.Graphics.Shader.Instructions;
 | |
| 
 | |
| namespace Ryujinx.Graphics.Shader.Decoders
 | |
| {
 | |
|     class OpCode
 | |
|     {
 | |
|         public InstEmitter Emitter { get; }
 | |
| 
 | |
|         public ulong Address   { get; }
 | |
|         public long  RawOpCode { get; }
 | |
| 
 | |
|         public Register Predicate { get; protected set; }
 | |
| 
 | |
|         public bool InvertPredicate { get; protected set; }
 | |
| 
 | |
|         // When inverted, the always true predicate == always false.
 | |
|         public bool NeverExecute => Predicate.Index == RegisterConsts.PredicateTrueIndex && InvertPredicate;
 | |
| 
 | |
|         public OpCode(InstEmitter emitter, ulong address, long opCode)
 | |
|         {
 | |
|             Emitter   = emitter;
 | |
|             Address   = address;
 | |
|             RawOpCode = opCode;
 | |
| 
 | |
|             Predicate = new Register(opCode.Extract(16, 3), RegisterType.Predicate);
 | |
| 
 | |
|             InvertPredicate = opCode.Extract(19);
 | |
|         }
 | |
|     }
 | |
| } |