Правильная установка gstreamer1.0-vaapi

Окей, ребята, вот моя проблема в течение последних нескольких недель. Я пытаюсь использовать vaapi. У меня есть процессор Intel i5 (Wayland), который поддерживает vaapi, но по какой-то странной причине я не могу заставить его работать, также я использую 14.10 64-битную версию.

Список установленных пакетов dpkg --get-selections | grep va:

gstreamer1.0-vaapi:amd64            install
i965-va-driver:amd64                install
i965-va-driver-dbg:amd64            install
libva-dev:amd64                     install
libva-drm1:amd64                    install
libva-egl1:amd64                    install
libva-glx1:amd64                    install
libva-intel-vaapi-driver            install
libva-tpi1:amd64                    install
libva-wayland1:amd64                install
libva-x11-1:amd64                   install
libva1:amd64                        install
libvdpau-va-gl1:amd64               install
libgstreamer-vaapi1.0-0:amd64       install
libgstreamer-vaapi1.0-dev           install
libavahi-client3:amd64              install
libavahi-client3:i386               install
libavahi-common-data:amd64          install
libavahi-common-data:i386           install
libavahi-common3:amd64              install
libavahi-common3:i386               install
libavahi-core7:amd64                install
libavahi-glib1:amd64                install
libavahi-gobject0:amd64             install

Вывод vainfo:

libva info: VA-API version 0.36.0
libva info: va_getDriverName() returns 0
libva info: Trying to open /usr/lib/x86_64-linux-gnu/dri/i965_drv_video.so
libva info: Found init function __vaDriverInit_0_35
libva info: va_openDriver() returns 0
vainfo: VA-API version: 0.36 (libva 1.4.0)
vainfo: Driver version: Intel i965 driver for Intel(R) Haswell Desktop - 1.3.2
vainfo: Supported profile and entrypoints
      VAProfileMPEG2Simple            : VAEntrypointVLD
      VAProfileMPEG2Simple            : VAEntrypointEncSlice
      VAProfileMPEG2Main              : VAEntrypointVLD
      VAProfileMPEG2Main              : VAEntrypointEncSlice
      VAProfileH264ConstrainedBaseline: VAEntrypointVLD
      VAProfileH264ConstrainedBaseline: VAEntrypointEncSlice
      VAProfileH264Main               : VAEntrypointVLD
      VAProfileH264Main               : VAEntrypointEncSlice
      VAProfileH264High               : VAEntrypointVLD
      VAProfileH264High               : VAEntrypointEncSlice
      VAProfileVC1Simple              : VAEntrypointVLD
      VAProfileVC1Main                : VAEntrypointVLD
      VAProfileVC1Advanced            : VAEntrypointVLD
      VAProfileNone                   : VAEntrypointVideoProc
      VAProfileJPEGBaseline           : VAEntrypointVLD

с простым конвейером gstreamer, как этот:

gst-launch-1.0 playbin video-sink=vaapisink uri=rtsp://ip_of_my_camera/

Я получаю это в качестве вывода:

New clock: GstSystemClock
Progress: (request) Sending PLAY request
Progress: (request) Sending PLAY request
Progress: (request) Sent PLAY request
Got context from element 'vaapidecode0': gst.vaapi.Display=context, display=(GstVaapiDisplay)NULL;
0:00:03.405005415 27214 0x7f2560023370 ERROR                  vaapi ../../../../gst-libs/gst/vaapi/gstvaapidecoder_h264.c:1351:ensure_context: unsupported profile_idc 66
0:00:03.405029986 27214 0x7f2560023370 ERROR            vaapidecode ../../../gst/vaapi/gstvaapidecode.c:284:gst_vaapidecode_decode_frame: decode error 9
ERROR: from element /GstPlayBin:playbin0/GstURIDecodeBin:uridecodebin0/GstRTSPSrc:source/GstUDPSrc:udpsrc0: Internal data flow error.
Additional debug info:
gstbasesrc.c(2943): gst_base_src_loop (): /GstPlayBin:playbin0/GstURIDecodeBin:uridecodebin0/GstRTSPSrc:source/GstUDPSrc:udpsrc0:
streaming task paused, reason not-supported (-6)
Execution ended after 0:00:02.567426400
Setting pipeline to PAUSED ...
Setting pipeline to READY ...
Setting pipeline to NULL ...
Freeing pipeline ...

Я попытался играть в простой mp4 после этого:

gst-launch-1.0 playbin video-sink=vaapisink uri=file:///home/user/test.mp4

Я получаю это в качестве вывода:

Setting pipeline to PAUSED ...
libva info: VA-API version 0.36.0
libva info: va_getDriverName() returns 0
libva info: Trying to open /usr/lib/x86_64-linux-gnu/dri/i965_drv_video.so
libva info: Found init function __vaDriverInit_0_35
libva info: va_openDriver() returns 0
Pipeline is PREROLLING ...
Got context from element 'vaapidecode0': gst.vaapi.Display=context, display=(GstVaapiDisplay)NULL;
0:00:00.082428099 27226 0x7fb268008c00 ERROR                  vaapi ../../../../gst-libs/gst/vaapi/gstvaapidecoder_h264.c:1351:ensure_context: unsupported profile_idc 66
0:00:00.082457191 27226 0x7fb268008c00 ERROR            vaapidecode ../../../gst/vaapi/gstvaapidecode.c:284:gst_vaapidecode_decode_frame: decode error 9
ERROR: from element /GstPlayBin:playbin0/GstURIDecodeBin:uridecodebin0/GstDecodeBin:decodebin0/GstQTDemux:qtdemux0: GStreamer encountered a general stream error.
Additional debug info:
qtdemux.c(4432): gst_qtdemux_loop (): /GstPlayBin:playbin0/GstURIDecodeBin:uridecodebin0/GstDecodeBin:decodebin0/GstQTDemux:qtdemux0:
streaming stopped, reason not-supported
ERROR: pipeline doesn't want to preroll.
Setting pipeline to NULL ...
Freeing pipeline ...

2 ответа

Я решил это, выбрав правильную версию версии gstreamer1.0-vaapi. Вы можете получить файл здесь: https://www.freedesktop.org/software/vaapi/releases/gstreamer-vaapi/

как установить: - ./configure - make - make install

Если неверная версия (ошибка все еще возникает), используйте -make uninstall, чтобы удалить ее, и продолжайте пробовать следующую версию

(Вы должны полностью удалить версию, установленную вами из sudo -apt get

Пожалуйста, расскажите нам больше о вашем источнике?

Попробуйте создать дамп в файл и загрузить его с помощью различных инструментов, таких как vlc, может появиться интересная информация

Вы можете адаптировать:

location=/tmp/tmp.ts
uri="file://${location}"    
gst-launch-1.0 udpsrc port=${port} ! filesink location=$location

gst-launch-1.0 playbin uri=$uri 
#| Got EOS from element "playbin0".

gst-launch-1.0 playbin  --gst-debug-level=3  uri=$uri audio-sink=fakesink

#| 0:00:00.062872448  1532 0xb5002060 ERROR                  vaapi gstvaapidecoder_h264.c:1351:ensure_context: unsupported profile_idc 66
#| 0:00:00.062892542  1532 0xb5002060 ERROR            vaapidecode gstvaapidecode.c:284:gst_vaapidecode_decode_frame: decode error 9


gst-launch-1.0 playbin  --gst-debug-level=3  uri=$uri 
vlc $location
#| [0x7f25e0c826d8] ts demux error: MPEG-4 descriptor not found

mediainfo $location | grep Codec
#| Format/Info                              : Advanced Video Codec
#| Codec ID                                 : 27
Другие вопросы по тегам