mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-11-04 12:34:39 +08:00 
			
		
		
		
	Merge pull request #602 from Subv/mufu_subop
GPU: Corrected the size of the MUFU subop field, and removed incorrect "min" operation.
This commit is contained in:
		
						commit
						066d6184d4
					
				@ -166,7 +166,6 @@ enum class SubOp : u64 {
 | 
			
		||||
    Lg2 = 0x3,
 | 
			
		||||
    Rcp = 0x4,
 | 
			
		||||
    Rsq = 0x5,
 | 
			
		||||
    Min = 0x8,
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
enum class F2iRoundingOp : u64 {
 | 
			
		||||
@ -210,7 +209,7 @@ union Instruction {
 | 
			
		||||
    } pred;
 | 
			
		||||
    BitField<19, 1, u64> negate_pred;
 | 
			
		||||
    BitField<20, 8, Register> gpr20;
 | 
			
		||||
    BitField<20, 7, SubOp> sub_op;
 | 
			
		||||
    BitField<20, 4, SubOp> sub_op;
 | 
			
		||||
    BitField<28, 8, Register> gpr28;
 | 
			
		||||
    BitField<39, 8, Register> gpr39;
 | 
			
		||||
    BitField<48, 16, u64> opcode;
 | 
			
		||||
 | 
			
		||||
@ -917,10 +917,6 @@ private:
 | 
			
		||||
                    regs.SetRegisterToFloat(instr.gpr0, 0, "inversesqrt(" + op_a + ')', 1, 1,
 | 
			
		||||
                                            instr.alu.saturate_d);
 | 
			
		||||
                    break;
 | 
			
		||||
                case SubOp::Min:
 | 
			
		||||
                    regs.SetRegisterToFloat(instr.gpr0, 0, "min(" + op_a + "," + op_b + ')', 1, 1,
 | 
			
		||||
                                            instr.alu.saturate_d);
 | 
			
		||||
                    break;
 | 
			
		||||
                default:
 | 
			
		||||
                    NGLOG_CRITICAL(HW_GPU, "Unhandled MUFU sub op: {0:x}",
 | 
			
		||||
                                   static_cast<unsigned>(instr.sub_op.Value()));
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user