Opened 21 months ago

Last modified 20 months ago

#10326 new defect

Possibly invalid restriction for CTTS sample_offset field

Reported by: Robert Swain Owned by:
Priority: normal Component: avformat
Version: git-master Keywords:
Cc: Robert Swain Blocked By:
Blocking: Reproduced by developer: no
Analyzed by developer: no

Description

Summary of the bug:

libavformat/mov.c logs an error for a CTTS box sample_offset that is, as far as I can tell, valid according to the ISO/IEC 14496-12 and Apple specifications.

How to reproduce:

The check is here: https://git.ffmpeg.org/gitweb/ffmpeg.git/blob/refs/heads/master:/libavformat/mov.c#l3322

         if (FFNABS(duration) < -(1<<28) && i+2<entries) {
             av_log(c->fc, AV_LOG_WARNING, "CTTS invalid\n");
             av_freep(&sc->ctts_data);
             sc->ctts_count = 0;
             return 0;
         }

A slightly different form of the check was originally introduced as a fix for https://trac.ffmpeg.org/ticket/385 with the commit message:

commit 4093220029a4d77f272c491e9299680480a08c00
Author: Michael Niedermayer <michael@niedermayer.cc>
Date:   Thu Mar 8 07:10:57 2012 +0100

    mov: Discard invalid CTTS.

    Fixes Ticket385

    Signed-off-by: Michael Niedermayer <michaelni@gmx.at>

There are no comments on the code nor does the commit message nor code explain why the check is correct.

As the Apple specification is publicly and freely available I'll link it here: https://developer.apple.com/library/archive/documentation/QuickTime/QTFF/QTFFChap2/qtff2.html#//apple_ref/doc/uid/TP40000939-CH204-SW19 I wasn't able to find anything in that specification nor in ISO/IEC 14496-12 section 8.6.1.3 about the sample_offset having a reduced range than the data type of the field.

The code enforces that the CTTS box sample_offset (the duration variable in the code in mov.c - also, why is it called duration?) is required to be <= 228. Why is this?

Change History (4)

comment:1 by Robert Swain, 21 months ago

An additional piece of information about the case I encountered in a different file but that I am unable to share - the video track's mdhd box time_scale field has a value of: 2086482457. The largest ctts sample_offset value in this file is 346769080, which is an unsigned value as the ctts box version is 0 in this file. log2(346769080) ~ 28.3694000241 so just over 28 bits.

comment:2 by Balling, 20 months ago

How would you fix that? Please note that STTS was recently made unsigned: 203b0e3561dea1ec459be226d805abe73e7535e5 but not everywhere it is handled, see https://patchwork.ffmpeg.org/project/ffmpeg/patch/20211116141533.1708-1-ffmpeg@gyani.pro/

The muxer should be adjusted to be able to write larger durations in the
stts but that's a larger undertaking which I'll do later.

Last edited 20 months ago by Balling (previous) (diff)

comment:3 by Balling, 20 months ago

Looks related: #8895

apparently CTTS

since it was written with only MP4 in mind, which only has unsigned value in the CTTS box (MOV can have signed values)

comment:4 by Balling, 20 months ago

Log2(346769080) ~ 28.3694000241 so just over 28 bits.

Can you provide that file, please?

Note: See TracTickets for help on using tickets.