[FFmpeg-cvslog] png: Be more informative regarding signature errors
Clément Bœsch
u at pkh.me
Wed Aug 5 16:23:46 CEST 2015
On Wed, Aug 05, 2015 at 12:10:56PM +0200, Luca Barbato wrote:
> ffmpeg | branch: master | Luca Barbato <lu_zero at gentoo.org> | Fri Jul 31 14:24:08 2015 +0200| [4fee11ab05fc8569ef35c0ce86a60375c903eefb] | committer: Luca Barbato
>
> png: Be more informative regarding signature errors
>
> Signed-off-by: Luca Barbato <lu_zero at gentoo.org>
>
> > http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=4fee11ab05fc8569ef35c0ce86a60375c903eefb
> ---
>
> libavcodec/pngdec.c | 20 +++++++++++++++++---
> 1 file changed, 17 insertions(+), 3 deletions(-)
>
> diff --git a/libavcodec/pngdec.c b/libavcodec/pngdec.c
> index 4ca919b..5fa7a2d 100644
> --- a/libavcodec/pngdec.c
> +++ b/libavcodec/pngdec.c
> @@ -18,6 +18,8 @@
> * License along with Libav; if not, write to the Free Software
> * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
> */
> +
> +#include "libavutil/avstring.h"
> #include "libavutil/imgutils.h"
> #include "avcodec.h"
> #include "bytestream.h"
> @@ -414,9 +416,21 @@ static int decode_frame(AVCodecContext *avctx,
> int ret;
>
> /* check signature */
> - if (buf_size < 8 ||
> - (memcmp(buf, ff_pngsig, 8) != 0 && memcmp(buf, ff_mngsig, 8) != 0)) {
> - av_log(avctx, AV_LOG_ERROR, "Invalid PNG signature (%d).\n", buf_size);
> + if (buf_size < 8) {
> + av_log(avctx, AV_LOG_ERROR, "Not enough data %d\n",
> + buf_size);
> + return AVERROR_INVALIDDATA;
> + }
> + if (memcmp(buf, ff_pngsig, 8) != 0 &&
> + memcmp(buf, ff_mngsig, 8) != 0) {
> + char signature[5 * 8 + 1] = { 0 };
> + int i;
> + for (i = 0; i < 8; i++) {
> + av_strlcatf(signature + i * 5, sizeof(signature) - i * 5,
> + " 0x%02x", buf[i]);
Unless I'm mistaken you want to either use snprintf, or strlcatf but
without the redundant +i*5 -i*5
> + }
> + av_log(avctx, AV_LOG_ERROR, "Invalid PNG signature %s\n",
> + signature);
> return AVERROR_INVALIDDATA;
> }
>
--
Clément B.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 473 bytes
Desc: not available
URL: <http://ffmpeg.org/pipermail/ffmpeg-cvslog/attachments/20150805/f33e0d35/attachment.sig>
More information about the ffmpeg-cvslog
mailing list