forked from eden-emu/eden
		
	shader_recompiler: add extended LDC to GLASM backend
This commit is contained in:
		
							parent
							
								
									e23adcd481
								
							
						
					
					
						commit
						6bac6d044f
					
				
					 1 changed files with 21 additions and 4 deletions
				
			
		|  | @ -13,9 +13,6 @@ namespace Shader::Backend::GLASM { | |||
| namespace { | ||||
| void GetCbuf(EmitContext& ctx, IR::Inst& inst, const IR::Value& binding, ScalarU32 offset, | ||||
|              std::string_view size) { | ||||
|     if (!binding.IsImmediate()) { | ||||
|         throw NotImplementedException("Indirect constant buffer loading"); | ||||
|     } | ||||
|     const Register ret{ctx.reg_alloc.Define(inst)}; | ||||
|     if (offset.type == Type::U32) { | ||||
|         // Avoid reading arrays out of bounds, matching hardware's behavior
 | ||||
|  | @ -24,7 +21,27 @@ void GetCbuf(EmitContext& ctx, IR::Inst& inst, const IR::Value& binding, ScalarU | |||
|             return; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     if (binding.IsImmediate()) { | ||||
|         ctx.Add("LDC.{} {},c{}[{}];", size, ret, binding.U32(), offset); | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     const ScalarU32 idx{ctx.reg_alloc.Consume(binding)}; | ||||
|     for (u32 i = 0; i < Info::MAX_INDIRECT_CBUFS; i++) { | ||||
|         ctx.Add("SEQ.S.CC RC.x,{},{};" | ||||
|                 "IF NE.x;" | ||||
|                 "LDC.{} {},c{}[{}];", | ||||
|                 idx, i, size, ret, i, offset); | ||||
| 
 | ||||
|         if (i != Info::MAX_INDIRECT_CBUFS - 1) { | ||||
|             ctx.Add("ELSE;"); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     for (u32 i = 0; i < Info::MAX_INDIRECT_CBUFS; i++) { | ||||
|         ctx.Add("ENDIF;"); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| bool IsInputArray(Stage stage) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Liam
						Liam