| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 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_IOMX_H_ | 
|  | 18 |  | 
|  | 19 | #define ANDROID_IOMX_H_ | 
|  | 20 |  | 
|  | 21 | #include <binder/IInterface.h> | 
| Andy McFadden | 7cd5853 | 2013-02-19 07:28:30 -0800 | [diff] [blame] | 22 | #include <gui/IGraphicBufferProducer.h> | 
| Jamie Gennis | 83750ea | 2010-08-30 16:48:38 -0700 | [diff] [blame] | 23 | #include <ui/GraphicBuffer.h> | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 24 | #include <utils/List.h> | 
|  | 25 | #include <utils/String8.h> | 
|  | 26 |  | 
|  | 27 | #include <OMX_Core.h> | 
| Andreas Huber | 8b938cd | 2009-07-31 11:52:50 -0700 | [diff] [blame] | 28 | #include <OMX_Video.h> | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 29 |  | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 30 | namespace android { | 
|  | 31 |  | 
|  | 32 | class IMemory; | 
|  | 33 | class IOMXObserver; | 
| Andreas Huber | 8b938cd | 2009-07-31 11:52:50 -0700 | [diff] [blame] | 34 | class IOMXRenderer; | 
| Andreas Huber | f4148b5 | 2009-08-07 12:01:29 -0700 | [diff] [blame] | 35 | class Surface; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 36 |  | 
|  | 37 | class IOMX : public IInterface { | 
|  | 38 | public: | 
|  | 39 | DECLARE_META_INTERFACE(OMX); | 
|  | 40 |  | 
| Andy Hung | 609b815 | 2014-05-02 11:05:04 -0700 | [diff] [blame] | 41 | typedef uint32_t buffer_id; | 
|  | 42 | typedef uint32_t node_id; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 43 |  | 
| Andreas Huber | d459b48 | 2012-01-31 11:16:24 -0800 | [diff] [blame] | 44 | // Given a node_id and the calling process' pid, returns true iff | 
| Andreas Huber | 7eaa9c9 | 2010-01-15 15:28:19 -0800 | [diff] [blame] | 45 | // the implementation of the OMX interface lives in the same | 
|  | 46 | // process. | 
| Andreas Huber | d459b48 | 2012-01-31 11:16:24 -0800 | [diff] [blame] | 47 | virtual bool livesLocally(node_id node, pid_t pid) = 0; | 
| Andreas Huber | 7eaa9c9 | 2010-01-15 15:28:19 -0800 | [diff] [blame] | 48 |  | 
| Andreas Huber | 134ee6a | 2009-12-16 09:30:55 -0800 | [diff] [blame] | 49 | struct ComponentInfo { | 
|  | 50 | String8 mName; | 
|  | 51 | List<String8> mRoles; | 
|  | 52 | }; | 
|  | 53 | virtual status_t listNodes(List<ComponentInfo> *list) = 0; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 54 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 55 | virtual status_t allocateNode( | 
|  | 56 | const char *name, const sp<IOMXObserver> &observer, | 
|  | 57 | node_id *node) = 0; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 58 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 59 | virtual status_t freeNode(node_id node) = 0; | 
|  | 60 |  | 
|  | 61 | virtual status_t sendCommand( | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 62 | node_id node, OMX_COMMANDTYPE cmd, OMX_S32 param) = 0; | 
|  | 63 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 64 | virtual status_t getParameter( | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 65 | node_id node, OMX_INDEXTYPE index, | 
|  | 66 | void *params, size_t size) = 0; | 
|  | 67 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 68 | virtual status_t setParameter( | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 69 | node_id node, OMX_INDEXTYPE index, | 
|  | 70 | const void *params, size_t size) = 0; | 
|  | 71 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 72 | virtual status_t getConfig( | 
| Andreas Huber | 693d271 | 2009-08-14 14:37:10 -0700 | [diff] [blame] | 73 | node_id node, OMX_INDEXTYPE index, | 
|  | 74 | void *params, size_t size) = 0; | 
|  | 75 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 76 | virtual status_t setConfig( | 
| Andreas Huber | 693d271 | 2009-08-14 14:37:10 -0700 | [diff] [blame] | 77 | node_id node, OMX_INDEXTYPE index, | 
|  | 78 | const void *params, size_t size) = 0; | 
|  | 79 |  | 
| Jamie Gennis | b1d666f | 2011-10-19 21:14:13 -0700 | [diff] [blame] | 80 | virtual status_t getState( | 
|  | 81 | node_id node, OMX_STATETYPE* state) = 0; | 
|  | 82 |  | 
| James Dong | e870772 | 2010-10-20 17:38:41 -0700 | [diff] [blame] | 83 | virtual status_t storeMetaDataInBuffers( | 
|  | 84 | node_id node, OMX_U32 port_index, OMX_BOOL enable) = 0; | 
|  | 85 |  | 
| Lajos Molnar | 56ce726 | 2013-05-02 16:30:48 -0700 | [diff] [blame] | 86 | virtual status_t prepareForAdaptivePlayback( | 
|  | 87 | node_id node, OMX_U32 portIndex, OMX_BOOL enable, | 
|  | 88 | OMX_U32 maxFrameWidth, OMX_U32 maxFrameHeight) = 0; | 
|  | 89 |  | 
| Rachad | 5a446aa | 2014-07-29 16:47:56 -0700 | [diff] [blame] | 90 | virtual status_t configureVideoTunnelMode( | 
|  | 91 | node_id node, OMX_U32 portIndex, OMX_BOOL tunneled, | 
|  | 92 | OMX_U32 audioHwSync, native_handle_t **sidebandHandle) = 0; | 
|  | 93 |  | 
| Jamie Gennis | 83750ea | 2010-08-30 16:48:38 -0700 | [diff] [blame] | 94 | virtual status_t enableGraphicBuffers( | 
|  | 95 | node_id node, OMX_U32 port_index, OMX_BOOL enable) = 0; | 
|  | 96 |  | 
| Jamie Gennis | e2ce645 | 2011-02-23 19:01:28 -0800 | [diff] [blame] | 97 | virtual status_t getGraphicBufferUsage( | 
|  | 98 | node_id node, OMX_U32 port_index, OMX_U32* usage) = 0; | 
|  | 99 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 100 | virtual status_t useBuffer( | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 101 | node_id node, OMX_U32 port_index, const sp<IMemory> ¶ms, | 
|  | 102 | buffer_id *buffer) = 0; | 
|  | 103 |  | 
| Jamie Gennis | 83750ea | 2010-08-30 16:48:38 -0700 | [diff] [blame] | 104 | virtual status_t useGraphicBuffer( | 
|  | 105 | node_id node, OMX_U32 port_index, | 
|  | 106 | const sp<GraphicBuffer> &graphicBuffer, buffer_id *buffer) = 0; | 
|  | 107 |  | 
| Lajos Molnar | d071586 | 2013-07-22 12:57:43 -0700 | [diff] [blame] | 108 | virtual status_t updateGraphicBufferInMeta( | 
|  | 109 | node_id node, OMX_U32 port_index, | 
|  | 110 | const sp<GraphicBuffer> &graphicBuffer, buffer_id buffer) = 0; | 
|  | 111 |  | 
| Andy McFadden | 7cd5853 | 2013-02-19 07:28:30 -0800 | [diff] [blame] | 112 | virtual status_t createInputSurface( | 
|  | 113 | node_id node, OMX_U32 port_index, | 
|  | 114 | sp<IGraphicBufferProducer> *bufferProducer) = 0; | 
|  | 115 |  | 
|  | 116 | virtual status_t signalEndOfInputStream(node_id node) = 0; | 
|  | 117 |  | 
| Andreas Huber | 570a3cb | 2010-01-20 15:05:46 -0800 | [diff] [blame] | 118 | // This API clearly only makes sense if the caller lives in the | 
|  | 119 | // same process as the callee, i.e. is the media_server, as the | 
|  | 120 | // returned "buffer_data" pointer is just that, a pointer into local | 
|  | 121 | // address space. | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 122 | virtual status_t allocateBuffer( | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 123 | node_id node, OMX_U32 port_index, size_t size, | 
| Andreas Huber | 570a3cb | 2010-01-20 15:05:46 -0800 | [diff] [blame] | 124 | buffer_id *buffer, void **buffer_data) = 0; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 125 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 126 | virtual status_t allocateBufferWithBackup( | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 127 | node_id node, OMX_U32 port_index, const sp<IMemory> ¶ms, | 
|  | 128 | buffer_id *buffer) = 0; | 
|  | 129 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 130 | virtual status_t freeBuffer( | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 131 | node_id node, OMX_U32 port_index, buffer_id buffer) = 0; | 
|  | 132 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 133 | virtual status_t fillBuffer(node_id node, buffer_id buffer) = 0; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 134 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 135 | virtual status_t emptyBuffer( | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 136 | node_id node, | 
|  | 137 | buffer_id buffer, | 
|  | 138 | OMX_U32 range_offset, OMX_U32 range_length, | 
|  | 139 | OMX_U32 flags, OMX_TICKS timestamp) = 0; | 
| Andreas Huber | 8b938cd | 2009-07-31 11:52:50 -0700 | [diff] [blame] | 140 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 141 | virtual status_t getExtensionIndex( | 
| Andreas Huber | 693d271 | 2009-08-14 14:37:10 -0700 | [diff] [blame] | 142 | node_id node, | 
|  | 143 | const char *parameter_name, | 
|  | 144 | OMX_INDEXTYPE *index) = 0; | 
| Andreas Huber | e40cda7 | 2013-07-17 13:55:26 -0700 | [diff] [blame] | 145 |  | 
|  | 146 | enum InternalOptionType { | 
|  | 147 | INTERNAL_OPTION_SUSPEND,  // data is a bool | 
| Andreas Huber | a61285d | 2013-07-31 13:50:42 -0700 | [diff] [blame] | 148 | INTERNAL_OPTION_REPEAT_PREVIOUS_FRAME_DELAY,  // data is an int64_t | 
| Chong Zhang | 94ee4b7 | 2014-01-10 17:36:57 -0800 | [diff] [blame] | 149 | INTERNAL_OPTION_MAX_TIMESTAMP_GAP, // data is int64_t | 
| Ronghua Wu | 37b2b38 | 2015-01-26 15:47:10 -0800 | [diff] [blame] | 150 | INTERNAL_OPTION_MAX_FPS, // data is float | 
| Chong Zhang | 72cecca | 2013-12-26 01:38:35 -0800 | [diff] [blame] | 151 | INTERNAL_OPTION_START_TIME, // data is an int64_t | 
| Chong Zhang | 2c9c8cb | 2014-02-11 13:54:59 -0800 | [diff] [blame] | 152 | INTERNAL_OPTION_TIME_LAPSE, // data is an int64_t[2] | 
| Andreas Huber | e40cda7 | 2013-07-17 13:55:26 -0700 | [diff] [blame] | 153 | }; | 
|  | 154 | virtual status_t setInternalOption( | 
|  | 155 | node_id node, | 
|  | 156 | OMX_U32 port_index, | 
|  | 157 | InternalOptionType type, | 
|  | 158 | const void *data, | 
|  | 159 | size_t size) = 0; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 160 | }; | 
|  | 161 |  | 
|  | 162 | struct omx_message { | 
|  | 163 | enum { | 
|  | 164 | EVENT, | 
|  | 165 | EMPTY_BUFFER_DONE, | 
|  | 166 | FILL_BUFFER_DONE, | 
|  | 167 |  | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 168 | } type; | 
|  | 169 |  | 
| Andreas Huber | 693d271 | 2009-08-14 14:37:10 -0700 | [diff] [blame] | 170 | IOMX::node_id node; | 
|  | 171 |  | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 172 | union { | 
|  | 173 | // if type == EVENT | 
|  | 174 | struct { | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 175 | OMX_EVENTTYPE event; | 
|  | 176 | OMX_U32 data1; | 
|  | 177 | OMX_U32 data2; | 
|  | 178 | } event_data; | 
|  | 179 |  | 
| Andreas Huber | e0f0b08 | 2009-08-27 14:50:58 -0700 | [diff] [blame] | 180 | // if type == EMPTY_BUFFER_DONE | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 181 | struct { | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 182 | IOMX::buffer_id buffer; | 
|  | 183 | } buffer_data; | 
|  | 184 |  | 
| Andreas Huber | e0f0b08 | 2009-08-27 14:50:58 -0700 | [diff] [blame] | 185 | // if type == FILL_BUFFER_DONE | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 186 | struct { | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 187 | IOMX::buffer_id buffer; | 
|  | 188 | OMX_U32 range_offset; | 
|  | 189 | OMX_U32 range_length; | 
|  | 190 | OMX_U32 flags; | 
|  | 191 | OMX_TICKS timestamp; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 192 | } extended_buffer_data; | 
|  | 193 |  | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 194 | } u; | 
|  | 195 | }; | 
|  | 196 |  | 
|  | 197 | class IOMXObserver : public IInterface { | 
|  | 198 | public: | 
|  | 199 | DECLARE_META_INTERFACE(OMXObserver); | 
|  | 200 |  | 
| Andreas Huber | 318ad9c | 2009-10-15 13:46:54 -0700 | [diff] [blame] | 201 | virtual void onMessage(const omx_message &msg) = 0; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 202 | }; | 
|  | 203 |  | 
|  | 204 | //////////////////////////////////////////////////////////////////////////////// | 
|  | 205 |  | 
|  | 206 | class BnOMX : public BnInterface<IOMX> { | 
|  | 207 | public: | 
|  | 208 | virtual status_t onTransact( | 
|  | 209 | uint32_t code, const Parcel &data, Parcel *reply, | 
|  | 210 | uint32_t flags = 0); | 
|  | 211 | }; | 
|  | 212 |  | 
|  | 213 | class BnOMXObserver : public BnInterface<IOMXObserver> { | 
|  | 214 | public: | 
|  | 215 | virtual status_t onTransact( | 
|  | 216 | uint32_t code, const Parcel &data, Parcel *reply, | 
|  | 217 | uint32_t flags = 0); | 
|  | 218 | }; | 
|  | 219 |  | 
| James Dong | 457116d | 2011-07-11 12:29:10 -0700 | [diff] [blame] | 220 | struct CodecProfileLevel { | 
|  | 221 | OMX_U32 mProfile; | 
|  | 222 | OMX_U32 mLevel; | 
|  | 223 | }; | 
|  | 224 |  | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 225 | }  // namespace android | 
|  | 226 |  | 
|  | 227 | #endif  // ANDROID_IOMX_H_ |