forked from eden-emu/eden
		
	fermi_2d: Fix surface copy block height.
This commit is contained in:
		
							parent
							
								
									634fa4a6ad
								
							
						
					
					
						commit
						f2da134385
					
				
					 2 changed files with 7 additions and 2 deletions
				
			
		|  | @ -59,12 +59,12 @@ void Fermi2D::HandleSurfaceCopy() { | ||||||
|         // If the input is tiled and the output is linear, deswizzle the input and copy it over.
 |         // If the input is tiled and the output is linear, deswizzle the input and copy it over.
 | ||||||
|         Texture::CopySwizzledData(regs.src.width, regs.src.height, src_bytes_per_pixel, |         Texture::CopySwizzledData(regs.src.width, regs.src.height, src_bytes_per_pixel, | ||||||
|                                   dst_bytes_per_pixel, src_buffer, dst_buffer, true, |                                   dst_bytes_per_pixel, src_buffer, dst_buffer, true, | ||||||
|                                   regs.src.block_height); |                                   regs.src.BlockHeight()); | ||||||
|     } else { |     } else { | ||||||
|         // If the input is linear and the output is tiled, swizzle the input and copy it over.
 |         // If the input is linear and the output is tiled, swizzle the input and copy it over.
 | ||||||
|         Texture::CopySwizzledData(regs.src.width, regs.src.height, src_bytes_per_pixel, |         Texture::CopySwizzledData(regs.src.width, regs.src.height, src_bytes_per_pixel, | ||||||
|                                   dst_bytes_per_pixel, dst_buffer, src_buffer, false, |                                   dst_bytes_per_pixel, dst_buffer, src_buffer, false, | ||||||
|                                   regs.dst.block_height); |                                   regs.dst.BlockHeight()); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -49,6 +49,11 @@ public: | ||||||
|                 return static_cast<GPUVAddr>((static_cast<GPUVAddr>(address_high) << 32) | |                 return static_cast<GPUVAddr>((static_cast<GPUVAddr>(address_high) << 32) | | ||||||
|                                              address_low); |                                              address_low); | ||||||
|             } |             } | ||||||
|  | 
 | ||||||
|  |             u32 BlockHeight() const { | ||||||
|  |                 // The block height is stored in log2 format.
 | ||||||
|  |                 return 1 << block_height; | ||||||
|  |             } | ||||||
|         }; |         }; | ||||||
|         static_assert(sizeof(Surface) == 0x28, "Surface has incorrect size"); |         static_assert(sizeof(Surface) == 0x28, "Surface has incorrect size"); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei