OMX.h revision d291c222357303b9611cab89d0c3b047584ef377
1/* 2 * Copyright (C) 2009 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17#ifndef ANDROID_OMX_H_ 18#define ANDROID_OMX_H_ 19 20#include <media/IOMX.h> 21#include <utils/threads.h> 22#include <utils/KeyedVector.h> 23 24namespace android { 25 26struct OMXMaster; 27struct OMXNodeInstance; 28 29class OMX : public BnOMX, 30 public IBinder::DeathRecipient { 31public: 32 OMX(); 33 34 virtual bool livesLocally(node_id node, pid_t pid); 35 36 virtual status_t listNodes(List<ComponentInfo> *list); 37 38 virtual status_t allocateNode( 39 const char *name, const sp<IOMXObserver> &observer, node_id *node); 40 41 virtual status_t freeNode(node_id node); 42 43 virtual status_t sendCommand( 44 node_id node, OMX_COMMANDTYPE cmd, OMX_S32 param); 45 46 virtual status_t getParameter( 47 node_id node, OMX_INDEXTYPE index, 48 void *params, size_t size); 49 50 virtual status_t setParameter( 51 node_id node, OMX_INDEXTYPE index, 52 const void *params, size_t size); 53 54 virtual status_t getConfig( 55 node_id node, OMX_INDEXTYPE index, 56 void *params, size_t size); 57 58 virtual status_t setConfig( 59 node_id node, OMX_INDEXTYPE index, 60 const void *params, size_t size); 61 62 virtual status_t getState( 63 node_id node, OMX_STATETYPE* state); 64 65 virtual status_t enableGraphicBuffers( 66 node_id node, OMX_U32 port_index, OMX_BOOL enable); 67 68 virtual status_t getGraphicBufferUsage( 69 node_id node, OMX_U32 port_index, OMX_U32* usage); 70 71 virtual status_t storeMetaDataInBuffers( 72 node_id node, OMX_U32 port_index, OMX_BOOL enable); 73 74 virtual status_t prepareForAdaptivePlayback( 75 node_id node, OMX_U32 portIndex, OMX_BOOL enable, 76 OMX_U32 max_frame_width, OMX_U32 max_frame_height); 77 78 virtual status_t configureVideoTunnelMode( 79 node_id node, OMX_U32 portIndex, OMX_BOOL tunneled, 80 OMX_U32 audioHwSync, native_handle_t **sidebandHandle); 81 82 virtual status_t useBuffer( 83 node_id node, OMX_U32 port_index, const sp<IMemory> ¶ms, 84 buffer_id *buffer); 85 86 virtual status_t useGraphicBuffer( 87 node_id node, OMX_U32 port_index, 88 const sp<GraphicBuffer> &graphicBuffer, buffer_id *buffer); 89 90 virtual status_t updateGraphicBufferInMeta( 91 node_id node, OMX_U32 port_index, 92 const sp<GraphicBuffer> &graphicBuffer, buffer_id buffer); 93 94 virtual status_t createInputSurface( 95 node_id node, OMX_U32 port_index, 96 sp<IGraphicBufferProducer> *bufferProducer); 97 98 virtual status_t createPersistentInputSurface( 99 sp<IGraphicBufferProducer> *bufferProducer, 100 sp<IGraphicBufferConsumer> *bufferConsumer); 101 102 virtual status_t usePersistentInputSurface( 103 node_id node, OMX_U32 port_index, 104 const sp<IGraphicBufferConsumer> &bufferConsumer); 105 106 virtual status_t signalEndOfInputStream(node_id node); 107 108 virtual status_t allocateBuffer( 109 node_id node, OMX_U32 port_index, size_t size, 110 buffer_id *buffer, void **buffer_data); 111 112 virtual status_t allocateBufferWithBackup( 113 node_id node, OMX_U32 port_index, const sp<IMemory> ¶ms, 114 buffer_id *buffer); 115 116 virtual status_t freeBuffer( 117 node_id node, OMX_U32 port_index, buffer_id buffer); 118 119 virtual status_t fillBuffer(node_id node, buffer_id buffer); 120 121 virtual status_t emptyBuffer( 122 node_id node, 123 buffer_id buffer, 124 OMX_U32 range_offset, OMX_U32 range_length, 125 OMX_U32 flags, OMX_TICKS timestamp); 126 127 virtual status_t getExtensionIndex( 128 node_id node, 129 const char *parameter_name, 130 OMX_INDEXTYPE *index); 131 132 virtual status_t setInternalOption( 133 node_id node, 134 OMX_U32 port_index, 135 InternalOptionType type, 136 const void *data, 137 size_t size); 138 139 virtual void binderDied(const wp<IBinder> &the_late_who); 140 141 OMX_ERRORTYPE OnEvent( 142 node_id node, 143 OMX_IN OMX_EVENTTYPE eEvent, 144 OMX_IN OMX_U32 nData1, 145 OMX_IN OMX_U32 nData2, 146 OMX_IN OMX_PTR pEventData); 147 148 OMX_ERRORTYPE OnEmptyBufferDone( 149 node_id node, buffer_id buffer, OMX_IN OMX_BUFFERHEADERTYPE *pBuffer); 150 151 OMX_ERRORTYPE OnFillBufferDone( 152 node_id node, buffer_id buffer, OMX_IN OMX_BUFFERHEADERTYPE *pBuffer); 153 154 void invalidateNodeID(node_id node); 155 156protected: 157 virtual ~OMX(); 158 159private: 160 struct CallbackDispatcherThread; 161 struct CallbackDispatcher; 162 163 Mutex mLock; 164 OMXMaster *mMaster; 165 int32_t mNodeCounter; 166 167 KeyedVector<wp<IBinder>, OMXNodeInstance *> mLiveNodes; 168 KeyedVector<node_id, OMXNodeInstance *> mNodeIDToInstance; 169 KeyedVector<node_id, sp<CallbackDispatcher> > mDispatchers; 170 171 node_id makeNodeID(OMXNodeInstance *instance); 172 OMXNodeInstance *findInstance(node_id node); 173 sp<CallbackDispatcher> findDispatcher(node_id node); 174 175 void invalidateNodeID_l(node_id node); 176 177 OMX(const OMX &); 178 OMX &operator=(const OMX &); 179}; 180 181} // namespace android 182 183#endif // ANDROID_OMX_H_ 184