ffprobe запускает SegFault в Ubuntu, но не в Windows - PullRequest
0 голосов
/ 06 ноября 2019

Я пытаюсь запустить модель VideoPose3D на вычислительном кластере в моем университете, но я столкнулся с проблемой, когда скрипт infer_video.py (запускается внутри Detectron ) перерывы из-за ffprobe. Рассматриваемая команда:

ffprobe -v error -select_streams v:0 -show_entries stream=width,height -of csv=p=0 filename_here

Она должна возвращать кортеж ширины, высоты входного видео. Этот сценарий работал хорошо в прошлом, но на видео, которые я использую сейчас, я получаю segfault. Для контекста, вот результат его запуска в вычислительном кластере (Ubuntu):

$ ffprobe data/test/00001/00001.mp4
ffprobe version 4.0.3 Copyright (c) 2007-2018 the FFmpeg developers
  built with gcc 8.1.0 (GCC)
  configuration: --prefix=/share/pkg.7/ffmpeg/4.0.3/install --enable-gpl --enable-libx264 --enable-hardcoded-tables --enable-pic --enable-shared --enable-lto
  libavutil      56. 14.100 / 56. 14.100
  libavcodec     58. 18.100 / 58. 18.100
  libavformat    58. 12.100 / 58. 12.100
  libavdevice    58.  3.100 / 58.  3.100
  libavfilter     7. 16.100 /  7. 16.100
  libswscale      5.  1.100 /  5.  1.100
  libswresample   3.  1.100 /  3.  1.100
  libpostproc    55.  1.100 / 55.  1.100
Segmentation fault

Вот результат этой же команды на моей локальной машине (Windows 10):

$ ffprobe data\test\00001\00001.mp4
ffprobe version 4.2.1 Copyright (c) 2007-2019 the FFmpeg developers
  built with gcc 9.1.1 (GCC) 20190807
  configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --enable-libdav1d --enable-libbluray --enable-libfreetype --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libtheora --enable-libtwolame --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libzimg --enable-lzma --enable-zlib --enable-gmp --enable-libvidstab --enable-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --enable-libmfx --enable-amf --enable-ffnvcodec --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt
  libavutil      56. 31.100 / 56. 31.100
  libavcodec     58. 54.100 / 58. 54.100
  libavformat    58. 29.100 / 58. 29.100
  libavdevice    58.  8.100 / 58.  8.100
  libavfilter     7. 57.100 /  7. 57.100
  libswscale      5.  5.100 /  5.  5.100
  libswresample   3.  5.100 /  3.  5.100
  libpostproc    55.  5.100 / 55.  5.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'data\test\00001\00001.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf58.29.100
  Duration: 00:02:52.18, start: 0.000000, bitrate: 1643 kb/s
    Stream #0:0(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p(tv, bt709), 1920x1080 [SAR 1:1 DAR 16:9], 1512 kb/s, 24 fps, 24 tbr, 90k tbn, 48 tbc (default)
    Metadata:
      handler_name    : VideoHandler
    Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 125 kb/s (default)
    Metadata:
      handler_name    : SoundHandler

Это наводит меня на мысль, что это как-то связано с версией ffprobe, но я не контролирую версию, установленную в вычислительном кластере. Это также не объясняет, почему это работало однажды на видео ранее. У кого-нибудь есть понимание? У меня также есть полный отладочный вывод запуска ffprobe на вычислительном кластере в gist, здесь.

РЕДАКТИРОВАТЬ: Дальнейший контекст, который может быть полезен, и заставляет меня полагать, что это проблема версиивидео, которые заполняют мой каталог данных, получаются с помощью youtube-dl. Когда я пытаюсь использовать youtube-dl в вычислительном кластере, это терпит неудачу, потому что ffmpeg выдает ошибку при попытке мультиплексировать аудио и видео потоки. Такая ошибка не возникает, когда я запускаю скрипт локально (с более новой версией ffmpeg).

Однажды ffmpeg работал на вычислительном кластере, у рассматриваемого видео не было аудиопотока, только видео. Это известная проблема со старыми версиями ffmpeg? Должен ли я обойти это, просто используя докер-контейнер с более высокой версией ffmpeg, или есть другие способы обхода, которые люди предлагают?

1 Ответ

0 голосов
/ 07 ноября 2019

Я не заканчивал тем, что копался в ffmpeg, чтобы видеть, что было ошибкой, но я подтвердил, что ошибка не возникает в версии 4.2.1. К счастью, я смог запросить обновление на вычислительном кластере, который я использую, и смог обойти эту проблему.

...