mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-26 04:17:12 +08:00 
			
		
		
		
	shader_decode: Reimplement BFE instructions
This commit is contained in:
		
							parent
							
								
									00e9ba0603
								
							
						
					
					
						commit
						465ba30d08
					
				| @ -17,32 +17,34 @@ u32 ShaderIR::DecodeBfe(NodeBlock& bb, u32 pc) { | |||||||
|     const Instruction instr = {program_code[pc]}; |     const Instruction instr = {program_code[pc]}; | ||||||
|     const auto opcode = OpCode::Decode(instr); |     const auto opcode = OpCode::Decode(instr); | ||||||
| 
 | 
 | ||||||
|     UNIMPLEMENTED_IF(instr.bfe.negate_b); |  | ||||||
| 
 |  | ||||||
|     Node op_a = GetRegister(instr.gpr8); |     Node op_a = GetRegister(instr.gpr8); | ||||||
|     op_a = GetOperandAbsNegInteger(op_a, false, instr.bfe.negate_a, false); |     Node op_b = [&] { | ||||||
|  |         switch (opcode->get().GetId()) { | ||||||
|  |         case OpCode::Id::BFE_R: | ||||||
|  |             return GetRegister(instr.gpr20); | ||||||
|  |         case OpCode::Id::BFE_C: | ||||||
|  |             return GetConstBuffer(instr.cbuf34.index, instr.cbuf34.GetOffset()); | ||||||
|  |         case OpCode::Id::BFE_IMM: | ||||||
|  |             return Immediate(instr.alu.GetSignedImm20_20()); | ||||||
|  |         default: | ||||||
|  |             UNREACHABLE(); | ||||||
|  |             return Immediate(0); | ||||||
|  |         } | ||||||
|  |     }(); | ||||||
| 
 | 
 | ||||||
|     switch (opcode->get().GetId()) { |     UNIMPLEMENTED_IF_MSG(instr.bfe.rd_cc, "Condition codes in BFE is not implemented"); | ||||||
|     case OpCode::Id::BFE_IMM: { |     UNIMPLEMENTED_IF_MSG(instr.bfe.brev, "BREV in BFE is not implemented"); | ||||||
|         UNIMPLEMENTED_IF_MSG(instr.generates_cc, |  | ||||||
|                              "Condition codes generation in BFE is not implemented"); |  | ||||||
| 
 | 
 | ||||||
|         const Node inner_shift_imm = Immediate(static_cast<u32>(instr.bfe.GetLeftShiftValue())); |     const bool is_signed = instr.bfe.is_signed; | ||||||
|         const Node outer_shift_imm = |  | ||||||
|             Immediate(static_cast<u32>(instr.bfe.GetLeftShiftValue() + instr.bfe.shift_position)); |  | ||||||
| 
 | 
 | ||||||
|         const Node inner_shift = |     const auto start_position = SignedOperation(OperationCode::IBitfieldExtract, is_signed, op_b, | ||||||
|             Operation(OperationCode::ILogicalShiftLeft, NO_PRECISE, op_a, inner_shift_imm); |                                                 Immediate(0), Immediate(8)); | ||||||
|         const Node outer_shift = |     const auto bits = SignedOperation(OperationCode::IBitfieldExtract, is_signed, op_b, | ||||||
|             Operation(OperationCode::ILogicalShiftRight, NO_PRECISE, inner_shift, outer_shift_imm); |                                       Immediate(8), Immediate(8)); | ||||||
| 
 | 
 | ||||||
|         SetInternalFlagsFromInteger(bb, outer_shift, instr.generates_cc); |     auto result = | ||||||
|         SetRegister(bb, instr.gpr0, outer_shift); |         SignedOperation(OperationCode::IBitfieldExtract, is_signed, op_a, start_position, bits); | ||||||
|         break; |     SetRegister(bb, instr.gpr0, result); | ||||||
|     } |  | ||||||
|     default: |  | ||||||
|         UNIMPLEMENTED_MSG("Unhandled BFE instruction: {}", opcode->get().GetName()); |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     return pc; |     return pc; | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user