forked from eden-emu/eden
		
	GPU: Implemented MUFU suboperation 8, sqrt.
This commit is contained in:
		
							parent
							
								
									eac897d583
								
							
						
					
					
						commit
						6880dd7352
					
				
					 2 changed files with 5 additions and 0 deletions
				
			
		|  | @ -166,6 +166,7 @@ enum class SubOp : u64 { | ||||||
|     Lg2 = 0x3, |     Lg2 = 0x3, | ||||||
|     Rcp = 0x4, |     Rcp = 0x4, | ||||||
|     Rsq = 0x5, |     Rsq = 0x5, | ||||||
|  |     Sqrt = 0x8, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| enum class F2iRoundingOp : u64 { | enum class F2iRoundingOp : u64 { | ||||||
|  |  | ||||||
|  | @ -917,6 +917,10 @@ private: | ||||||
|                     regs.SetRegisterToFloat(instr.gpr0, 0, "inversesqrt(" + op_a + ')', 1, 1, |                     regs.SetRegisterToFloat(instr.gpr0, 0, "inversesqrt(" + op_a + ')', 1, 1, | ||||||
|                                             instr.alu.saturate_d); |                                             instr.alu.saturate_d); | ||||||
|                     break; |                     break; | ||||||
|  |                 case SubOp::Sqrt: | ||||||
|  |                     regs.SetRegisterToFloat(instr.gpr0, 0, "sqrt(" + op_a + ')', 1, 1, | ||||||
|  |                                             instr.alu.saturate_d); | ||||||
|  |                     break; | ||||||
|                 default: |                 default: | ||||||
|                     NGLOG_CRITICAL(HW_GPU, "Unhandled MUFU sub op: {0:x}", |                     NGLOG_CRITICAL(HW_GPU, "Unhandled MUFU sub op: {0:x}", | ||||||
|                                    static_cast<unsigned>(instr.sub_op.Value())); |                                    static_cast<unsigned>(instr.sub_op.Value())); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Subv
						Subv