forked from eden-emu/eden
		
	Merge pull request #6410 from lat9nq/avoid-oob
decoders: Avoid out-of-bounds access
This commit is contained in:
		
						commit
						df91c9f5e6
					
				
					 1 changed files with 8 additions and 0 deletions
				
			
		|  | @ -63,6 +63,14 @@ void Swizzle(std::span<u8> output, std::span<const u8> input, u32 bytes_per_pixe | ||||||
|                 const u32 unswizzled_offset = |                 const u32 unswizzled_offset = | ||||||
|                     slice * pitch * height + line * pitch + column * bytes_per_pixel; |                     slice * pitch * height + line * pitch + column * bytes_per_pixel; | ||||||
| 
 | 
 | ||||||
|  |                 if (const auto offset = (TO_LINEAR ? unswizzled_offset : swizzled_offset); | ||||||
|  |                     offset >= input.size()) { | ||||||
|  |                     // TODO(Rodrigo): This is an out of bounds access that should never happen. To
 | ||||||
|  |                     // avoid crashing the emulator, break.
 | ||||||
|  |                     ASSERT_MSG(false, "offset {} exceeds input size {}!", offset, input.size()); | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|                 u8* const dst = &output[TO_LINEAR ? swizzled_offset : unswizzled_offset]; |                 u8* const dst = &output[TO_LINEAR ? swizzled_offset : unswizzled_offset]; | ||||||
|                 const u8* const src = &input[TO_LINEAR ? unswizzled_offset : swizzled_offset]; |                 const u8* const src = &input[TO_LINEAR ? unswizzled_offset : swizzled_offset]; | ||||||
|                 std::memcpy(dst, src, bytes_per_pixel); |                 std::memcpy(dst, src, bytes_per_pixel); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei