summaryrefslogtreecommitdiffstats
path: root/media/libstagefright/StagefrightMetadataRetriever.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'media/libstagefright/StagefrightMetadataRetriever.cpp')
-rw-r--r--media/libstagefright/StagefrightMetadataRetriever.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/media/libstagefright/StagefrightMetadataRetriever.cpp b/media/libstagefright/StagefrightMetadataRetriever.cpp
index c3adac4..5b96040 100644
--- a/media/libstagefright/StagefrightMetadataRetriever.cpp
+++ b/media/libstagefright/StagefrightMetadataRetriever.cpp
@@ -28,6 +28,8 @@
#include <media/ICrypto.h>
#include <media/IMediaHTTPService.h>
+#include <media/stagefright/FFMPEGSoftCodec.h>
+
#include <media/stagefright/foundation/ABuffer.h>
#include <media/stagefright/foundation/ADebug.h>
#include <media/stagefright/foundation/AMessage.h>
@@ -506,6 +508,14 @@ VideoFrame *StagefrightMetadataRetriever::getFrameAtTime(
for (size_t i = 0; i < matchingCodecs.size(); ++i) {
const char *componentName = matchingCodecs[i].mName.string();
+ const char *ffmpegComponentName;
+ /* determine whether ffmpeg should override a broken h/w codec */
+ ffmpegComponentName = FFMPEGSoftCodec::overrideComponentName(0, trackMeta, mime, false);
+ if (ffmpegComponentName) {
+ ALOGV("override compoent %s to %s for video frame extraction.", componentName, ffmpegComponentName);
+ componentName = ffmpegComponentName;
+ }
+
VideoFrame *frame =
extractVideoFrame(componentName, trackMeta, source, timeUs, option);