forked from eden-emu/eden
		
	Merge pull request #1010 from bunnei/unk-vert-attrib-shader
gl_shader_decompiler: Improve handling of unknown input/output attributes.
This commit is contained in:
		
						commit
						403dfd68fc
					
				
					 2 changed files with 11 additions and 10 deletions
				
			
		|  | @ -74,12 +74,11 @@ union Attribute { | |||
|     enum class Index : u64 { | ||||
|         Position = 7, | ||||
|         Attribute_0 = 8, | ||||
|         Attribute_31 = 39, | ||||
|         // This attribute contains a tuple of (~, ~, InstanceId, VertexId) when inside a vertex
 | ||||
|         // shader, and a tuple of (TessCoord.x, TessCoord.y, TessCoord.z, ~) when inside a Tess Eval
 | ||||
|         // shader.
 | ||||
|         TessCoordInstanceIDVertexID = 47, | ||||
|         // TODO(bunnei): Figure out what this is used for. Super Mario Odyssey uses this.
 | ||||
|         Unknown_63 = 63, | ||||
|     }; | ||||
| 
 | ||||
|     union { | ||||
|  |  | |||
|  | @ -358,8 +358,13 @@ public: | |||
|     void SetOutputAttributeToRegister(Attribute::Index attribute, u64 elem, const Register& reg) { | ||||
|         std::string dest = GetOutputAttribute(attribute) + GetSwizzle(elem); | ||||
|         std::string src = GetRegisterAsFloat(reg); | ||||
| 
 | ||||
|         if (!dest.empty()) { | ||||
|             // Can happen with unknown/unimplemented output attributes, in which case we ignore the
 | ||||
|             // instruction for now.
 | ||||
|             shader.AddLine(dest + " = " + src + ';'); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /// Generates code representing a uniform (C buffer) register, interpreted as the input type.
 | ||||
|     std::string GetUniform(u64 index, u64 offset, GLSLRegister::Type type) { | ||||
|  | @ -534,20 +539,16 @@ private: | |||
|             // shader.
 | ||||
|             ASSERT(stage == Maxwell3D::Regs::ShaderStage::Vertex); | ||||
|             return "vec4(0, 0, uintBitsToFloat(gl_InstanceID), uintBitsToFloat(gl_VertexID))"; | ||||
|         case Attribute::Index::Unknown_63: | ||||
|             // TODO(bunnei): Figure out what this is used for. Super Mario Odyssey uses this.
 | ||||
|             LOG_CRITICAL(HW_GPU, "Unhandled input attribute Unknown_63"); | ||||
|             UNREACHABLE(); | ||||
|             break; | ||||
|         default: | ||||
|             const u32 index{static_cast<u32>(attribute) - | ||||
|                             static_cast<u32>(Attribute::Index::Attribute_0)}; | ||||
|             if (attribute >= Attribute::Index::Attribute_0) { | ||||
|             if (attribute >= Attribute::Index::Attribute_0 && | ||||
|                 attribute <= Attribute::Index::Attribute_31) { | ||||
|                 declr_input_attribute.insert(attribute); | ||||
|                 return "input_attribute_" + std::to_string(index); | ||||
|             } | ||||
| 
 | ||||
|             LOG_CRITICAL(HW_GPU, "Unhandled input attribute: {}", index); | ||||
|             LOG_CRITICAL(HW_GPU, "Unhandled input attribute: {}", static_cast<u32>(attribute)); | ||||
|             UNREACHABLE(); | ||||
|         } | ||||
| 
 | ||||
|  | @ -569,6 +570,7 @@ private: | |||
| 
 | ||||
|             LOG_CRITICAL(HW_GPU, "Unhandled output attribute: {}", index); | ||||
|             UNREACHABLE(); | ||||
|             return {}; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei