From 69518bd178ebfaabbafe53080b2fed9797c28dc7 Mon Sep 17 00:00:00 2001 From: Andreas Kling Date: Fri, 13 Nov 2020 11:58:00 +0100 Subject: [PATCH] LibGfx: Fail PPM decode if there's not enough pixel data in the input Fixes #3820. --- Libraries/LibGfx/PPMLoader.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/Libraries/LibGfx/PPMLoader.cpp b/Libraries/LibGfx/PPMLoader.cpp index bb345e18a5..d891821877 100644 --- a/Libraries/LibGfx/PPMLoader.cpp +++ b/Libraries/LibGfx/PPMLoader.cpp @@ -28,6 +28,7 @@ #include #include #include +#include #include #include @@ -266,6 +267,7 @@ static bool read_max_val(PPMLoadingContext& context, Streamer& streamer) static bool read_image_data(PPMLoadingContext& context, Streamer& streamer) { Vector color_data; + color_data.ensure_capacity(context.width * context.height); if (context.type == PPMLoadingContext::P3_ASCII) { u16 red; @@ -303,6 +305,9 @@ static bool read_image_data(PPMLoadingContext& context, Streamer& streamer) } } + if (context.width * context.height != color_data.size()) + return false; + context.bitmap = Bitmap::create_purgeable(BitmapFormat::RGB32, { context.width, context.height }); size_t index = 0; @@ -322,6 +327,10 @@ static bool decode_ppm(PPMLoadingContext& context) if (context.state >= PPMLoadingContext::State::Decoded) return true; + auto error_guard = ArmedScopeGuard([&] { + context.state = PPMLoadingContext::State::Error; + }); + Streamer streamer(context.data, context.data_size); if (!read_magic_number(context, streamer)) @@ -351,6 +360,7 @@ static bool decode_ppm(PPMLoadingContext& context) if (!read_image_data(context, streamer)) return false; + error_guard.disarm(); context.state = PPMLoadingContext::State::Decoded; return true; }