mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-25 03:46:43 +08:00 
			
		
		
		
	shader/half_set_predicate: Fix HSETP2 for constant buffers
HSETP2 when used with a constant buffer parses the second operand type as F32. This is not configurable.
This commit is contained in:
		
							parent
							
								
									632c9e4ee3
								
							
						
					
					
						commit
						3d0f357307
					
				| @ -33,6 +33,8 @@ u32 ShaderIR::DecodeHalfSetPredicate(NodeBlock& bb, u32 pc) { | |||||||
|         h_and = instr.hsetp2.cbuf_and_imm.h_and; |         h_and = instr.hsetp2.cbuf_and_imm.h_and; | ||||||
|         op_b = GetOperandAbsNegHalf(GetConstBuffer(instr.cbuf34.index, instr.cbuf34.GetOffset()), |         op_b = GetOperandAbsNegHalf(GetConstBuffer(instr.cbuf34.index, instr.cbuf34.GetOffset()), | ||||||
|                                     instr.hsetp2.cbuf.abs_b, instr.hsetp2.cbuf.negate_b); |                                     instr.hsetp2.cbuf.abs_b, instr.hsetp2.cbuf.negate_b); | ||||||
|  |         // F32 is hardcoded in hardware
 | ||||||
|  |         op_b = UnpackHalfFloat(std::move(op_b), Tegra::Shader::HalfType::F32); | ||||||
|         break; |         break; | ||||||
|     case OpCode::Id::HSETP2_IMM: |     case OpCode::Id::HSETP2_IMM: | ||||||
|         cond = instr.hsetp2.cbuf_and_imm.cond; |         cond = instr.hsetp2.cbuf_and_imm.cond; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user