shader: Implement CAL inlining function calls
This commit is contained in:
		
							parent
							
								
									b9f7bf4472
								
							
						
					
					
						commit
						71f96fa636
					
				
					 24 changed files with 286 additions and 330 deletions
				
			
		|  | @ -10,12 +10,14 @@ | |||
| 
 | ||||
| namespace Shader::Optimization { | ||||
| 
 | ||||
| void DeadCodeEliminationPass(IR::Block& block) { | ||||
| void DeadCodeEliminationPass(IR::Program& program) { | ||||
|     // We iterate over the instructions in reverse order.
 | ||||
|     // This is because removing an instruction reduces the number of uses for earlier instructions.
 | ||||
|     for (IR::Inst& inst : block | std::views::reverse) { | ||||
|         if (!inst.HasUses() && !inst.MayHaveSideEffects()) { | ||||
|             inst.Invalidate(); | ||||
|     for (IR::Block* const block : program.post_order_blocks) { | ||||
|         for (IR::Inst& inst : block->Instructions() | std::views::reverse) { | ||||
|             if (!inst.HasUses() && !inst.MayHaveSideEffects()) { | ||||
|                 inst.Invalidate(); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ReinUsesLisp
						ReinUsesLisp