| Index: media/base/android/media_codec_util.cc
|
| diff --git a/media/base/android/media_codec_util.cc b/media/base/android/media_codec_util.cc
|
| index ae726d0b96f1f22997531445db784f2586c7e22c..5ad325417f49ed0477f5ee8cfabff8b6bb1268ff 100644
|
| --- a/media/base/android/media_codec_util.cc
|
| +++ b/media/base/android/media_codec_util.cc
|
| @@ -25,8 +25,7 @@ using base::android::ScopedJavaLocalRef;
|
|
|
| namespace media {
|
|
|
| -// static
|
| -const std::string CodecTypeToAndroidMimeType(const std::string& codec) {
|
| +static std::string CodecTypeToAndroidMimeType(const std::string& codec) {
|
| // TODO(xhwang): Shall we handle more detailed strings like "mp4a.40.2"?
|
| if (codec == "avc1")
|
| return "video/avc";
|
| @@ -45,34 +44,9 @@ const std::string CodecTypeToAndroidMimeType(const std::string& codec) {
|
| return std::string();
|
| }
|
|
|
| -// TODO(qinmin): using a map to help all the conversions in this class.
|
| -const std::string AndroidMimeTypeToCodecType(const std::string& mime) {
|
| - if (mime == "video/mp4v-es")
|
| - return "mp4v";
|
| - if (mime == "video/avc")
|
| - return "avc1";
|
| - if (mime == "video/hevc")
|
| - return "hvc1";
|
| - if (mime == "video/x-vnd.on2.vp8")
|
| - return "vp8";
|
| - if (mime == "video/x-vnd.on2.vp9")
|
| - return "vp9";
|
| - if (mime == "audio/mp4a-latm")
|
| - return "mp4a";
|
| - if (mime == "audio/mpeg")
|
| - return "mp3";
|
| - if (mime == "audio/vorbis")
|
| - return "vorbis";
|
| - if (mime == "audio/opus")
|
| - return "opus";
|
| - return std::string();
|
| -}
|
| -
|
| -std::string GetDefaultCodecName(const std::string& mime_type,
|
| - MediaCodecDirection direction) {
|
| - if (!MediaCodecUtil::IsMediaCodecAvailable())
|
| - return std::string();
|
| -
|
| +static std::string GetDefaultCodecName(const std::string& mime_type,
|
| + MediaCodecDirection direction) {
|
| + DCHECK(MediaCodecUtil::IsMediaCodecAvailable());
|
| JNIEnv* env = AttachCurrentThread();
|
| ScopedJavaLocalRef<jstring> j_mime = ConvertUTF8ToJavaString(env, mime_type);
|
| ScopedJavaLocalRef<jstring> j_codec_name =
|
| @@ -80,49 +54,6 @@ std::string GetDefaultCodecName(const std::string& mime_type,
|
| return ConvertJavaStringToUTF8(env, j_codec_name.obj());
|
| }
|
|
|
| -bool SupportsGetName() {
|
| - // MediaCodec.getName() is only available on JB MR2 and greater.
|
| - return base::android::BuildInfo::GetInstance()->sdk_int() >= 18;
|
| -}
|
| -
|
| -// Represents supported codecs on android.
|
| -// TODO(qinmin): Currently the codecs string only contains one codec. Do we
|
| -// need to support codecs separated by comma. (e.g. "vp8" -> "vp8, vp8.0")?
|
| -struct CodecsInfo {
|
| - std::string codecs; // E.g. "vp8" or "avc1".
|
| - std::string name; // E.g. "OMX.google.vp8.decoder".
|
| - MediaCodecDirection direction;
|
| -};
|
| -
|
| -// Get a list of supported codecs.
|
| -std::vector<CodecsInfo> GetCodecsInfo() {
|
| - std::vector<CodecsInfo> codecs_info;
|
| - if (!MediaCodecUtil::IsMediaCodecAvailable())
|
| - return codecs_info;
|
| -
|
| - JNIEnv* env = AttachCurrentThread();
|
| - std::string mime_type;
|
| - ScopedJavaLocalRef<jobjectArray> j_codec_info_array =
|
| - Java_MediaCodecUtil_getCodecsInfo(env);
|
| - jsize len = env->GetArrayLength(j_codec_info_array.obj());
|
| - for (jsize i = 0; i < len; ++i) {
|
| - ScopedJavaLocalRef<jobject> j_info(
|
| - env, env->GetObjectArrayElement(j_codec_info_array.obj(), i));
|
| - ScopedJavaLocalRef<jstring> j_codec_type =
|
| - Java_CodecInfo_codecType(env, j_info.obj());
|
| - ConvertJavaStringToUTF8(env, j_codec_type.obj(), &mime_type);
|
| - ScopedJavaLocalRef<jstring> j_codec_name =
|
| - Java_CodecInfo_codecName(env, j_info.obj());
|
| - CodecsInfo info;
|
| - info.codecs = AndroidMimeTypeToCodecType(mime_type);
|
| - ConvertJavaStringToUTF8(env, j_codec_name.obj(), &info.name);
|
| - info.direction = static_cast<MediaCodecDirection>(
|
| - Java_CodecInfo_direction(env, j_info.obj()));
|
| - codecs_info.push_back(info);
|
| - }
|
| - return codecs_info;
|
| -}
|
| -
|
| // static
|
| bool MediaCodecUtil::IsMediaCodecAvailable() {
|
| // MediaCodec is only available on JB and greater.
|
| @@ -183,38 +114,25 @@ bool MediaCodecUtil::IsKnownUnaccelerated(const std::string& mime_type,
|
| if (!IsMediaCodecAvailable())
|
| return true;
|
|
|
| - std::string codec_name;
|
| - if (SupportsGetName()) {
|
| - codec_name = GetDefaultCodecName(mime_type, direction);
|
| - } else {
|
| - std::string codec_type = AndroidMimeTypeToCodecType(mime_type);
|
| - std::vector<CodecsInfo> codecs_info = GetCodecsInfo();
|
| - for (size_t i = 0; i < codecs_info.size(); ++i) {
|
| - if (codecs_info[i].codecs == codec_type &&
|
| - codecs_info[i].direction == direction) {
|
| - codec_name = codecs_info[i].name;
|
| - break;
|
| - }
|
| - }
|
| - }
|
| - DVLOG(1) << __PRETTY_FUNCTION__ << "Default codec for " << mime_type << " : "
|
| - << codec_name;
|
| + std::string codec_name = GetDefaultCodecName(mime_type, direction);
|
| + DVLOG(1) << __FUNCTION__ << "Default codec for " << mime_type << " : "
|
| + << codec_name << ", direction: " << direction;
|
| + if (!codec_name.size())
|
| + return true;
|
| +
|
| // It would be nice if MediaCodecInfo externalized some notion of
|
| // HW-acceleration but it doesn't. Android Media guidance is that the
|
| // "OMX.google" prefix is always used for SW decoders, so that's what we
|
| // use. "OMX.SEC.*" codec is Samsung software implementation - report it
|
| // as unaccelerated as well. MediaTek hardware vp8 is known slower than
|
| // the software implementation. http://crbug.com/446974.
|
| - if (codec_name.length() > 0) {
|
| - return base::StartsWith(codec_name, "OMX.google.",
|
| - base::CompareCase::SENSITIVE) ||
|
| - base::StartsWith(codec_name, "OMX.SEC.",
|
| - base::CompareCase::SENSITIVE) ||
|
| - (base::StartsWith(codec_name, "OMX.MTK.",
|
| - base::CompareCase::SENSITIVE) &&
|
| - mime_type == "video/x-vnd.on2.vp8");
|
| - }
|
| - return true;
|
| + return base::StartsWith(codec_name, "OMX.google.",
|
| + base::CompareCase::SENSITIVE) ||
|
| + base::StartsWith(codec_name, "OMX.SEC.",
|
| + base::CompareCase::SENSITIVE) ||
|
| + (base::StartsWith(codec_name, "OMX.MTK.",
|
| + base::CompareCase::SENSITIVE) &&
|
| + mime_type == "video/x-vnd.on2.vp8");
|
| }
|
|
|
| // static
|
|
|