• Alex Sukhanov's avatar
    af_aresample: Fix timestamp of first padded PCM audio packet · 86b3435f
    Alex Sukhanov authored
    Problem:
    ffmpeg generated video file which had two audio packets with the same timestamp: last original audio packet and first padded audio packet.
    
    Timestamp of first added audio packet by 'apad' fitler had the same value as last original audio packet. The problem was in 'aresample' fitler, which used next pts instead of current one.
    As long as 'apad' and 'aresample' filters have separate mechanisms of timestamp calculation, they got the same values.
    
    Command line:
    ffmpeg -i <input_filename> -shortest -apad 512 -af asetnsamples=n=512 -b:a 1058400 -ac 1 -ar 44100 -async 0 -acodec pcm_s16le -sn -f matroska -y <output_file>
    
    Fix:
    Call swr_next_pts() function before swr_convert()
    
    Tested:
    FATE tests passed.
    Fix has been tested in our Transcoder regression framework on ~10k test videos. It's about ~500k transcodes.
    Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
    86b3435f
af_aresample.c 10.2 KB