forked from eden-emu/eden
		
	Merge pull request #1214 from ogniK5377/ipa-assert
Added better asserts to IPA, Renamed IPA modes to match mesa
This commit is contained in:
		
						commit
						106579cde4
					
				
					 2 changed files with 13 additions and 6 deletions
				
			
		|  | @ -243,7 +243,8 @@ enum class TextureType : u64 { | ||||||
|     TextureCube = 3, |     TextureCube = 3, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| enum class IpaMode : u64 { Pass = 0, None = 1, Constant = 2, Sc = 3 }; | enum class IpaInterpMode : u64 { Linear = 0, Perspective = 1, Flat = 2, Sc = 3 }; | ||||||
|  | enum class IpaSampleMode : u64 { Default = 0, Centroid = 1, Offset = 2 }; | ||||||
| 
 | 
 | ||||||
| union Instruction { | union Instruction { | ||||||
|     Instruction& operator=(const Instruction& instr) { |     Instruction& operator=(const Instruction& instr) { | ||||||
|  | @ -328,7 +329,9 @@ union Instruction { | ||||||
|     } alu; |     } alu; | ||||||
| 
 | 
 | ||||||
|     union { |     union { | ||||||
|         BitField<54, 3, IpaMode> mode; |         BitField<51, 1, u64> saturate; | ||||||
|  |         BitField<52, 2, IpaSampleMode> sample_mode; | ||||||
|  |         BitField<54, 2, IpaInterpMode> interp_mode; | ||||||
|     } ipa; |     } ipa; | ||||||
| 
 | 
 | ||||||
|     union { |     union { | ||||||
|  |  | ||||||
|  | @ -2125,8 +2125,12 @@ private: | ||||||
|             case OpCode::Id::IPA: { |             case OpCode::Id::IPA: { | ||||||
|                 const auto& attribute = instr.attribute.fmt28; |                 const auto& attribute = instr.attribute.fmt28; | ||||||
|                 const auto& reg = instr.gpr0; |                 const auto& reg = instr.gpr0; | ||||||
|                 switch (instr.ipa.mode) { |                 ASSERT_MSG(instr.ipa.sample_mode == Tegra::Shader::IpaSampleMode::Default, | ||||||
|                 case Tegra::Shader::IpaMode::Pass: |                            "Unhandled IPA sample mode: {}", | ||||||
|  |                            static_cast<u32>(instr.ipa.sample_mode.Value())); | ||||||
|  |                 ASSERT_MSG(instr.ipa.saturate == 0, "IPA saturate not implemented"); | ||||||
|  |                 switch (instr.ipa.interp_mode) { | ||||||
|  |                 case Tegra::Shader::IpaInterpMode::Linear: | ||||||
|                     if (stage == Maxwell3D::Regs::ShaderStage::Fragment && |                     if (stage == Maxwell3D::Regs::ShaderStage::Fragment && | ||||||
|                         attribute.index == Attribute::Index::Position) { |                         attribute.index == Attribute::Index::Position) { | ||||||
|                         switch (attribute.element) { |                         switch (attribute.element) { | ||||||
|  | @ -2147,12 +2151,12 @@ private: | ||||||
|                         regs.SetRegisterToInputAttibute(reg, attribute.element, attribute.index); |                         regs.SetRegisterToInputAttibute(reg, attribute.element, attribute.index); | ||||||
|                     } |                     } | ||||||
|                     break; |                     break; | ||||||
|                 case Tegra::Shader::IpaMode::None: |                 case Tegra::Shader::IpaInterpMode::Perspective: | ||||||
|                     regs.SetRegisterToInputAttibute(reg, attribute.element, attribute.index); |                     regs.SetRegisterToInputAttibute(reg, attribute.element, attribute.index); | ||||||
|                     break; |                     break; | ||||||
|                 default: |                 default: | ||||||
|                     LOG_CRITICAL(HW_GPU, "Unhandled IPA mode: {}", |                     LOG_CRITICAL(HW_GPU, "Unhandled IPA mode: {}", | ||||||
|                                  static_cast<u32>(instr.ipa.mode.Value())); |                                  static_cast<u32>(instr.ipa.interp_mode.Value())); | ||||||
|                     UNREACHABLE(); |                     UNREACHABLE(); | ||||||
|                     regs.SetRegisterToInputAttibute(reg, attribute.element, attribute.index); |                     regs.SetRegisterToInputAttibute(reg, attribute.element, attribute.index); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei