[FFmpeg-cvslog] hevc: make avcodec_decode_video2() fail if get_format() fails

wm4 git at videolan.org
Wed May 20 21:47:10 CEST 2015


ffmpeg | branch: master | wm4 <nfxjfg at googlemail.com> | Thu May 14 19:23:57 2015 +0200| [3efe0393e4f0eaa27bac8833edbd7d3cff4704e1] | committer: Vittorio Giovara

hevc: make avcodec_decode_video2() fail if get_format() fails

Personally, I need the decoder to back out if get_format() returns no
usable pixel format. This didn't work because the error code was not
propagated down the call chain. This in turn happened because the
variable declaration removed in this patch shadowed the variable, whose
value is returned at the end of the function. Consequently, failures of
decode_nal_unit() were ignored in this place.

Reviewed-by:  Andreas Cadhalpun <andreas.cadhalpun at googlemail.com>
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=3efe0393e4f0eaa27bac8833edbd7d3cff4704e1
---

 libavcodec/hevc.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/libavcodec/hevc.c b/libavcodec/hevc.c
index 4c06fb8..1b5e2ed 100644
--- a/libavcodec/hevc.c
+++ b/libavcodec/hevc.c
@@ -2818,7 +2818,7 @@ static int decode_nal_units(HEVCContext *s, const uint8_t *buf, int length)
 
     /* parse the NAL units */
     for (i = 0; i < s->nb_nals; i++) {
-        int ret = decode_nal_unit(s, &s->nals[i]);
+        ret = decode_nal_unit(s, &s->nals[i]);
         if (ret < 0) {
             av_log(s->avctx, AV_LOG_WARNING,
                    "Error parsing NAL unit #%d.\n", i);



More information about the ffmpeg-cvslog mailing list