Ошибка FFMpeg Android Stagefright SIGSEGV (декодирование h264) - PullRequest
7 голосов
/ 01 февраля 2012

Мне нужно декодировать h264 файл в YUV на Android 2.3+. Как я понимаю, мне нужно общаться со Stagefright, поскольку это единственный способ, после закрытия доступа с реализациями OpenMAX IL . Я использовал FFmpeg 0.10 (и пробовал 0.9 / 0.9.1 ..) для этой проблемы, скомпилировал его с NDK7 (а также пробовал NDK6b с тем же результатом):

  ffmpeg version 0.10 Copyright (c) 2000-2012 the FFmpeg developers
  built on Jan 28 2012 14:42:37 with gcc 4.4.3
  configuration: --target-os=linux --cross-prefix=arm-linux-androideabi- --arch=arm --cpu=armv7-a --sysroot=/home/grid/Android/Android_NDK/platforms/android-9/arch-arm --disable-avdevice --disable-decoder=h264 --disable-decoder=h264_vdpau --enable-libstagefright-h264 --prefix=build/stagefright/armeabi-v7a --extra-cflags='-Iandroid-source/frameworks/base/include -Iandroid-source/system/core/include -Iandroid-source/frameworks/base/media/libstagefright -Iandroid-source/frameworks/base/include/media/stagefright/openmax -I/home/grid/Android/Android_NDK/sources/cxx-stl/system/include -march=armv7-a -mfloat-abi=softfp -mfpu=neon' --extra-ldflags='-Wl,--fix-cortex-a8 -Landroid-libs -Wl,-rpath-link,android-libs' --extra-cxxflags='-Wno-multichar -fno-exceptions -fno-rtti'
  libavutil      51. 34.101 / 51. 34.101
  libavcodec     53. 60.100 / 53. 60.100
  libavformat    53. 31.100 / 53. 31.100
  libavfilter     2. 60.100 /  2. 60.100
  libswscale      2.  1.100 /  2.  1.100
  libswresample   0.  6.100 /  0.  6.100
Hyper fast Audio and Video encoder
usage: ffmpeg [options] [[infile options] -i infile]... {[outfile options] outfile}...

Аппаратное обеспечение : Beagleboard-Xm + TI Android 2.3 (официальный)

Итак, ввод следующей команды выдает ошибку с 480p: ffmpeg -i /sdcard/Video/480p.mp4

Остановлен (сигнал) ffmpeg -i /sdcard/Video/480p.mp4

Полный Android «ответ» от ADB Logcat: http://pastebin.com/76JLgtXX

Android-разработчики, кто-нибудь знает, что означает эта ошибка и как с ней бороться? Я пытался увеличить окно DSP, но безуспешно. Команды типа "stagefright /sdcard/Video/480p.mp4" работают нормально.

P.S. Кроме того, я обнаружил, что на некоторых больших файлах (720p) Android отвечает следующим образом:

[libstagefright_h264 @ 0xd479b0] Ошибка декодирования: 80000000

1 Ответ

2 голосов
/ 29 июня 2012

Вы включили libstagefright-h264 в своих флагах настройки ffmpeg, но не включили его как декодер как таковой:

--enable-decoder=libstagefright_h264
...