mirror of
				https://github.com/PabloMK7/citra.git
				synced 2025-10-31 13:50:03 +00:00 
			
		
		
		
	Shader Disassembly: Fix printing of jump offsets
This commit is contained in:
		
							parent
							
								
									3194f40e96
								
							
						
					
					
						commit
						8540e02176
					
				
					 1 changed files with 4 additions and 4 deletions
				
			
		|  | @ -104,7 +104,7 @@ QVariant GraphicsVertexShaderModel::data(const QModelIndex& index, int role) con | ||||||
|         case 2: |         case 2: | ||||||
|         { |         { | ||||||
|             std::ostringstream output; |             std::ostringstream output; | ||||||
|             output.flags(std::ios::hex | std::ios::uppercase); |             output.flags(std::ios::uppercase); | ||||||
| 
 | 
 | ||||||
|             // To make the code aligning columns of assembly easier to keep track of, this function
 |             // To make the code aligning columns of assembly easier to keep track of, this function
 | ||||||
|             // keeps track of the start of the start of the previous column, allowing alignment
 |             // keeps track of the start of the start of the previous column, allowing alignment
 | ||||||
|  | @ -264,16 +264,16 @@ QVariant GraphicsVertexShaderModel::data(const QModelIndex& index, int role) con | ||||||
|                     u32 target_addr_else = instr.flow_control.dest_offset; |                     u32 target_addr_else = instr.flow_control.dest_offset; | ||||||
| 
 | 
 | ||||||
|                     if (opcode_info.subtype & OpCode::Info::HasAlternative) { |                     if (opcode_info.subtype & OpCode::Info::HasAlternative) { | ||||||
|                         output << "else jump to 0x" << std::setw(4) << std::right << std::setfill('0') << (4 * instr.flow_control.dest_offset); |                         output << "else jump to 0x" << std::setw(4) << std::right << std::setfill('0') << std::hex << (4 * instr.flow_control.dest_offset); | ||||||
|                     } else if (opcode_info.subtype & OpCode::Info::HasExplicitDest) { |                     } else if (opcode_info.subtype & OpCode::Info::HasExplicitDest) { | ||||||
|                         output << "jump to 0x" << std::setw(4) << std::right << std::setfill('0') << (4 * instr.flow_control.dest_offset); |                         output << "jump to 0x" << std::setw(4) << std::right << std::setfill('0') << std::hex << (4 * instr.flow_control.dest_offset); | ||||||
|                     } else { |                     } else { | ||||||
|                         // TODO: Handle other cases
 |                         // TODO: Handle other cases
 | ||||||
|                         output << "(unknown destination)"; |                         output << "(unknown destination)"; | ||||||
|                     } |                     } | ||||||
| 
 | 
 | ||||||
|                     if (opcode_info.subtype & OpCode::Info::HasFinishPoint) { |                     if (opcode_info.subtype & OpCode::Info::HasFinishPoint) { | ||||||
|                         output << " (return on " << std::setw(4) << std::right << std::setfill('0') |                         output << " (return on 0x" << std::setw(4) << std::right << std::setfill('0') << std::hex | ||||||
|                                << (4 * instr.flow_control.dest_offset + 4 * instr.flow_control.num_instructions) << ')'; |                                << (4 * instr.flow_control.dest_offset + 4 * instr.flow_control.num_instructions) << ')'; | ||||||
|                     } |                     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue