forked from eden-emu/eden
		
	Merge pull request #9353 from vonchenplus/draw_indexed
video_core: Fine tuning the index drawing judgment logic
This commit is contained in:
		
						commit
						ac0721a4bc
					
				
					 2 changed files with 22 additions and 27 deletions
				
			
		|  | @ -126,7 +126,6 @@ void Maxwell3D::InitializeRegisterDefaults() { | ||||||
|     draw_command[MAXWELL3D_REG_INDEX(draw_inline_index)] = true; |     draw_command[MAXWELL3D_REG_INDEX(draw_inline_index)] = true; | ||||||
|     draw_command[MAXWELL3D_REG_INDEX(inline_index_2x16.even)] = true; |     draw_command[MAXWELL3D_REG_INDEX(inline_index_2x16.even)] = true; | ||||||
|     draw_command[MAXWELL3D_REG_INDEX(inline_index_4x8.index0)] = true; |     draw_command[MAXWELL3D_REG_INDEX(inline_index_4x8.index0)] = true; | ||||||
|     draw_command[MAXWELL3D_REG_INDEX(draw.instance_id)] = true; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Maxwell3D::ProcessMacro(u32 method, const u32* base_start, u32 amount, bool is_last_call) { | void Maxwell3D::ProcessMacro(u32 method, const u32* base_start, u32 amount, bool is_last_call) { | ||||||
|  | @ -218,16 +217,19 @@ void Maxwell3D::ProcessMethodCall(u32 method, u32 argument, u32 nonshadow_argume | ||||||
|         regs.index_buffer.count = regs.index_buffer32_first.count; |         regs.index_buffer.count = regs.index_buffer32_first.count; | ||||||
|         regs.index_buffer.first = regs.index_buffer32_first.first; |         regs.index_buffer.first = regs.index_buffer32_first.first; | ||||||
|         dirty.flags[VideoCommon::Dirty::IndexBuffer] = true; |         dirty.flags[VideoCommon::Dirty::IndexBuffer] = true; | ||||||
|  |         draw_indexed = true; | ||||||
|         return ProcessDraw(); |         return ProcessDraw(); | ||||||
|     case MAXWELL3D_REG_INDEX(index_buffer16_first): |     case MAXWELL3D_REG_INDEX(index_buffer16_first): | ||||||
|         regs.index_buffer.count = regs.index_buffer16_first.count; |         regs.index_buffer.count = regs.index_buffer16_first.count; | ||||||
|         regs.index_buffer.first = regs.index_buffer16_first.first; |         regs.index_buffer.first = regs.index_buffer16_first.first; | ||||||
|         dirty.flags[VideoCommon::Dirty::IndexBuffer] = true; |         dirty.flags[VideoCommon::Dirty::IndexBuffer] = true; | ||||||
|  |         draw_indexed = true; | ||||||
|         return ProcessDraw(); |         return ProcessDraw(); | ||||||
|     case MAXWELL3D_REG_INDEX(index_buffer8_first): |     case MAXWELL3D_REG_INDEX(index_buffer8_first): | ||||||
|         regs.index_buffer.count = regs.index_buffer8_first.count; |         regs.index_buffer.count = regs.index_buffer8_first.count; | ||||||
|         regs.index_buffer.first = regs.index_buffer8_first.first; |         regs.index_buffer.first = regs.index_buffer8_first.first; | ||||||
|         dirty.flags[VideoCommon::Dirty::IndexBuffer] = true; |         dirty.flags[VideoCommon::Dirty::IndexBuffer] = true; | ||||||
|  |         draw_indexed = true; | ||||||
|         return ProcessDraw(); |         return ProcessDraw(); | ||||||
|     case MAXWELL3D_REG_INDEX(topology_override): |     case MAXWELL3D_REG_INDEX(topology_override): | ||||||
|         use_topology_override = true; |         use_topology_override = true; | ||||||
|  | @ -300,21 +302,33 @@ void Maxwell3D::CallMethod(u32 method, u32 method_argument, bool is_last_call) { | ||||||
|             draw_mode = DrawMode::InlineIndex; |             draw_mode = DrawMode::InlineIndex; | ||||||
|         }; |         }; | ||||||
|         switch (method) { |         switch (method) { | ||||||
|  |         case MAXWELL3D_REG_INDEX(draw.begin): { | ||||||
|  |             draw_mode = | ||||||
|  |                 (regs.draw.instance_id == Maxwell3D::Regs::Draw::InstanceId::Subsequent) || | ||||||
|  |                         (regs.draw.instance_id == Maxwell3D::Regs::Draw::InstanceId::Unchanged) | ||||||
|  |                     ? DrawMode::Instance | ||||||
|  |                     : DrawMode::General; | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|         case MAXWELL3D_REG_INDEX(draw.end): |         case MAXWELL3D_REG_INDEX(draw.end): | ||||||
|             switch (draw_mode) { |             switch (draw_mode) { | ||||||
|             case DrawMode::General: |             case DrawMode::General: | ||||||
|                 ProcessDraw(1); |                 ProcessDraw(); | ||||||
|                 break; |                 break; | ||||||
|             case DrawMode::InlineIndex: |             case DrawMode::InlineIndex: | ||||||
|                 regs.index_buffer.count = static_cast<u32>(inline_index_draw_indexes.size() / 4); |                 regs.index_buffer.count = static_cast<u32>(inline_index_draw_indexes.size() / 4); | ||||||
|                 regs.index_buffer.format = Regs::IndexFormat::UnsignedInt; |                 regs.index_buffer.format = Regs::IndexFormat::UnsignedInt; | ||||||
|                 ProcessDraw(1); |                 draw_indexed = true; | ||||||
|  |                 ProcessDraw(); | ||||||
|                 inline_index_draw_indexes.clear(); |                 inline_index_draw_indexes.clear(); | ||||||
|                 break; |                 break; | ||||||
|             case DrawMode::Instance: |             case DrawMode::Instance: | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|             break; |             break; | ||||||
|  |         case MAXWELL3D_REG_INDEX(index_buffer.count): | ||||||
|  |             draw_indexed = true; | ||||||
|  |             break; | ||||||
|         case MAXWELL3D_REG_INDEX(draw_inline_index): |         case MAXWELL3D_REG_INDEX(draw_inline_index): | ||||||
|             update_inline_index(method_argument); |             update_inline_index(method_argument); | ||||||
|             break; |             break; | ||||||
|  | @ -328,13 +342,6 @@ void Maxwell3D::CallMethod(u32 method, u32 method_argument, bool is_last_call) { | ||||||
|             update_inline_index(regs.inline_index_4x8.index2); |             update_inline_index(regs.inline_index_4x8.index2); | ||||||
|             update_inline_index(regs.inline_index_4x8.index3); |             update_inline_index(regs.inline_index_4x8.index3); | ||||||
|             break; |             break; | ||||||
|         case MAXWELL3D_REG_INDEX(draw.instance_id): |  | ||||||
|             draw_mode = |  | ||||||
|                 (regs.draw.instance_id == Maxwell3D::Regs::Draw::InstanceId::Subsequent) || |  | ||||||
|                         (regs.draw.instance_id == Maxwell3D::Regs::Draw::InstanceId::Unchanged) |  | ||||||
|                     ? DrawMode::Instance |  | ||||||
|                     : DrawMode::General; |  | ||||||
|             break; |  | ||||||
|         } |         } | ||||||
|     } else { |     } else { | ||||||
|         ProcessDeferredDraw(); |         ProcessDeferredDraw(); | ||||||
|  | @ -624,27 +631,16 @@ void Maxwell3D::ProcessClearBuffers(u32 layer_count) { | ||||||
| 
 | 
 | ||||||
| void Maxwell3D::ProcessDraw(u32 instance_count) { | void Maxwell3D::ProcessDraw(u32 instance_count) { | ||||||
|     LOG_TRACE(HW_GPU, "called, topology={}, count={}", regs.draw.topology.Value(), |     LOG_TRACE(HW_GPU, "called, topology={}, count={}", regs.draw.topology.Value(), | ||||||
|               regs.vertex_buffer.count); |               draw_indexed ? regs.index_buffer.count : regs.vertex_buffer.count); | ||||||
| 
 |  | ||||||
|     ASSERT_MSG(!(regs.index_buffer.count && regs.vertex_buffer.count), "Both indexed and direct?"); |  | ||||||
| 
 |  | ||||||
|     // Both instance configuration registers can not be set at the same time.
 |  | ||||||
|     ASSERT_MSG(regs.draw.instance_id == Maxwell3D::Regs::Draw::InstanceId::First || |  | ||||||
|                    regs.draw.instance_id != Maxwell3D::Regs::Draw::InstanceId::Unchanged, |  | ||||||
|                "Illegal combination of instancing parameters"); |  | ||||||
| 
 | 
 | ||||||
|     ProcessTopologyOverride(); |     ProcessTopologyOverride(); | ||||||
| 
 | 
 | ||||||
|     const bool is_indexed = regs.index_buffer.count && !regs.vertex_buffer.count; |  | ||||||
|     if (ShouldExecute()) { |     if (ShouldExecute()) { | ||||||
|         rasterizer->Draw(is_indexed, instance_count); |         rasterizer->Draw(draw_indexed, instance_count); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (is_indexed) { |     draw_indexed = false; | ||||||
|         regs.index_buffer.count = 0; |     deferred_draw_method.clear(); | ||||||
|     } else { |  | ||||||
|         regs.vertex_buffer.count = 0; |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Maxwell3D::ProcessDeferredDraw() { | void Maxwell3D::ProcessDeferredDraw() { | ||||||
|  | @ -667,8 +663,6 @@ void Maxwell3D::ProcessDeferredDraw() { | ||||||
|     ASSERT_MSG(!(vertex_buffer_count && index_buffer_count), "Instance both indexed and direct?"); |     ASSERT_MSG(!(vertex_buffer_count && index_buffer_count), "Instance both indexed and direct?"); | ||||||
| 
 | 
 | ||||||
|     ProcessDraw(instance_count); |     ProcessDraw(instance_count); | ||||||
| 
 |  | ||||||
|     deferred_draw_method.clear(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } // namespace Tegra::Engines
 | } // namespace Tegra::Engines
 | ||||||
|  |  | ||||||
|  | @ -3159,6 +3159,7 @@ private: | ||||||
|     std::vector<u32> deferred_draw_method; |     std::vector<u32> deferred_draw_method; | ||||||
|     enum class DrawMode : u32 { General = 0, Instance, InlineIndex }; |     enum class DrawMode : u32 { General = 0, Instance, InlineIndex }; | ||||||
|     DrawMode draw_mode{DrawMode::General}; |     DrawMode draw_mode{DrawMode::General}; | ||||||
|  |     bool draw_indexed{}; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| #define ASSERT_REG_POSITION(field_name, position)                                                  \ | #define ASSERT_REG_POSITION(field_name, position)                                                  \ | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 liamwhite
						liamwhite