Xubuntu 12.10 и веб-камера FFMPEG
Проблемы с запуском ffmpeg
для ffserver
в новой установке Xubuntu 12.10.
Я только что установил Xubuntu 12.10 с нуля, затем установил ffmpeg. Я подключил свою веб-камеру (учтите, что я использовал эту веб-камеру на другой системе Ubuntu 12.04 и 11.04 без каких-либо проблем, используя ту же ffserver
и той же командой) затем запустил команду ffmpeg:
ffmpeg -f video4linux2 -i /dev/video0 http://IP:8090/cam1.ffm
Теперь в теории это должно работать, но я получаю следующее:
fmpeg version 0.8.4-6:0.8.4-0ubuntu0.12.10.1, Copyright (c) 2000-2012 the Libav developers
built on Nov 6 2012 16:49:20 with gcc 4.7.2
*** THIS PROGRAM IS DEPRECATED ***
This program is only provided for compatibility and will be removed in a future release. Please use avconv instead.
ffmpeg: /build/buildd/libav-0.8.4/libavutil/mathematics.c:79: av_rescale_rnd: Assertion `c > 0' failed.
Aborted (core dumped)
Я искал эту ошибку и не могу найти ее нигде. Поэтому я попытался mplayer, чтобы увидеть, если веб-камера работает, и если video0
работал:
mplayer tv:// -tv device=/dev/video0:driver=v4l2:width=352:height=288
Это прекрасно работает и показывает мне мой экран веб-камеры.
Теперь я подумал, хорошо, может быть, эта глупая штука с устаревшей имеет к этому какое-то отношение, поэтому я попробовал ту же самую команду для ffmpeg, используя avconv, и получаю ту же ошибку.
lsusb
дает мне:
Bus 001 Device 003: ID 04fc:1528 Sunplus Technology Co., Ltd SPCA1527A/SPCA1528 SD card camera (webcam mode)
Как я уже сказал, у меня точно такая же веб-камера, работающая на двух других ПК с двумя разными установками Ubuntu.
РЕДАКТИРОВАТЬ:
Я перекомпилировал ffmpeg
используя эти инструкции: https://ffmpeg.org/trac/ffmpeg/wiki/UbuntuCompilationGuide
Это работает, если я просто использую ту же команду, что и выше, она запускается, процессор работает на 100%, как если бы он конвертировал. Но нет выхода в ffmpeg
просто висит здесь бесконечно, пока я ctrl-c
:
ffmpeg version git-2013-01-01-fde1305 Copyright (c) 2000-2013 the FFmpeg developers
built on Jan 1 2013 11:42:21 with gcc 4.7 (Ubuntu/Linaro 4.7.2-2ubuntu1)
configuration: --enable-gpl --enable-libass --enable-libfaac --enable-libfdk-aac --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-librtmp --enable-libtheora --enable-libvorbis --enable-libvpx --enable-x11grab --enable-libx264 --enable-nonfree --enable-version3
libavutil 52. 13.100 / 52. 13.100
libavcodec 54. 85.100 / 54. 85.100
libavformat 54. 58.102 / 54. 58.102
libavdevice 54. 3.102 / 54. 3.102
libavfilter 3. 30.102 / 3. 30.102
libswscale 2. 1.103 / 2. 1.103
libswresample 0. 17.102 / 0. 17.102
libpostproc 52. 2.100 / 52. 2.100
[video4linux2,v4l2 @ 0x97c8200] DTS discontinuity in stream 0: packet 3 with DTS 21527529506, packet 4 with DTS 21527577460
Тогда однажды я ctrl-c
дважды я получаю это:
^CEstimating duration from bitrate, this may be inaccurate
Input #0, video4linux2,v4l2, from '/dev/video0':
Duration: N/A, start: 21527.513483, bitrate: N/A
Stream #0:0: Video: mjpeg, yuvj420p, 320x240, -2147483 kb/s, 18.08 tbr, 1000k tbn, 1000k tbc
http://IP:8090/cam1.ffm: Input/output error
Received signal 2: terminating.
Хорошо, давайте посмотрим, если я укажу частоту кадров, что происходит:
ffmpeg -r 2 -f video4linux2 -i /dev/video0 http://IP:8090/cam1.ffm
ffmpeg version git-2013-01-01-fde1305 Copyright (c) 2000-2013 the FFmpeg developers
built on Jan 1 2013 11:42:21 with gcc 4.7 (Ubuntu/Linaro 4.7.2-2ubuntu1)
configuration: --enable-gpl --enable-libass --enable-libfaac --enable-libfdk-aac --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-librtmp --enable-libtheora --enable-libvorbis --enable-libvpx --enable-x11grab --enable-libx264 --enable-nonfree --enable-version3
libavutil 52. 13.100 / 52. 13.100
libavcodec 54. 85.100 / 54. 85.100
libavformat 54. 58.102 / 54. 58.102
libavdevice 54. 3.102 / 54. 3.102
libavfilter 3. 30.102 / 3. 30.102
libswscale 2. 1.103 / 2. 1.103
libswresample 0. 17.102 / 0. 17.102
libpostproc 52. 2.100 / 52. 2.100
[video4linux2,v4l2 @ 0xa5fa2a0] DTS discontinuity in stream 0: packet 3 with DTS 21627329870, packet 4 with DTS 21627409821
[video4linux2,v4l2 @ 0xa5fa2a0] max_analyze_duration 5000000 reached at 5000000
[video4linux2,v4l2 @ 0xa5fa2a0] Estimating duration from bitrate, this may be inaccurate
Input #0, video4linux2,v4l2, from '/dev/video0':
Duration: N/A, start: 21627.313851, bitrate: N/A
Stream #0:0: Video: mjpeg, yuvj420p, 320x240, 0 kb/s, 2 fps, 0.25 tbr, 1000k tbn, 2 tbc
Incompatible pixel format '(null)' for codec 'flv', auto-selecting format '(null)'
Last message repeated 1 times
[flv @ 0xa6046c0] Specified pixel format yuvj420p is invalid or not supported
Output #0, ffm, to 'http://198.144.186.224:8090/cam1.ffm':
Metadata:
creation_time : now
Stream #0:0: Video: flv1 ([0][0][0][5] / 0x5000000), yuvj420p, 320x2, q=255-255, 200 kb/s, 1000k tbn, 2 tbc
Stream mapping:
Stream #0:0 -> #0:0 (mjpeg -> flv)
Error while opening encoder for output stream #0:0 - maybe incorrect parameters such as bit_rate, rate, width or height
мой ffserver
Conf-файл выглядит так (хотя, как я уже говорил, он работал раньше с другого компьютера):
Port 8090
BindAddress IP
MaxHTTPConnections 30
MaxClients 20
MaxBandwidth 2000
CustomLog -
<Feed cam1.ffm>
File /tmp/cam1.ffm
FileMaxSize 10000K
</Feed>
<Stream cam1.flv>
Feed cam1.ffm
Format flv
VideoCodec flv
VideoFrameRate 2
VideoBufferSize 20000
VideoBitRate 200
VideoQMin 5
VideoQMax 10
VideoSize qvga
PreRoll 0
Noaudio
AVOptionVideo flags +global_header
</Stream>
<Stream stat.html>
Format status
</Stream>
РЕДАКТИРОВАТЬ 2:
Просто подтвердил, что при запуске на моем компьютере с Ubuntu 11.04 он работает просто отлично, команда немного другая, но работает:
ffmpeg -r 10 -s 320x240 -f video4linux2 -aspect 4:3 -i /dev/video0 http://IP:8090/cam1.ffm
Поэтому я скопировал эту команду в другую систему Xubuntu и получил missing yuvj420p
проблема из ранее:
[video4linux2,v4l2 @ 0xb1c53e0] Estimating duration from bitrate, this may be inaccurate
Input #0, video4linux2,v4l2, from '/dev/video0':
Duration: N/A, start: 27867.321194, bitrate: N/A
Stream #0:0: Video: mjpeg, yuvj420p, 320x240, -1 kb/s, 10 tbr, 1000k tbn, 10 tbc
Incompatible pixel format '(null)' for codec 'flv', auto-selecting format '(null)'
Last message repeated 1 times
[flv @ 0xb1ca6e0] Specified pixel format yuvj420p is invalid or not supported
Output #0, ffm, to 'http://198.144.186.224:8090/cam1.ffm':
Metadata:
creation_time : now
Stream #0:0: Video: flv1 ([0][0][0][5] / 0x5000000), yuvj420p, 320x10, q=255-255, 200 kb/s, 1000k tbn, 10 tbc
Stream mapping:
Stream #0:0 -> #0:0 (mjpeg -> flv)
Error while opening encoder for output stream #0:0 - maybe incorrect parameters such as bit_rate, rate, width or height
Выше размещена информация о конфигурации, когда я запускаю ffmpeg
на моей машине Xubuntu, вот что отображается при запуске ffmpeg
на моей машине Ubuntu 11:
FFmpeg version 0.6.6-4:0.6.6-0ubuntu0.11.04.1, Copyright (c) 2000-2010 the Libav developers
built on Jun 12 2012 16:28:21 with gcc 4.5.2
configuration: --extra-version=4:0.6.6-0ubuntu0.11.04.1 --prefix=/usr --enable-avfilter --enable-avfilter-lavf --enable-vdpau --enable-bzlib --enable-libgsm --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-pthreads --enable-zlib --enable-libvpx --disable-stripping --enable-runtime-cpudetect --enable-vaapi --enable-gpl --enable-postproc --enable-swscale --enable-x11grab --enable-libdc1394 --enable-shared --disable-static
WARNING: library configuration mismatch
libavutil configuration: --extra-version=4:0.6.6-1ubuntu1 --prefix=/usr --enable-avfilter --enable-avfilter-lavf --enable-vdpau --enable-bzlib --enable-libdirac --enable-libgsm --enable-libopenjpeg --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-pthreads --enable-zlib --enable-libvpx --disable-stripping --enable-runtime-cpudetect --enable-vaapi --enable-libopenjpeg --enable-gpl --enable-postproc --enable-swscale --enable-x11grab --enable-libfaad --enable-libdirac --enable-libfaad --enable-libmp3lame --enable-librtmp --enable-libx264 --enable-libxvid --enable-libdc1394 --shlibdir=/usr/lib/i686/cmov --cpu=i686 --enable-shared --disable-static --disable-ffmpeg --disable-ffplay
libavcodec configuration: --extra-version=4:0.6.6-1ubuntu1 --prefix=/usr --enable-avfilter --enable-avfilter-lavf --enable-vdpau --enable-bzlib --enable-libdirac --enable-libgsm --enable-libopenjpeg --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-pthreads --enable-zlib --enable-libvpx --disable-stripping --enable-runtime-cpudetect --enable-vaapi --enable-libopenjpeg --enable-gpl --enable-postproc --enable-swscale --enable-x11grab --enable-libfaad --enable-libdirac --enable-libfaad --enable-libmp3lame --enable-librtmp --enable-libx264 --enable-libxvid --enable-libdc1394 --shlibdir=/usr/lib/i686/cmov --cpu=i686 --enable-shared --disable-static --disable-ffmpeg --disable-ffplay
libavformat configuration: --extra-version=4:0.6.6-0ubuntu0.11.04.1 --prefix=/usr --enable-avfilter --enable-avfilter-lavf --enable-vdpau --enable-bzlib --enable-libgsm --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-pthreads --enable-zlib --enable-libvpx --disable-stripping --enable-runtime-cpudetect --enable-vaapi --enable-gpl --enable-postproc --enable-swscale --enable-x11grab --enable-libdc1394 --shlibdir=/usr/lib/i686/cmov --cpu=i686 --enable-shared --disable-static --disable-ffmpeg --disable-ffplay
libavdevice configuration: --extra-version=4:0.6.6-0ubuntu0.11.04.1 --prefix=/usr --enable-avfilter --enable-avfilter-lavf --enable-vdpau --enable-bzlib --enable-libgsm --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-pthreads --enable-zlib --enable-libvpx --disable-stripping --enable-runtime-cpudetect --enable-vaapi --enable-gpl --enable-postproc --enable-swscale --enable-x11grab --enable-libdc1394 --shlibdir=/usr/lib/i686/cmov --cpu=i686 --enable-shared --disable-static --disable-ffmpeg --disable-ffplay
libavfilter configuration: --extra-version=4:0.6.6-0ubuntu0.11.04.1 --prefix=/usr --enable-avfilter --enable-avfilter-lavf --enable-vdpau --enable-bzlib --enable-libgsm --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-pthreads --enable-zlib --enable-libvpx --disable-stripping --enable-runtime-cpudetect --enable-vaapi --enable-gpl --enable-postproc --enable-swscale --enable-x11grab --enable-libdc1394 --shlibdir=/usr/lib/i686/cmov --cpu=i686 --enable-shared --disable-static --disable-ffmpeg --disable-ffplay
libswscale configuration: --extra-version=4:0.6.6-0ubuntu0.11.04.1 --prefix=/usr --enable-avfilter --enable-avfilter-lavf --enable-vdpau --enable-bzlib --enable-libgsm --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-pthreads --enable-zlib --enable-libvpx --disable-stripping --enable-runtime-cpudetect --enable-vaapi --enable-gpl --enable-postproc --enable-swscale --enable-x11grab --enable-libdc1394 --shlibdir=/usr/lib/i686/cmov --cpu=i686 --enable-shared --disable-static --disable-ffmpeg --disable-ffplay
libpostproc configuration: --extra-version=4:0.6.6-0ubuntu0.11.04.1 --prefix=/usr --enable-avfilter --enable-avfilter-lavf --enable-vdpau --enable-bzlib --enable-libgsm --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-pthreads --enable-zlib --enable-libvpx --disable-stripping --enable-runtime-cpudetect --enable-vaapi --enable-gpl --enable-postproc --enable-swscale --enable-x11grab --enable-libdc1394 --shlibdir=/usr/lib/i686/cmov --cpu=i686 --enable-shared --disable-static --disable-ffmpeg --disable-ffplay
libavutil 50.15. 1 / 50.15. 1
libavcodec 52.72. 2 / 52.72. 2
libavformat 52.64. 2 / 52.64. 2
libavdevice 52. 2. 0 / 52. 2. 0
libavfilter 1.19. 0 / 1.19. 0
libswscale 0.11. 0 / 0.11. 0
libpostproc 51. 2. 0 / 51. 2. 0
Так что, конечно, он скомпилирован с различными опциями, но какая опция поддерживает yuvj420p
или как я могу получить ошибку, чтобы она ушла теперь, когда я знаю, что проблема "кажется"?
РЕДАКТИРОВАТЬ 3:
Я перекомпилировал, используя мои переключатели из моей работающей системы Ubuntu 11:
./configure --enable-gpl --enable-libass --enable-libfaac --enable-libfdk-aac --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-librtmp --enable-libtheora --enable-libvorbis --enable-libvpx --enable-x11grab --enable-libx264 --enable-nonfree --enable-version3 --enable-shared --enable-libv4l2 --enable-avfilter --enable-vdpau --enable-bzlib --enable-libgsm --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-pthreads --enable-zlib --disable-stripping --enable-runtime-cpudetect --enable-vaapi --enable-gpl --enable-postproc --enable-swscale --enable-libdc1394 --disable-static
--enable-shared
должен быть yuvj
подмножества.
Итак, все готово и все переключатели, теперь я запускаю его и получаю:
[video4linux2,v4l2 @ 0x9d1d0e0] Estimating duration from bitrate, this may be inaccurate
Input #0, video4linux2,v4l2, from '/dev/video0':
Duration: N/A, start: 36365.493926, bitrate: 36863 kb/s
Stream #0:0: Video: rawvideo (I420 / 0x30323449), yuv420p, 640x480, 36863 kb/s, 10 tbr, 1000k tbn, 10 tbc
Incompatible pixel format '(null)' for codec 'flv', auto-selecting format '(null)'
Last message repeated 1 times
[flv @ 0x9d22440] Warning min_rate > 0 but min_rate != max_rate isn't recommended!
[flv @ 0x9d22440] bitrate below min bitrate
Output #0, ffm, to 'http://IP:8090/cam1.ffm':
Metadata:
creation_time : now
Stream #0:0: Video: flv1 ([0][0][0][5] / 0x5000000), yuv420p, 640x10, q=255-255, 200 kb/s, 1000k tbn, 10 tbc
Stream mapping:
Stream #0:0 -> #0:0 (rawvideo -> flv)
Error while opening encoder for output stream #0:0 - maybe incorrect parameters such as bit_rate, rate, width or height
Так что теперь он работает и находит вещи, но по-прежнему не позволяет мне из-за bitrate below min bitrate
, Я пробовал настройку -b 200k
а также -b 600k
но все та же вещь. Я полагаю, это потому, что в файле FFM указано 200, но я хочу, чтобы оно было на 200.
Итак, как мне отключить проверку битрейта?
Думаю, в этом и заключается проблема, честно говоря, я испытываю желание установить Ubuntu 11.04 на эту систему и поцарапать ее, каждая новая версия программного обеспечения усложняет и усложняет ситуацию.