forked from eden-emu/eden
		
	shader: Address feedback
This commit is contained in:
		
							parent
							
								
									b85c9d8e84
								
							
						
					
					
						commit
						4a97dd4483
					
				
					 2 changed files with 10 additions and 7 deletions
				
			
		|  | @ -184,16 +184,19 @@ void TranslatorVisitor::F2F_imm([[maybe_unused]] u64 insn) { | ||||||
|         BitField<49, 1, u64> abs; |         BitField<49, 1, u64> abs; | ||||||
|         BitField<10, 2, FloatFormat> src_size; |         BitField<10, 2, FloatFormat> src_size; | ||||||
|         BitField<41, 1, u64> selector; |         BitField<41, 1, u64> selector; | ||||||
|         BitField<20, 20, u64> imm; |         BitField<20, 19, u64> imm; | ||||||
| 
 |         BitField<56, 1, u64> imm_neg; | ||||||
|     } const f2f{insn}; |     } const f2f{insn}; | ||||||
| 
 | 
 | ||||||
|     IR::F16F32F64 src_a; |     IR::F16F32F64 src_a; | ||||||
|     switch (f2f.src_size) { |     switch (f2f.src_size) { | ||||||
|     case FloatFormat::F16: { |     case FloatFormat::F16: { | ||||||
|         const u32 imm{static_cast<u32>(f2f.imm & 0x00ffff)}; |         const u32 imm{static_cast<u32>(f2f.imm & 0x0000ffff)}; | ||||||
|         IR::Value vector{ir.UnpackFloat2x16(ir.Imm32(imm | (imm << 16)))}; |         const IR::Value vector{ir.UnpackFloat2x16(ir.Imm32(imm | (imm << 16)))}; | ||||||
|         src_a = IR::F16{ir.CompositeExtract(vector, 0)}; |         src_a = IR::F16{ir.CompositeExtract(vector, f2f.selector != 0 ? 0 : 1)}; | ||||||
|  |         if (f2f.imm_neg != 0) { | ||||||
|  |             throw NotImplementedException("Neg bit on F16"); | ||||||
|  |         } | ||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|     case FloatFormat::F32: |     case FloatFormat::F32: | ||||||
|  | @ -206,6 +209,6 @@ void TranslatorVisitor::F2F_imm([[maybe_unused]] u64 insn) { | ||||||
|         throw NotImplementedException("Invalid dest format {}", f2f.src_size.Value()); |         throw NotImplementedException("Invalid dest format {}", f2f.src_size.Value()); | ||||||
|     } |     } | ||||||
|     F2F(*this, insn, src_a, f2f.abs != 0); |     F2F(*this, insn, src_a, f2f.abs != 0); | ||||||
| } // namespace Shader::Maxwell
 | } | ||||||
| 
 | 
 | ||||||
| } // namespace Shader::Maxwell
 | } // namespace Shader::Maxwell
 | ||||||
|  |  | ||||||
|  | @ -83,7 +83,7 @@ void IADD3(TranslatorVisitor& v, u64 insn, IR::U32 op_b, IR::U32 op_c) { | ||||||
|         lhs = v.ir.IAdd(lhs, carry); |         lhs = v.ir.IAdd(lhs, carry); | ||||||
|     } |     } | ||||||
|     if (iadd3.cc != 0 && iadd3.shift == Shift::Left) { |     if (iadd3.cc != 0 && iadd3.shift == Shift::Left) { | ||||||
|         IR::U32 high_bits{v.ir.ShiftRightLogical(lhs, v.ir.Imm32(16))}; |         const IR::U32 high_bits{v.ir.ShiftRightLogical(lhs, v.ir.Imm32(16))}; | ||||||
|         of_1 = v.ir.LogicalOr(of_1, v.ir.INotEqual(v.ir.Imm32(0), high_bits)); |         of_1 = v.ir.LogicalOr(of_1, v.ir.INotEqual(v.ir.Imm32(0), high_bits)); | ||||||
|     } |     } | ||||||
|     lhs = IntegerShift(v.ir, lhs, iadd3.shift); |     lhs = IntegerShift(v.ir, lhs, iadd3.shift); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 FernandoS27
						FernandoS27