summaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorAndreas Huber <andih@google.com>2010-01-15 15:28:19 -0800
committerAndreas Huber <andih@google.com>2010-01-19 10:57:57 -0800
commitf1fe064d735698b09e4bc7b3a10e4dc3dba9a1d9 (patch)
tree1d8e2e0a407c8a11184c8a8e7a9f05847c03b00c /include
parent0a2d8709e4badeeb892b325c1b6fd52ad16f9c7d (diff)
downloadframeworks_base-f1fe064d735698b09e4bc7b3a10e4dc3dba9a1d9.zip
frameworks_base-f1fe064d735698b09e4bc7b3a10e4dc3dba9a1d9.tar.gz
frameworks_base-f1fe064d735698b09e4bc7b3a10e4dc3dba9a1d9.tar.bz2
Avoid unnecessary buffer copying if at all possible, detect if running in the mediaserver process.
Diffstat (limited to 'include')
-rw-r--r--include/media/IOMX.h5
-rw-r--r--include/media/stagefright/OMXCodec.h1
2 files changed, 6 insertions, 0 deletions
diff --git a/include/media/IOMX.h b/include/media/IOMX.h
index 39bd5b1..d38c177 100644
--- a/include/media/IOMX.h
+++ b/include/media/IOMX.h
@@ -42,6 +42,11 @@ public:
typedef void *buffer_id;
typedef void *node_id;
+ // Given the calling process' pid, returns true iff
+ // the implementation of the OMX interface lives in the same
+ // process.
+ virtual bool livesLocally(pid_t pid) = 0;
+
struct ComponentInfo {
String8 mName;
List<String8> mRoles;
diff --git a/include/media/stagefright/OMXCodec.h b/include/media/stagefright/OMXCodec.h
index 351763c..2c32386 100644
--- a/include/media/stagefright/OMXCodec.h
+++ b/include/media/stagefright/OMXCodec.h
@@ -109,6 +109,7 @@ private:
};
sp<IOMX> mOMX;
+ bool mOMXLivesLocally;
IOMX::node_id mNode;
uint32_t mQuirks;
bool mIsEncoder;