forked from eden-emu/eden
		
	Merge pull request #9406 from vonchenplus/topology
video_core: Adjust topology update logic and Adjust Clear Manage
This commit is contained in:
		
						commit
						d6c387db44
					
				
					 4 changed files with 36 additions and 32 deletions
				
			
		|  | @ -46,21 +46,26 @@ void DrawManager::ProcessMethodCall(u32 method, u32 argument) { | |||
|         SetInlineIndexBuffer(regs.inline_index_4x8.index2); | ||||
|         SetInlineIndexBuffer(regs.inline_index_4x8.index3); | ||||
|         break; | ||||
|     case MAXWELL3D_REG_INDEX(topology_override): | ||||
|         use_topology_override = true; | ||||
|     case MAXWELL3D_REG_INDEX(vertex_array_instance_first): | ||||
|     case MAXWELL3D_REG_INDEX(vertex_array_instance_subsequent): { | ||||
|         LOG_WARNING(HW_GPU, "(STUBBED) called"); | ||||
|         break; | ||||
|     } | ||||
|     default: | ||||
|         break; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void DrawManager::Clear(u32 layer_count) { | ||||
|     if (maxwell3d->ShouldExecute()) { | ||||
|         maxwell3d->rasterizer->Clear(layer_count); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void DrawManager::DrawDeferred() { | ||||
|     if (draw_state.draw_mode != DrawMode::Instance || draw_state.instance_count == 0) | ||||
|     if (draw_state.draw_mode != DrawMode::Instance || draw_state.instance_count == 0) { | ||||
|         return; | ||||
|     } | ||||
|     DrawEnd(draw_state.instance_count + 1, true); | ||||
|     draw_state.instance_count = 0; | ||||
| } | ||||
|  | @ -115,8 +120,9 @@ void DrawManager::DrawEnd(u32 instance_count, bool force_draw) { | |||
|     const auto& regs{maxwell3d->regs}; | ||||
|     switch (draw_state.draw_mode) { | ||||
|     case DrawMode::Instance: | ||||
|         if (!force_draw) | ||||
|         if (!force_draw) { | ||||
|             break; | ||||
|         } | ||||
|         [[fallthrough]]; | ||||
|     case DrawMode::General: | ||||
|         draw_state.base_instance = regs.global_base_instance_index; | ||||
|  | @ -156,11 +162,12 @@ void DrawManager::DrawIndexSmall(u32 argument) { | |||
|     ProcessDraw(true, 1); | ||||
| } | ||||
| 
 | ||||
| void DrawManager::ProcessTopologyOverride() { | ||||
|     if (!use_topology_override) | ||||
|         return; | ||||
| 
 | ||||
| void DrawManager::UpdateTopology() { | ||||
|     const auto& regs{maxwell3d->regs}; | ||||
|     switch (regs.primitive_topology_control) { | ||||
|     case PrimitiveTopologyControl::UseInBeginMethods: | ||||
|         break; | ||||
|     case PrimitiveTopologyControl::UseSeparateState: | ||||
|         switch (regs.topology_override) { | ||||
|         case PrimitiveTopologyOverride::None: | ||||
|             break; | ||||
|  | @ -177,15 +184,18 @@ void DrawManager::ProcessTopologyOverride() { | |||
|             draw_state.topology = static_cast<PrimitiveTopology>(regs.topology_override); | ||||
|             break; | ||||
|         } | ||||
|         break; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void DrawManager::ProcessDraw(bool draw_indexed, u32 instance_count) { | ||||
|     LOG_TRACE(HW_GPU, "called, topology={}, count={}", draw_state.topology, | ||||
|               draw_indexed ? draw_state.index_buffer.count : draw_state.vertex_buffer.count); | ||||
| 
 | ||||
|     ProcessTopologyOverride(); | ||||
|     UpdateTopology(); | ||||
| 
 | ||||
|     if (maxwell3d->ShouldExecute()) | ||||
|     if (maxwell3d->ShouldExecute()) { | ||||
|         maxwell3d->rasterizer->Draw(draw_indexed, instance_count); | ||||
|     } | ||||
| } | ||||
| } // namespace Tegra::Engines
 | ||||
|  |  | |||
|  | @ -10,6 +10,7 @@ class RasterizerInterface; | |||
| } | ||||
| 
 | ||||
| namespace Tegra::Engines { | ||||
| using PrimitiveTopologyControl = Maxwell3D::Regs::PrimitiveTopologyControl; | ||||
| using PrimitiveTopology = Maxwell3D::Regs::PrimitiveTopology; | ||||
| using PrimitiveTopologyOverride = Maxwell3D::Regs::PrimitiveTopologyOverride; | ||||
| using IndexBuffer = Maxwell3D::Regs::IndexBuffer; | ||||
|  | @ -58,12 +59,11 @@ private: | |||
| 
 | ||||
|     void DrawIndexSmall(u32 argument); | ||||
| 
 | ||||
|     void ProcessTopologyOverride(); | ||||
|     void UpdateTopology(); | ||||
| 
 | ||||
|     void ProcessDraw(bool draw_indexed, u32 instance_count); | ||||
| 
 | ||||
|     Maxwell3D* maxwell3d{}; | ||||
|     State draw_state{}; | ||||
|     bool use_topology_override{}; | ||||
| }; | ||||
| } // namespace Tegra::Engines
 | ||||
|  |  | |||
|  | @ -138,9 +138,6 @@ void RasterizerOpenGL::LoadDiskResources(u64 title_id, std::stop_token stop_load | |||
| 
 | ||||
| void RasterizerOpenGL::Clear(u32 layer_count) { | ||||
|     MICROPROFILE_SCOPE(OpenGL_Clears); | ||||
|     if (!maxwell3d->ShouldExecute()) { | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     const auto& regs = maxwell3d->regs; | ||||
|     bool use_color{}; | ||||
|  |  | |||
|  | @ -216,9 +216,6 @@ void RasterizerVulkan::Draw(bool is_indexed, u32 instance_count) { | |||
| void RasterizerVulkan::Clear(u32 layer_count) { | ||||
|     MICROPROFILE_SCOPE(Vulkan_Clearing); | ||||
| 
 | ||||
|     if (!maxwell3d->ShouldExecute()) { | ||||
|         return; | ||||
|     } | ||||
|     FlushWork(); | ||||
| 
 | ||||
|     query_cache.UpdateCounters(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei