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