[FFmpeg-devel] [PATCH] avformat/movenc: Fix writing a sample size of 0 for PCM in MP4

Raphaël Zumer raphael.zumer at vimeo.com
Tue Jul 25 19:28:59 EEST 2023


Encoding PCM in MP4 currently causes subsequent decoding to fail due to a sample size of 0.

Use bits per coded sample instead, which are set correctly based on my tests and allow muxed files to be decoded as expected.

Note: PCM in MP4 muxed with versions of FFmpeg 6.0 and prior (before implementation of the pcmC box) will continue to fail decoding due to the sample size not being available. I see that it was assumed to be 16-bit before commit d4ee17.

Signed-off-by: Raphaël Zumer <rzumer at tebako.net>
---
  libavformat/movenc.c | 2 +-
  1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/libavformat/movenc.c b/libavformat/movenc.c
index f1cc80b1b3..3c44ace5b0 100644
--- a/libavformat/movenc.c
+++ b/libavformat/movenc.c
@@ -1237,7 +1237,7 @@ static int mov_write_pcmc_tag(AVFormatContext *s, AVIOContext *pb, MOVTrack *tra
                      track->par->codec_id == AV_CODEC_ID_PCM_S24LE ||
                      track->par->codec_id == AV_CODEC_ID_PCM_S32LE);
      avio_w8(pb, format_flags);
-    avio_w8(pb, track->par->bits_per_raw_sample);
+    avio_w8(pb, track->par->bits_per_coded_sample);
  
      return update_size(pb, pos);
  }
-- 
2.41.0



More information about the ffmpeg-devel mailing list