mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-04-20 11:36:13 +00:00
cellPngDec: Ignore bytesPerLine < width * bpp.
It seems strange, but Sonic CD passes bytesPerLine = w * 3 for a 4 channel image. Either this is a bug elsewhere, or it ignores likely incorrect strides. Untested except in Sonic CD.
This commit is contained in:
parent
0e3e4c7553
commit
fed2998d48
1 changed files with 2 additions and 2 deletions
|
@ -182,7 +182,7 @@ int cellPngDecDecodeData(u32 mainHandle, u32 subHandle, mem8_ptr_t data, const m
|
|||
{
|
||||
const char nComponents = current_outParam.outputColorSpace == CELL_PNGDEC_RGBA ? 4 : 3;
|
||||
image_size *= nComponents;
|
||||
if (bytesPerLine != width * nComponents || flip) //check if we need padding
|
||||
if (bytesPerLine > width * nComponents || flip) //check if we need padding
|
||||
{
|
||||
const int linesize = std::min(bytesPerLine, width * nComponents);
|
||||
for (int i = 0; i < height; i++)
|
||||
|
@ -203,7 +203,7 @@ int cellPngDecDecodeData(u32 mainHandle, u32 subHandle, mem8_ptr_t data, const m
|
|||
{
|
||||
const char nComponents = 4;
|
||||
image_size *= nComponents;
|
||||
if (bytesPerLine != width * nComponents || flip) //check if we need padding
|
||||
if (bytesPerLine > width * nComponents || flip) //check if we need padding
|
||||
{
|
||||
//TODO: find out if we can't do padding without an extra copy
|
||||
const int linesize = std::min(bytesPerLine, width * nComponents);
|
||||
|
|
Loading…
Add table
Reference in a new issue