[FFmpeg-user] way to reencode corrupted video

Richard Bartczak richard.bartczak at gmx.de
Wed Feb 26 01:10:54 EET 2025


There are fatal errors in the stream.

I did check it with a script (Linux) :

---

frame=    8 fps=0.0 q=40.0 size=       0kB time=00:00:01.13 bitrate=  
0.0kbits/s dup=21 drop=0 speed=12.8x
frame=   26 fps=0.0 q=49.0 size=       0kB time=00:00:01.83 bitrate=  
0.0kbits/s dup=21 drop=0 speed=3.07x
frame=   69 fps= 62 q=49.0 size=       0kB time=00:00:03.56 bitrate=  
0.0kbits/s dup=21 drop=0 speed=3.18x
frame=  120 fps= 74 q=50.0 size=       0kB time=00:00:05.61 bitrate=  
0.0kbits/s dup=21 drop=0 speed=3.46x
frame=  167 fps= 79 q=49.0 size=       0kB time=00:00:07.48 bitrate=  
0.0kbits/s dup=21 drop=0 speed=3.52x
frame=  209 fps= 79 q=49.0 size=       0kB time=00:00:09.15 bitrate=  
0.0kbits/s dup=21 drop=0 speed=3.46x
frame=  260 fps= 83 q=48.0 size=     368kB time=00:00:11.20 bitrate=
269.2kbits/s dup=21 drop=0 speed=3.56x
frame=  309 fps= 84 q=49.0 size=     368kB time=00:00:13.16 bitrate=
229.1kbits/s dup=21 drop=0 speed=3.58x
frame=  354 fps= 85 q=49.0 size=     368kB time=00:00:14.95 bitrate=
201.6kbits/s dup=21 drop=0 speed=3.58x
[h264 @ 0x574eb5937540] cabac decode of qscale diff failed at 59 6
[h264 @ 0x574eb5937540] error while decoding MB 59 6, bytestream 77049
[h264 @ 0x574eb5937540] concealing 7430 DC, 7430 AC, 7430 MV errors in P
frame
[NULL @ 0x574eb57c9700] Invalid NAL unit size (60897492 > 110161).
[NULL @ 0x574eb57c9700] missing picture in access unit with size 110165
[h264 @ 0x574eb594b680] Invalid NAL unit size (60897492 > 110161).
[h264 @ 0x574eb594b680] Error splitting the input into NAL units.
[NULL @ 0x574eb57c9700] Invalid NAL unit size (-1600997495 > 84591).
[NULL @ 0x574eb57c9700] missing picture in access unit with size 84595
[NULL @ 0x574eb57c9700] Invalid NAL unit size (1695808648 > 76726).
[NULL @ 0x574eb57c9700] missing picture in access unit with size 76730
[h264 @ 0x574eb588c480] Invalid NAL unit size (-1600997495 > 84591).
[h264 @ 0x574eb588c480] Error splitting the input into NAL units.
[h264 @ 0x574eb58a0380] Invalid NAL unit size (1695808648 > 76726).
[h264 @ 0x574eb58a0380] Error splitting the input into NAL units.
[NULL @ 0x574eb57c9700] Invalid NAL unit size (540206825 > 109538).
[NULL @ 0x574eb57c9700] missing picture in access unit with size 109542
[h264 @ 0x574eb57e40c0] Invalid NAL unit size (540206825 > 109538).
[h264 @ 0x574eb57e40c0] Error splitting the input into NAL units.
[NULL @ 0x574eb57c9700] Invalid NAL unit size (1072494654 > 74994).
[NULL @ 0x574eb57c9700] missing picture in access unit with size 74998
[h264 @ 0x574eb5844d00] Invalid NAL unit size (1072494654 > 74994).
[h264 @ 0x574eb5844d00] Error splitting the input into NAL units.
[vist#0:0/h264 @ 0x574eb57cfe00] corrupt decoded frame
[vist#0:0/h264 @ 0x574eb57cfe00] Error submitting packet to decoder:
Invalid data found when processing input
     Last message repeated 4 times

frame=  392 fps= 84 q=49.0 size=     368kB time=00:00:16.51 bitrate=
182.6kbits/s dup=26 drop=0 speed=3.53x
frame=  436 fps= 84 q=49.0 size=     368kB time=00:00:18.28 bitrate=
164.9kbits/s dup=26 drop=0 speed=3.53x

---

It leads to the missing audio after this error.

This error must be removed to reencode :

ffmpeg -i "test.mp4" -codec copy -ss 00:00:00.000 -t 00:00:14.950
"test1.mp4"

ffmpeg -i "test.mp4" -codec copy -ss 00:00:16.510 -t 00:00:50.080
"test2.mp4"

But to "cat" the files via ffmpeg, all errors must be removed :

All mp4 files of the directory will be "cat"

ffmpeg -safe 0 -f concat -i <(printf "file '$PWD/%s'\n" *.mp4) -c copy
test.mp4

But with Avidemux you can ad all videos per drag + drop, after all, save
the files in copy mode to one-mp4 and reencode as you wish.

The script to get all errors with the respective timestamp :

#!/bin/bash

while IFS= read -r -d $'\0' video
do
     filename=$(basename -- "$video")
     filename="${filename%.*}"

     ffmpeg -y -i "$video" -vcodec libx264 -crf 51 -preset ultrafast
-acodec copy -f mp4 -movflags frag_keyframe+empty_moov+delay_moov pipe:1
 >/dev/null 2>"${filename}.txt" </dev/null
     TxtFileName="${filename}.txt"
     mystring=${TxtFileName}
     echo $mystring
     grep -i -n 'error\|duplicate\|failure\|missing\|POCs\|corrupt'
"${TxtFileName}"
     echo "Ready"

done < <(find -iregex ".*\.\(mp4\|mkv\|m2ts\|mpg\|ts\)" -print0)
#dos2unix -c mac "${TxtFileName}"
#grep -C 5 -i -n 'error\|duplicate\|failure' "${TxtFileName}"
echo "Ready"
read pause


All video files of the directory will be checked, the result you will
find in the txt-file.

Regards



Am 25.02.25 um 03:02 schrieb BloodMan:
> Hello,
>
> wetransfer mp4 test file: https://we.tl/t-BJKuiAHTKQ
>
> The video plays using VLC with glitches and drops (with sound until
> the end) but reencoding generally failed (silence after the first drop).
>
> How to survive? How to reencode with "ignore errors like play in vlc"?
> I tested many ffmpeg commands and tricks and nothing :/
> Anyone?
>
>
> ps. ffmpeg from git (N-118536-g4ff1d1f3d6) of course


More information about the ffmpeg-user mailing list