forked from eden-emu/eden
		
	Merge pull request #1648 from FernandoS27/texs-3-array
Implement 3 coordinate array in TEXS instruction
This commit is contained in:
		
						commit
						1916213311
					
				
					 1 changed files with 11 additions and 7 deletions
				
			
		|  | @ -2742,12 +2742,12 @@ private: | ||||||
|                 } |                 } | ||||||
|                 case 3: { |                 case 3: { | ||||||
|                     if (is_array) { |                     if (is_array) { | ||||||
|                         UNIMPLEMENTED_MSG("3-coordinate arrays not fully implemented"); |                         const std::string index = regs.GetRegisterAsInteger(instr.gpr8); | ||||||
|                         const std::string x = regs.GetRegisterAsFloat(instr.gpr8); |                         const std::string x = regs.GetRegisterAsFloat(instr.gpr8.Value() + 1); | ||||||
|                         const std::string y = regs.GetRegisterAsFloat(instr.gpr20); |                         const std::string y = regs.GetRegisterAsFloat(instr.gpr8.Value() + 2); | ||||||
|                         coord = "vec2 coords = vec2(" + x + ", " + y + ");"; |                         const std::string z = regs.GetRegisterAsFloat(instr.gpr20); | ||||||
|                         texture_type = Tegra::Shader::TextureType::Texture2D; |                         coord = | ||||||
|                         is_array = false; |                             "vec4 coords = vec4(" + x + ", " + y + ", " + z + ", " + index + ");"; | ||||||
|                     } else { |                     } else { | ||||||
|                         const std::string x = regs.GetRegisterAsFloat(instr.gpr8); |                         const std::string x = regs.GetRegisterAsFloat(instr.gpr8); | ||||||
|                         const std::string y = regs.GetRegisterAsFloat(instr.gpr8.Value() + 1); |                         const std::string y = regs.GetRegisterAsFloat(instr.gpr8.Value() + 1); | ||||||
|  | @ -2777,7 +2777,11 @@ private: | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 case Tegra::Shader::TextureProcessMode::LZ: { |                 case Tegra::Shader::TextureProcessMode::LZ: { | ||||||
|  |                     if (depth_compare && is_array) { | ||||||
|  |                         texture = "texture(" + sampler + ", coords)"; | ||||||
|  |                     } else { | ||||||
|                         texture = "textureLod(" + sampler + ", coords, 0.0)"; |                         texture = "textureLod(" + sampler + ", coords, 0.0)"; | ||||||
|  |                     } | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 case Tegra::Shader::TextureProcessMode::LL: { |                 case Tegra::Shader::TextureProcessMode::LL: { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei