]> git.sesse.net Git - ffmpeg/commitdiff
avformat/riffenc: correct calculation for extradata size
authorGyan Doshi <ffmpeg@gyani.pro>
Sat, 25 Jul 2020 05:09:32 +0000 (10:39 +0530)
committerGyan Doshi <ffmpeg@gyani.pro>
Sun, 26 Jul 2020 05:39:39 +0000 (11:09 +0530)
In 1ec2b3de5a, the extradata size was affected when the raster was
signaled as flipped due to user-set option rather than via extradata.
This resulted in a wrong header size being written. Fixed.

libavformat/riffenc.c

index d0ee98bfcccaf080ddf717ff93debbafd87abd82..04a21fcffaabc8c4c680d5caa7840b7858072d81 100644 (file)
@@ -209,10 +209,10 @@ int ff_put_wav_header(AVFormatContext *s, AVIOContext *pb,
 void ff_put_bmp_header(AVIOContext *pb, AVCodecParameters *par,
                        int for_asf, int ignore_extradata, int rgb_frame_is_flipped)
 {
-    int keep_height = (par->extradata_size >= 9 &&
-                      !memcmp(par->extradata + par->extradata_size - 9, "BottomUp", 9)) ||
-                      rgb_frame_is_flipped;
-    int extradata_size = par->extradata_size - 9*keep_height;
+    int flipped_extradata = (par->extradata_size >= 9 &&
+                            !memcmp(par->extradata + par->extradata_size - 9, "BottomUp", 9));
+    int keep_height = flipped_extradata || rgb_frame_is_flipped;
+    int extradata_size = par->extradata_size - 9*flipped_extradata;
     enum AVPixelFormat pix_fmt = par->format;
     int pal_avi;