OMXCodec.h revision d07139e2e817a9b3ae9c87ba4e1e8d65d3e549da
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 OMX_CODEC_H_ 18 19#define OMX_CODEC_H_ 20 21#include <media/IOMX.h> 22#include <media/stagefright/MediaBuffer.h> 23#include <media/stagefright/MediaSource.h> 24#include <utils/threads.h> 25 26namespace android { 27 28class MemoryDealer; 29struct OMXCodecObserver; 30 31struct OMXCodec : public MediaSource, 32 public MediaBufferObserver { 33 enum CreationFlags { 34 kPreferSoftwareCodecs = 1, 35 }; 36 static sp<MediaSource> Create( 37 const sp<IOMX> &omx, 38 const sp<MetaData> &meta, bool createEncoder, 39 const sp<MediaSource> &source, 40 const char *matchComponentName = NULL, 41 uint32_t flags = 0); 42 43 static void setComponentRole( 44 const sp<IOMX> &omx, IOMX::node_id node, bool isEncoder, 45 const char *mime); 46 47 virtual status_t start(MetaData *params = NULL); 48 virtual status_t stop(); 49 50 virtual sp<MetaData> getFormat(); 51 52 virtual status_t read( 53 MediaBuffer **buffer, const ReadOptions *options = NULL); 54 55 void on_message(const omx_message &msg); 56 57 // from MediaBufferObserver 58 virtual void signalBufferReturned(MediaBuffer *buffer); 59 60protected: 61 virtual ~OMXCodec(); 62 63private: 64 enum State { 65 DEAD, 66 LOADED, 67 LOADED_TO_IDLE, 68 IDLE_TO_EXECUTING, 69 EXECUTING, 70 EXECUTING_TO_IDLE, 71 IDLE_TO_LOADED, 72 RECONFIGURING, 73 ERROR 74 }; 75 76 enum { 77 kPortIndexInput = 0, 78 kPortIndexOutput = 1 79 }; 80 81 enum PortStatus { 82 ENABLED, 83 DISABLING, 84 DISABLED, 85 ENABLING, 86 SHUTTING_DOWN, 87 }; 88 89 enum Quirks { 90 kNeedsFlushBeforeDisable = 1, 91 kWantsNALFragments = 2, 92 kRequiresLoadedToIdleAfterAllocation = 4, 93 kRequiresAllocateBufferOnInputPorts = 8, 94 kRequiresFlushCompleteEmulation = 16, 95 kRequiresAllocateBufferOnOutputPorts = 32, 96 kRequiresFlushBeforeShutdown = 64, 97 kDefersOutputBufferAllocation = 128, 98 kDecoderLiesAboutNumberOfChannels = 256, 99 kInputBufferSizesAreBogus = 512, 100 kSupportsMultipleFramesPerInputBuffer = 1024, 101 kAvoidMemcopyInputRecordingFrames = 2048, 102 }; 103 104 struct BufferInfo { 105 IOMX::buffer_id mBuffer; 106 bool mOwnedByComponent; 107 sp<IMemory> mMem; 108 size_t mSize; 109 void *mData; 110 MediaBuffer *mMediaBuffer; 111 }; 112 113 struct CodecSpecificData { 114 size_t mSize; 115 uint8_t mData[1]; 116 }; 117 118 sp<IOMX> mOMX; 119 bool mOMXLivesLocally; 120 IOMX::node_id mNode; 121 uint32_t mQuirks; 122 bool mIsEncoder; 123 char *mMIME; 124 char *mComponentName; 125 sp<MetaData> mOutputFormat; 126 sp<MediaSource> mSource; 127 Vector<CodecSpecificData *> mCodecSpecificData; 128 size_t mCodecSpecificDataIndex; 129 130 sp<MemoryDealer> mDealer[2]; 131 132 State mState; 133 Vector<BufferInfo> mPortBuffers[2]; 134 PortStatus mPortStatus[2]; 135 bool mInitialBufferSubmit; 136 bool mSignalledEOS; 137 status_t mFinalStatus; 138 bool mNoMoreOutputData; 139 bool mOutputPortSettingsHaveChanged; 140 int64_t mSeekTimeUs; 141 142 MediaBuffer *mLeftOverBuffer; 143 144 Mutex mLock; 145 Condition mAsyncCompletion; 146 147 // A list of indices into mPortStatus[kPortIndexOutput] filled with data. 148 List<size_t> mFilledBuffers; 149 Condition mBufferFilled; 150 151 OMXCodec(const sp<IOMX> &omx, IOMX::node_id node, uint32_t quirks, 152 bool isEncoder, const char *mime, const char *componentName, 153 const sp<MediaSource> &source); 154 155 void addCodecSpecificData(const void *data, size_t size); 156 void clearCodecSpecificData(); 157 158 void setComponentRole(); 159 160 void setAMRFormat(bool isWAMR, int32_t bitRate); 161 void setAACFormat(int32_t numChannels, int32_t sampleRate, int32_t bitRate); 162 163 status_t setVideoPortFormatType( 164 OMX_U32 portIndex, 165 OMX_VIDEO_CODINGTYPE compressionFormat, 166 OMX_COLOR_FORMATTYPE colorFormat); 167 168 void setVideoInputFormat( 169 const char *mime, OMX_U32 width, OMX_U32 height, 170 OMX_U32 frameRate, OMX_U32 bitRate); 171 172 status_t setupMPEG4EncoderParameters(); 173 status_t setupAVCEncoderParameters(); 174 175 status_t setVideoOutputFormat( 176 const char *mime, OMX_U32 width, OMX_U32 height); 177 178 void setImageOutputFormat( 179 OMX_COLOR_FORMATTYPE format, OMX_U32 width, OMX_U32 height); 180 181 void setJPEGInputFormat( 182 OMX_U32 width, OMX_U32 height, OMX_U32 compressedSize); 183 184 void setMinBufferSize(OMX_U32 portIndex, OMX_U32 size); 185 186 void setRawAudioFormat( 187 OMX_U32 portIndex, int32_t sampleRate, int32_t numChannels); 188 189 status_t allocateBuffers(); 190 status_t allocateBuffersOnPort(OMX_U32 portIndex); 191 192 status_t freeBuffersOnPort( 193 OMX_U32 portIndex, bool onlyThoseWeOwn = false); 194 195 void drainInputBuffer(IOMX::buffer_id buffer); 196 void fillOutputBuffer(IOMX::buffer_id buffer); 197 void drainInputBuffer(BufferInfo *info); 198 void fillOutputBuffer(BufferInfo *info); 199 200 void drainInputBuffers(); 201 void fillOutputBuffers(); 202 203 // Returns true iff a flush was initiated and a completion event is 204 // upcoming, false otherwise (A flush was not necessary as we own all 205 // the buffers on that port). 206 // This method will ONLY ever return false for a component with quirk 207 // "kRequiresFlushCompleteEmulation". 208 bool flushPortAsync(OMX_U32 portIndex); 209 210 void disablePortAsync(OMX_U32 portIndex); 211 void enablePortAsync(OMX_U32 portIndex); 212 213 static size_t countBuffersWeOwn(const Vector<BufferInfo> &buffers); 214 static bool isIntermediateState(State state); 215 216 void onEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2); 217 void onCmdComplete(OMX_COMMANDTYPE cmd, OMX_U32 data); 218 void onStateChange(OMX_STATETYPE newState); 219 void onPortSettingsChanged(OMX_U32 portIndex); 220 221 void setState(State newState); 222 223 status_t init(); 224 void initOutputFormat(const sp<MetaData> &inputFormat); 225 226 void dumpPortStatus(OMX_U32 portIndex); 227 228 status_t configureCodec(const sp<MetaData> &meta); 229 230 static uint32_t getComponentQuirks(const char *componentName); 231 232 static void findMatchingCodecs( 233 const char *mime, 234 bool createEncoder, const char *matchComponentName, 235 uint32_t flags, 236 Vector<String8> *matchingCodecs); 237 238 OMXCodec(const OMXCodec &); 239 OMXCodec &operator=(const OMXCodec &); 240}; 241 242struct CodecProfileLevel { 243 OMX_U32 mProfile; 244 OMX_U32 mLevel; 245}; 246 247struct CodecCapabilities { 248 String8 mComponentName; 249 Vector<CodecProfileLevel> mProfileLevels; 250}; 251 252// Return a vector of componentNames with supported profile/level pairs 253// supporting the given mime type, if queryDecoders==true, returns components 254// that decode content of the given type, otherwise returns components 255// that encode content of the given type. 256// profile and level indications only make sense for h.263, mpeg4 and avc 257// video. 258// The profile/level values correspond to 259// OMX_VIDEO_H263PROFILETYPE, OMX_VIDEO_MPEG4PROFILETYPE, 260// OMX_VIDEO_AVCPROFILETYPE, OMX_VIDEO_H263LEVELTYPE, OMX_VIDEO_MPEG4LEVELTYPE 261// and OMX_VIDEO_AVCLEVELTYPE respectively. 262 263status_t QueryCodecs( 264 const sp<IOMX> &omx, 265 const char *mimeType, bool queryDecoders, 266 Vector<CodecCapabilities> *results); 267 268} // namespace android 269 270#endif // OMX_CODEC_H_ 271