forked from eden-emu/eden
		
	Shader_IR: Implement Fast BRX and allow multi-branches in the CFG.
This commit is contained in:
		
							parent
							
								
									2baf1e1ed4
								
							
						
					
					
						commit
						683008bc59
					
				
					 7 changed files with 260 additions and 132 deletions
				
			
		|  | @ -17,13 +17,14 @@ using Tegra::Shader::Pred; | |||
| class ExprAnd; | ||||
| class ExprBoolean; | ||||
| class ExprCondCode; | ||||
| class ExprGprEqual; | ||||
| class ExprNot; | ||||
| class ExprOr; | ||||
| class ExprPredicate; | ||||
| class ExprVar; | ||||
| 
 | ||||
| using ExprData = | ||||
|     std::variant<ExprVar, ExprCondCode, ExprPredicate, ExprNot, ExprOr, ExprAnd, ExprBoolean>; | ||||
| using ExprData = std::variant<ExprVar, ExprCondCode, ExprPredicate, ExprNot, ExprOr, ExprAnd, | ||||
|                               ExprBoolean, ExprGprEqual>; | ||||
| using Expr = std::shared_ptr<ExprData>; | ||||
| 
 | ||||
| class ExprAnd final { | ||||
|  | @ -118,6 +119,18 @@ public: | |||
|     bool value; | ||||
| }; | ||||
| 
 | ||||
| class ExprGprEqual final { | ||||
| public: | ||||
|     ExprGprEqual(u32 gpr, u32 value) : gpr{gpr}, value{value} {} | ||||
| 
 | ||||
|     bool operator==(const ExprGprEqual& b) const { | ||||
|         return gpr == b.gpr && value == b.value; | ||||
|     } | ||||
| 
 | ||||
|     u32 gpr; | ||||
|     u32 value; | ||||
| }; | ||||
| 
 | ||||
| template <typename T, typename... Args> | ||||
| Expr MakeExpr(Args&&... args) { | ||||
|     static_assert(std::is_convertible_v<T, ExprData>); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Fernando Sahmkow
						Fernando Sahmkow