mirror of
https://github.com/minetest/irrlicht.git
synced 2025-01-26 07:51:28 +01:00
Fix checkDataSizeLimit test in png loader.
I thought BitDepth was per pixel back then, but it's per channel. So limit could be broken. git-svn-id: svn://svn.code.sf.net/p/irrlicht/code/trunk@6409 dfc29bdd-3216-0410-991c-e03cc46cb475
This commit is contained in:
parent
338af5c0ea
commit
501185e9cc
@ -143,10 +143,10 @@ IImage* CImageLoaderPng::loadImage(io::IReadFile* file) const
|
|||||||
|
|
||||||
png_read_info(png_ptr, info_ptr); // Read the info section of the png file
|
png_read_info(png_ptr, info_ptr); // Read the info section of the png file
|
||||||
|
|
||||||
u32 Width;
|
u32 Width=0;
|
||||||
u32 Height;
|
u32 Height=0;
|
||||||
s32 BitDepth;
|
s32 BitDepth=0;
|
||||||
s32 ColorType;
|
s32 ColorType=0;
|
||||||
{
|
{
|
||||||
// Use temporary variables to avoid passing cast pointers
|
// Use temporary variables to avoid passing cast pointers
|
||||||
png_uint_32 w,h;
|
png_uint_32 w,h;
|
||||||
@ -158,9 +158,6 @@ IImage* CImageLoaderPng::loadImage(io::IReadFile* file) const
|
|||||||
Height=h;
|
Height=h;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!IImage::checkDataSizeLimit((size_t)Width* Height * (BitDepth/8)))
|
|
||||||
png_cpexcept_error(png_ptr, "Image dimensions too large");
|
|
||||||
|
|
||||||
// Convert palette color to true color
|
// Convert palette color to true color
|
||||||
if (ColorType==PNG_COLOR_TYPE_PALETTE)
|
if (ColorType==PNG_COLOR_TYPE_PALETTE)
|
||||||
png_set_palette_to_rgb(png_ptr);
|
png_set_palette_to_rgb(png_ptr);
|
||||||
@ -223,12 +220,13 @@ IImage* CImageLoaderPng::loadImage(io::IReadFile* file) const
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ECOLOR_FORMAT colorFormat = ColorType==PNG_COLOR_TYPE_RGB_ALPHA ? ECF_A8R8G8B8 : ECF_R8G8B8;
|
||||||
|
|
||||||
|
if (!IImage::checkDataSizeLimit(IImage::getDataSizeFromFormat(colorFormat, Width, Height)))
|
||||||
|
png_cpexcept_error(png_ptr, "Image dimensions too large");
|
||||||
|
|
||||||
// Create the image structure to be filled by png data
|
// Create the image structure to be filled by png data
|
||||||
video::IImage* image = 0;
|
video::IImage* image = new CImage(colorFormat, core::dimension2du(Width, Height));
|
||||||
if (ColorType==PNG_COLOR_TYPE_RGB_ALPHA)
|
|
||||||
image = new CImage(ECF_A8R8G8B8, core::dimension2d<u32>(Width, Height));
|
|
||||||
else
|
|
||||||
image = new CImage(ECF_R8G8B8, core::dimension2d<u32>(Width, Height));
|
|
||||||
if (!image)
|
if (!image)
|
||||||
{
|
{
|
||||||
os::Printer::log("LOAD PNG: Internal PNG create image struct failure\n", file->getFileName(), ELL_ERROR);
|
os::Printer::log("LOAD PNG: Internal PNG create image struct failure\n", file->getFileName(), ELL_ERROR);
|
||||||
|
Loading…
Reference in New Issue
Block a user