forked from eden-emu/eden
		
	DMA & InlineToMemory Engines Rework.
This commit is contained in:
		
							parent
							
								
									b2099fbdcc
								
							
						
					
					
						commit
						f5fd6b5c86
					
				
					 21 changed files with 323 additions and 242 deletions
				
			
		|  | @ -3,6 +3,7 @@ | |||
| 
 | ||||
| #include <cstring> | ||||
| 
 | ||||
| #include "common/algorithm.h" | ||||
| #include "common/assert.h" | ||||
| #include "video_core/engines/engine_upload.h" | ||||
| #include "video_core/memory_manager.h" | ||||
|  | @ -34,21 +35,48 @@ void State::ProcessData(const u32 data, const bool is_last_call) { | |||
|     if (!is_last_call) { | ||||
|         return; | ||||
|     } | ||||
|     ProcessData(inner_buffer); | ||||
| } | ||||
| 
 | ||||
| void State::ProcessData(const u32* data, size_t num_data) { | ||||
|     std::span<const u8> read_buffer(reinterpret_cast<const u8*>(data), num_data * sizeof(u32)); | ||||
|     ProcessData(read_buffer); | ||||
| } | ||||
| 
 | ||||
| void State::ProcessData(std::span<const u8> read_buffer) { | ||||
|     const GPUVAddr address{regs.dest.Address()}; | ||||
|     if (is_linear) { | ||||
|         rasterizer->AccelerateInlineToMemory(address, copy_size, inner_buffer); | ||||
|         if (regs.line_count == 1) { | ||||
|             rasterizer->AccelerateInlineToMemory(address, copy_size, read_buffer); | ||||
|         } else { | ||||
|             for (u32 line = 0; line < regs.line_count; ++line) { | ||||
|                 const GPUVAddr dest_line = address + static_cast<size_t>(line) * regs.dest.pitch; | ||||
|                 memory_manager.WriteBlockUnsafe( | ||||
|                     dest_line, read_buffer.data() + static_cast<size_t>(line) * regs.line_length_in, | ||||
|                     regs.line_length_in); | ||||
|             } | ||||
|             memory_manager.InvalidateRegion(address, regs.dest.pitch * regs.line_count); | ||||
|         } | ||||
|     } else { | ||||
|         UNIMPLEMENTED_IF(regs.dest.z != 0); | ||||
|         UNIMPLEMENTED_IF(regs.dest.depth != 1); | ||||
|         UNIMPLEMENTED_IF(regs.dest.BlockWidth() != 0); | ||||
|         UNIMPLEMENTED_IF(regs.dest.BlockDepth() != 0); | ||||
|         u32 width = regs.dest.width; | ||||
|         u32 x_elements = regs.line_length_in; | ||||
|         u32 x_offset = regs.dest.x; | ||||
|         const u32 bpp_shift = Common::FoldRight( | ||||
|             4U, [](u32 x, u32 y) { return std::min(x, static_cast<u32>(std::countr_zero(y))); }, | ||||
|             width, x_elements, x_offset, static_cast<u32>(address)); | ||||
|         width >>= bpp_shift; | ||||
|         x_elements >>= bpp_shift; | ||||
|         x_offset >>= bpp_shift; | ||||
|         const u32 bytes_per_pixel = 1U << bpp_shift; | ||||
|         const std::size_t dst_size = Tegra::Texture::CalculateSize( | ||||
|             true, 1, regs.dest.width, regs.dest.height, 1, regs.dest.BlockHeight(), 0); | ||||
|             true, bytes_per_pixel, width, regs.dest.height, regs.dest.depth, | ||||
|             regs.dest.BlockHeight(), regs.dest.BlockDepth()); | ||||
|         tmp_buffer.resize(dst_size); | ||||
|         memory_manager.ReadBlock(address, tmp_buffer.data(), dst_size); | ||||
|         Tegra::Texture::SwizzleKepler(regs.dest.width, regs.dest.height, regs.dest.x, regs.dest.y, | ||||
|                                       regs.dest.BlockHeight(), copy_size, inner_buffer.data(), | ||||
|                                       tmp_buffer.data()); | ||||
|         Tegra::Texture::SwizzleSubrect(tmp_buffer, read_buffer, bytes_per_pixel, width, | ||||
|                                        regs.dest.height, regs.dest.depth, x_offset, regs.dest.y, | ||||
|                                        x_elements, regs.line_count, regs.dest.BlockHeight(), | ||||
|                                        regs.dest.BlockDepth(), regs.line_length_in); | ||||
|         memory_manager.WriteBlock(address, tmp_buffer.data(), dst_size); | ||||
|     } | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei