[FFmpeg-devel] [PATCH v1] avformat/mov: get endian format from pcmC

zedong.xzd at gmail.com zedong.xzd at gmail.com
Sun May 29 04:37:30 EEST 2022


From: xiong zedong <zedong.xzd at gmail.com>

Signed-off-by: xiong zedong <zedong.xzd at gmail.com>
---
 libavformat/mov.c | 16 +++++++++++++++-
 1 file changed, 15 insertions(+), 1 deletion(-)

diff --git a/libavformat/mov.c b/libavformat/mov.c
index d7be593a86..a3a79679ad 100644
--- a/libavformat/mov.c
+++ b/libavformat/mov.c
@@ -1552,10 +1552,23 @@ static int mov_read_enda(MOVContext *c, AVIOContext *pb, MOVAtom atom)
         return 0;
     st = c->fc->streams[c->fc->nb_streams-1];
 
-    little_endian = avio_rb16(pb) & 0xFF;
+    /* ISO/IEC 23003-5 Part 5: Uncompressed audio in MPEG-4 file format */
+    if (atom.type == MKTAG('p','c','m','C')) {
+        avio_r8(pb); /* version */
+        avio_rb24(pb); /* flags */
+        little_endian = avio_r8(pb) & 0x01; /* format_flags */
+        avio_r8(pb); /* PCM_sample_size */
+    } else {
+        little_endian = avio_rb16(pb) & 0xFF;
+    }
+
     av_log(c->fc, AV_LOG_TRACE, "enda %d\n", little_endian);
     if (little_endian == 1) {
         switch (st->codecpar->codec_id) {
+        /* for 16 bits in pcmC */
+        case AV_CODEC_ID_PCM_S16BE:
+            st->codecpar->codec_id = AV_CODEC_ID_PCM_S16LE;
+            break;
         case AV_CODEC_ID_PCM_S24BE:
             st->codecpar->codec_id = AV_CODEC_ID_PCM_S24LE;
             break;
@@ -7584,6 +7597,7 @@ static const MOVParseTableEntry mov_default_parse_table[] = {
 { MKTAG('e','d','t','s'), mov_read_default },
 { MKTAG('e','l','s','t'), mov_read_elst },
 { MKTAG('e','n','d','a'), mov_read_enda },
+{ MKTAG('p','c','m','C'), mov_read_enda },
 { MKTAG('f','i','e','l'), mov_read_fiel },
 { MKTAG('a','d','r','m'), mov_read_adrm },
 { MKTAG('f','t','y','p'), mov_read_ftyp },
-- 
2.24.2 (Apple Git-127)



More information about the ffmpeg-devel mailing list