forked from eden-emu/eden
		
	emit_glsl_warp: Fix shfl_in_bounds conditional
This commit is contained in:
		
							parent
							
								
									c4e1a9a7a6
								
							
						
					
					
						commit
						ef8f689761
					
				
					 2 changed files with 9 additions and 4 deletions
				
			
		|  | @ -141,7 +141,8 @@ void EmitShuffleIndex(EmitContext& ctx, IR::Inst& inst, std::string_view value, | |||
|     const auto src_thread_id{fmt::format("({})|({})", lhs, min_thread_id)}; | ||||
|     ctx.Add("shfl_in_bounds=int({})<=int({});", src_thread_id, max_thread_id); | ||||
|     SetInBoundsFlag(ctx, inst); | ||||
|     ctx.AddU32("{}=shfl_in_bounds?readInvocationARB({},{}):{};", inst, value, src_thread_id, value); | ||||
|     ctx.Add("shfl_result=readInvocationARB({},{});", value, src_thread_id); | ||||
|     ctx.AddU32("{}=shfl_in_bounds?shfl_result:{};", inst, value); | ||||
| } | ||||
| 
 | ||||
| void EmitShuffleUp(EmitContext& ctx, IR::Inst& inst, std::string_view value, std::string_view index, | ||||
|  | @ -158,7 +159,8 @@ void EmitShuffleUp(EmitContext& ctx, IR::Inst& inst, std::string_view value, std | |||
|     const auto src_thread_id{fmt::format("({}-{})", THREAD_ID, index)}; | ||||
|     ctx.Add("shfl_in_bounds=int({})>=int({});", src_thread_id, max_thread_id); | ||||
|     SetInBoundsFlag(ctx, inst); | ||||
|     ctx.AddU32("{}=shfl_in_bounds?readInvocationARB({},{}):{};", inst, value, src_thread_id, value); | ||||
|     ctx.Add("shfl_result=readInvocationARB({},{});", value, src_thread_id); | ||||
|     ctx.AddU32("{}=shfl_in_bounds?shfl_result:{};", inst, value); | ||||
| } | ||||
| 
 | ||||
| void EmitShuffleDown(EmitContext& ctx, IR::Inst& inst, std::string_view value, | ||||
|  | @ -175,7 +177,8 @@ void EmitShuffleDown(EmitContext& ctx, IR::Inst& inst, std::string_view value, | |||
|     const auto src_thread_id{fmt::format("({}+{})", THREAD_ID, index)}; | ||||
|     ctx.Add("shfl_in_bounds=int({})<=int({});", src_thread_id, max_thread_id); | ||||
|     SetInBoundsFlag(ctx, inst); | ||||
|     ctx.AddU32("{}=shfl_in_bounds?readInvocationARB({},{}):{};", inst, value, src_thread_id, value); | ||||
|     ctx.Add("shfl_result=readInvocationARB({},{});", value, src_thread_id); | ||||
|     ctx.AddU32("{}=shfl_in_bounds?shfl_result:{};", inst, value); | ||||
| } | ||||
| 
 | ||||
| void EmitShuffleButterfly(EmitContext& ctx, IR::Inst& inst, std::string_view value, | ||||
|  | @ -193,7 +196,8 @@ void EmitShuffleButterfly(EmitContext& ctx, IR::Inst& inst, std::string_view val | |||
|     const auto src_thread_id{fmt::format("({}^{})", THREAD_ID, index)}; | ||||
|     ctx.Add("shfl_in_bounds=int({})<=int({});", src_thread_id, max_thread_id); | ||||
|     SetInBoundsFlag(ctx, inst); | ||||
|     ctx.AddU32("{}=shfl_in_bounds?readInvocationARB({},{}):{};", inst, value, src_thread_id, value); | ||||
|     ctx.Add("shfl_result=readInvocationARB({},{});", value, src_thread_id); | ||||
|     ctx.AddU32("{}=shfl_in_bounds?shfl_result:{};", inst, value); | ||||
| } | ||||
| 
 | ||||
| void EmitFSwizzleAdd(EmitContext& ctx, IR::Inst& inst, std::string_view op_a, std::string_view op_b, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Ameer J
						Ameer J