summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorscherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-24 22:38:53 +0000
committerscherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-11-24 22:38:53 +0000
commit3e1a292b64b685d64f119b8a138dd0be85611b8b (patch)
tree4cdecb1d1fbb9e620fb88995b748d5f153faefd1
parentfaed6e1304f7ba31ed12d42ea3dc694021690afd (diff)
downloadchromium_src-3e1a292b64b685d64f119b8a138dd0be85611b8b.zip
chromium_src-3e1a292b64b685d64f119b8a138dd0be85611b8b.tar.gz
chromium_src-3e1a292b64b685d64f119b8a138dd0be85611b8b.tar.bz2
Implement method stubs for OpenMAX IL instead of relying on -lOmxCore.
You can switch to using -lOmxCore by setting the gyp variable use_system_openmax=1. BUG=28663 TEST=building omx_test should have no linker errors Review URL: http://codereview.chromium.org/436021 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@32988 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--build/all.gyp5
-rw-r--r--media/media.gyp15
-rw-r--r--media/omx/omx_test.cc3
-rw-r--r--media/omx/omx_test.gyp30
-rw-r--r--third_party/openmax/omx_stub.cc36
-rw-r--r--third_party/openmax/openmax.gyp52
6 files changed, 96 insertions, 45 deletions
diff --git a/build/all.gyp b/build/all.gyp
index 4a61b70..7f0fd9d 100644
--- a/build/all.gyp
+++ b/build/all.gyp
@@ -56,11 +56,6 @@
'../webkit/tools/pepper_test_plugin/pepper_test_plugin.gyp:*',
],
}],
- ['enable_openmax==1', {
- 'dependencies': [
- '../media/omx/omx_test.gyp:*',
- ],
- }],
['OS=="mac" or OS=="linux" or OS=="freebsd"', {
'dependencies': [
'../third_party/yasm/yasm.gyp:*#host',
diff --git a/media/media.gyp b/media/media.gyp
index 3bbc7df..7973394 100644
--- a/media/media.gyp
+++ b/media/media.gyp
@@ -238,6 +238,21 @@
'tools/qt_faststart.c'
],
},
+ {
+ 'target_name': 'omx_test',
+ 'type': 'executable',
+ 'dependencies': [
+ '../base/base.gyp:base',
+ '../third_party/openmax/openmax.gyp:il',
+ ],
+ 'sources': [
+ 'omx/input_buffer.cc',
+ 'omx/input_buffer.h',
+ 'omx/omx_test.cc',
+ 'omx/omx_video_decoder.cc',
+ 'omx/omx_video_decoder.h',
+ ],
+ },
],
'conditions': [
['OS=="win"', {
diff --git a/media/omx/omx_test.cc b/media/omx/omx_test.cc
index 306a2fd..bb4ffd2 100644
--- a/media/omx/omx_test.cc
+++ b/media/omx/omx_test.cc
@@ -12,6 +12,7 @@
#include "base/at_exit.h"
#include "base/command_line.h"
+#include "base/file_util.h"
#include "base/message_loop.h"
#include "base/scoped_ptr.h"
#include "media/omx/input_buffer.h"
@@ -89,7 +90,7 @@ class TestApp {
void Run() {
// Open the input file.
- file_ = fopen(filename_, "rb");
+ file_ = file_util::OpenFile(filename_, "rb");
if (!file_) {
printf("Error - can't open file %s\n", filename_);
return;
diff --git a/media/omx/omx_test.gyp b/media/omx/omx_test.gyp
deleted file mode 100644
index 0e2fcaa..0000000
--- a/media/omx/omx_test.gyp
+++ /dev/null
@@ -1,30 +0,0 @@
-# Copyright (c) 2009 The Chromium Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style license that can be
-# found in the LICENSE file.
-
-{
- 'variables': {
- 'chromium_code': 1,
- },
- 'conditions': [
- ['OS=="linux"', {
- 'targets' : [
- {
- 'target_name': 'omx_test',
- 'type': 'executable',
- 'dependencies': [
- '../../base/base.gyp:base',
- '../../third_party/openmax/openmax.gyp:il',
- ],
- 'sources': [
- 'input_buffer.cc',
- 'input_buffer.h',
- 'omx_test.cc',
- 'omx_video_decoder.cc',
- 'omx_video_decoder.h',
- ],
- },
- ],
- }],
- ],
-}
diff --git a/third_party/openmax/omx_stub.cc b/third_party/openmax/omx_stub.cc
new file mode 100644
index 0000000..a2a7526
--- /dev/null
+++ b/third_party/openmax/omx_stub.cc
@@ -0,0 +1,36 @@
+// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+// Satisfies linker dependencies for targets requiring an OpenMAX Core library.
+// Not intended in any way to be functional!!
+
+#include <OMX_Core.h>
+
+#define NOTIMPLEMENTED_POLICY 3 // Fail at runtime via DCHECK.
+#include "base/logging.h"
+
+extern "C" {
+
+OMX_API OMX_ERRORTYPE OMX_Init() {
+ NOTIMPLEMENTED();
+ return OMX_ErrorNotImplemented;
+}
+
+OMX_API OMX_ERRORTYPE OMX_Deinit() {
+ NOTIMPLEMENTED();
+ return OMX_ErrorNotImplemented;
+}
+
+OMX_API OMX_ERRORTYPE OMX_GetHandle(OMX_HANDLETYPE*, OMX_STRING, OMX_PTR,
+ OMX_CALLBACKTYPE*) {
+ NOTIMPLEMENTED();
+ return OMX_ErrorNotImplemented;
+}
+
+OMX_API OMX_ERRORTYPE OMX_FreeHandle(OMX_HANDLETYPE) {
+ NOTIMPLEMENTED();
+ return OMX_ErrorNotImplemented;
+};
+
+} // extern "C"
diff --git a/third_party/openmax/openmax.gyp b/third_party/openmax/openmax.gyp
index aeca369..53929ba 100644
--- a/third_party/openmax/openmax.gyp
+++ b/third_party/openmax/openmax.gyp
@@ -3,11 +3,46 @@
# found in the LICENSE file.
{
+ 'variables': {
+ 'use_system_openmax%': 0,
+ },
+ 'target_defaults': {
+ 'conditions': [
+ ['use_system_openmax==0', {
+ 'type': '<(library)',
+ 'dependencies': [
+ '../../base/base.gyp:base',
+ ],
+ 'sources': [
+ 'omx_stub.cc',
+ ],
+ 'include_dirs': [
+ 'il',
+ ],
+ 'defines': [
+ '__OMX_EXPORTS',
+ ],
+ 'direct_dependent_settings': {
+ 'defines': [
+ '__OMX_EXPORTS',
+ ],
+ },
+ },{
+ 'type': 'none',
+ 'direct_dependent_settings': {
+ 'link_settings': {
+ 'libraries': [
+ '-lOmxCore',
+ ],
+ },
+ },
+ }],
+ ],
+ },
'targets': [
{
# OpenMAX IL level of API.
'target_name': 'il',
- 'type': 'none',
'sources': [
'il/OMX_Audio.h',
'il/OMX_Component.h',
@@ -24,14 +59,13 @@
'include_dirs': [
'il',
],
- 'link_settings': {
- 'libraries': [
- '-lOmxCore',
- # We need dl for dlopen() and friends.
- '-ldl',
- ],
- },
},
},
- ],
+ ],
}
+
+# Local Variables:
+# tab-width:2
+# indent-tabs-mode:nil
+# End:
+# vim: set expandtab tabstop=2 shiftwidth=2: