Index: media/base/media.cc |
diff --git a/media/base/media.cc b/media/base/media.cc |
index 37fc02ae4575c3cb6cf51a94c0f6fdaebc23c9fe..3db513fc2e17878bd6bf2823cc3285e4b0c72028 100644 |
--- a/media/base/media.cc |
+++ b/media/base/media.cc |
@@ -11,36 +11,42 @@ |
#include "build/build_config.h" |
#include "media/base/yuv_convert.h" |
+#if !defined(MEDIA_DISABLE_FFMPEG) |
+#include "media/ffmpeg/ffmpeg_common.h" |
+#endif |
+ |
namespace media { |
namespace internal { |
// Platform specific initialization method. |
-extern bool InitializeMediaLibraryInternal(const base::FilePath& module_dir); |
+extern void InitializeMediaLibraryInternal(); |
} // namespace internal |
// Media must only be initialized once, so use a LazyInstance to ensure this. |
class MediaInitializer { |
public: |
- bool Initialize(const base::FilePath& module_dir) { |
+ void Initialize() { |
base::AutoLock auto_lock(lock_); |
- if (!tried_initialize_) { |
- tried_initialize_ = true; |
- initialized_ = internal::InitializeMediaLibraryInternal(module_dir); |
- } |
- return initialized_; |
- } |
+ if (!initialized_) { |
+#if !defined(MEDIA_DISABLE_FFMPEG) |
+ // Disable logging as it interferes with layout tests. |
+ av_log_set_level(AV_LOG_QUIET); |
- bool IsInitialized() { |
- base::AutoLock auto_lock(lock_); |
- return initialized_; |
+#if defined(ALLOCATOR_SHIM) |
+ // Remove allocation limit from ffmpeg, so calls go down to shim layer. |
+ av_max_alloc(0); |
+#endif // defined(ALLOCATOR_SHIM) |
+ |
+#endif // !defined(MEDIA_DISABLE_FFMPEG) |
+ |
+ initialized_ = true; |
+ } |
} |
private: |
friend struct base::DefaultLazyInstanceTraits<MediaInitializer>; |
- MediaInitializer() |
- : initialized_(false), |
- tried_initialize_(false) { |
+ MediaInitializer() : initialized_(false) { |
// Perform initialization of libraries which require runtime CPU detection. |
InitializeCPUSpecificYUVConversions(); |
} |
@@ -51,7 +57,6 @@ class MediaInitializer { |
base::Lock lock_; |
bool initialized_; |
- bool tried_initialize_; |
DISALLOW_COPY_AND_ASSIGN(MediaInitializer); |
}; |
@@ -59,18 +64,8 @@ class MediaInitializer { |
static base::LazyInstance<MediaInitializer>::Leaky g_media_library = |
LAZY_INSTANCE_INITIALIZER; |
-bool InitializeMediaLibrary(const base::FilePath& module_dir) { |
- return g_media_library.Get().Initialize(module_dir); |
-} |
- |
-void InitializeMediaLibraryForTesting() { |
- base::FilePath module_dir; |
- CHECK(PathService::Get(base::DIR_EXE, &module_dir)); |
- CHECK(g_media_library.Get().Initialize(module_dir)); |
-} |
- |
-bool IsMediaLibraryInitialized() { |
- return g_media_library.Get().IsInitialized(); |
+void InitializeMediaLibrary() { |
+ g_media_library.Get().Initialize(); |
} |
void InitializeCPUSpecificMediaFeatures() { |