summaryrefslogtreecommitdiffstats
path: root/media
diff options
context:
space:
mode:
authorAndreas Huber <andih@google.com>2010-02-01 13:02:39 -0800
committerAndroid (Google) Code Review <android-gerrit@google.com>2010-02-01 13:02:39 -0800
commitafeb8352e222a218440e4b5a9d17181fc304c179 (patch)
tree8b13af642bd2a3c0b2dc5ca90bb20bd478689fd0 /media
parent6b3359d4669f539c173bfc40809deb8ffde3dd0c (diff)
parent78d529eb330ab6c04b5c694403f5a7e7de4b702f (diff)
downloadframeworks_av-afeb8352e222a218440e4b5a9d17181fc304c179.zip
frameworks_av-afeb8352e222a218440e4b5a9d17181fc304c179.tar.gz
frameworks_av-afeb8352e222a218440e4b5a9d17181fc304c179.tar.bz2
Merge "The TI MP3 decoder lies about the number of channels it outputs, add a quirk for that."
Diffstat (limited to 'media')
-rw-r--r--media/libstagefright/OMXCodec.cpp13
1 files changed, 10 insertions, 3 deletions
diff --git a/media/libstagefright/OMXCodec.cpp b/media/libstagefright/OMXCodec.cpp
index e17fbb8..90bbdfe 100644
--- a/media/libstagefright/OMXCodec.cpp
+++ b/media/libstagefright/OMXCodec.cpp
@@ -290,6 +290,7 @@ uint32_t OMXCodec::getComponentQuirks(const char *componentName) {
}
if (!strcmp(componentName, "OMX.TI.MP3.decode")) {
quirks |= kNeedsFlushBeforeDisable;
+ quirks |= kDecoderLiesAboutNumberOfChannels;
}
if (!strcmp(componentName, "OMX.TI.AAC.decode")) {
quirks |= kNeedsFlushBeforeDisable;
@@ -2817,7 +2818,9 @@ void OMXCodec::initOutputFormat(const sp<MetaData> &inputFormat) {
if ((OMX_U32)numChannels != params.nChannels) {
LOGW("Codec outputs a different number of channels than "
- "the input stream contains.");
+ "the input stream contains (contains %d channels, "
+ "codec outputs %ld channels).",
+ numChannels, params.nChannels);
}
mOutputFormat->setCString(
@@ -2825,8 +2828,12 @@ void OMXCodec::initOutputFormat(const sp<MetaData> &inputFormat) {
// Use the codec-advertised number of channels, as some
// codecs appear to output stereo even if the input data is
- // mono.
- mOutputFormat->setInt32(kKeyChannelCount, params.nChannels);
+ // mono. If we know the codec lies about this information,
+ // use the actual number of channels instead.
+ mOutputFormat->setInt32(
+ kKeyChannelCount,
+ (mQuirks & kDecoderLiesAboutNumberOfChannels)
+ ? numChannels : params.nChannels);
// The codec-reported sampleRate is not reliable...
mOutputFormat->setInt32(kKeySampleRate, sampleRate);