ACodec.h revision 8f469e18c307cb9dc0d16ed9225972aa8be4516f
1/* 2 * Copyright (C) 2010 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 A_CODEC_H_ 18 19#define A_CODEC_H_ 20 21#include <stdint.h> 22#include <android/native_window.h> 23#include <media/IOMX.h> 24#include <media/stagefright/foundation/AHierarchicalStateMachine.h> 25#include <media/stagefright/CodecBase.h> 26#include <media/stagefright/SkipCutBuffer.h> 27#include <OMX_Audio.h> 28 29#define TRACK_BUFFER_TIMING 0 30 31namespace android { 32 33struct ABuffer; 34struct MemoryDealer; 35struct DescribeColorFormatParams; 36 37struct ACodec : public AHierarchicalStateMachine, public CodecBase { 38 ACodec(); 39 40 virtual void setNotificationMessage(const sp<AMessage> &msg); 41 42 void initiateSetup(const sp<AMessage> &msg); 43 44 virtual void initiateAllocateComponent(const sp<AMessage> &msg); 45 virtual void initiateConfigureComponent(const sp<AMessage> &msg); 46 virtual void initiateCreateInputSurface(); 47 virtual void initiateSetInputSurface(const sp<PersistentSurface> &surface); 48 virtual void initiateStart(); 49 virtual void initiateShutdown(bool keepComponentAllocated = false); 50 51 virtual status_t setSurface(const sp<Surface> &surface); 52 53 virtual void signalFlush(); 54 virtual void signalResume(); 55 56 virtual void signalSetParameters(const sp<AMessage> &msg); 57 virtual void signalEndOfInputStream(); 58 virtual void signalRequestIDRFrame(); 59 60 // AHierarchicalStateMachine implements the message handling 61 virtual void onMessageReceived(const sp<AMessage> &msg) { 62 handleMessage(msg); 63 } 64 65 struct PortDescription : public CodecBase::PortDescription { 66 size_t countBuffers(); 67 IOMX::buffer_id bufferIDAt(size_t index) const; 68 sp<ABuffer> bufferAt(size_t index) const; 69 70 private: 71 friend struct ACodec; 72 73 Vector<IOMX::buffer_id> mBufferIDs; 74 Vector<sp<ABuffer> > mBuffers; 75 76 PortDescription(); 77 void addBuffer(IOMX::buffer_id id, const sp<ABuffer> &buffer); 78 79 DISALLOW_EVIL_CONSTRUCTORS(PortDescription); 80 }; 81 82 static bool isFlexibleColorFormat( 83 const sp<IOMX> &omx, IOMX::node_id node, 84 uint32_t colorFormat, bool usingNativeBuffers, OMX_U32 *flexibleEquivalent); 85 86 // Returns 0 if configuration is not supported. NOTE: this is treated by 87 // some OMX components as auto level, and by others as invalid level. 88 static int /* OMX_VIDEO_AVCLEVELTYPE */ getAVCLevelFor( 89 int width, int height, int rate, int bitrate, 90 OMX_VIDEO_AVCPROFILETYPE profile = OMX_VIDEO_AVCProfileBaseline); 91 92protected: 93 virtual ~ACodec(); 94 95private: 96 struct BaseState; 97 struct UninitializedState; 98 struct LoadedState; 99 struct LoadedToIdleState; 100 struct IdleToExecutingState; 101 struct ExecutingState; 102 struct OutputPortSettingsChangedState; 103 struct ExecutingToIdleState; 104 struct IdleToLoadedState; 105 struct FlushingState; 106 struct DeathNotifier; 107 108 enum { 109 kWhatSetup = 'setu', 110 kWhatOMXMessage = 'omx ', 111 kWhatInputBufferFilled = 'inpF', 112 kWhatOutputBufferDrained = 'outD', 113 kWhatShutdown = 'shut', 114 kWhatFlush = 'flus', 115 kWhatResume = 'resm', 116 kWhatDrainDeferredMessages = 'drai', 117 kWhatAllocateComponent = 'allo', 118 kWhatConfigureComponent = 'conf', 119 kWhatSetSurface = 'setS', 120 kWhatCreateInputSurface = 'cisf', 121 kWhatSetInputSurface = 'sisf', 122 kWhatSignalEndOfInputStream = 'eois', 123 kWhatStart = 'star', 124 kWhatRequestIDRFrame = 'ridr', 125 kWhatSetParameters = 'setP', 126 kWhatSubmitOutputMetaDataBufferIfEOS = 'subm', 127 kWhatOMXDied = 'OMXd', 128 kWhatReleaseCodecInstance = 'relC', 129 }; 130 131 enum { 132 kPortIndexInput = 0, 133 kPortIndexOutput = 1 134 }; 135 136 enum { 137 kFlagIsSecure = 1, 138 kFlagPushBlankBuffersToNativeWindowOnShutdown = 2, 139 kFlagIsGrallocUsageProtected = 4, 140 }; 141 142 struct BufferInfo { 143 enum Status { 144 OWNED_BY_US, 145 OWNED_BY_COMPONENT, 146 OWNED_BY_UPSTREAM, 147 OWNED_BY_DOWNSTREAM, 148 OWNED_BY_NATIVE_WINDOW, 149 }; 150 151 IOMX::buffer_id mBufferID; 152 Status mStatus; 153 unsigned mDequeuedAt; 154 155 sp<ABuffer> mData; 156 sp<GraphicBuffer> mGraphicBuffer; 157 }; 158 159#if TRACK_BUFFER_TIMING 160 struct BufferStats { 161 int64_t mEmptyBufferTimeUs; 162 int64_t mFillBufferDoneTimeUs; 163 }; 164 165 KeyedVector<int64_t, BufferStats> mBufferStats; 166#endif 167 168 sp<AMessage> mNotify; 169 170 sp<UninitializedState> mUninitializedState; 171 sp<LoadedState> mLoadedState; 172 sp<LoadedToIdleState> mLoadedToIdleState; 173 sp<IdleToExecutingState> mIdleToExecutingState; 174 sp<ExecutingState> mExecutingState; 175 sp<OutputPortSettingsChangedState> mOutputPortSettingsChangedState; 176 sp<ExecutingToIdleState> mExecutingToIdleState; 177 sp<IdleToLoadedState> mIdleToLoadedState; 178 sp<FlushingState> mFlushingState; 179 sp<SkipCutBuffer> mSkipCutBuffer; 180 181 AString mComponentName; 182 uint32_t mFlags; 183 uint32_t mQuirks; 184 sp<IOMX> mOMX; 185 IOMX::node_id mNode; 186 sp<MemoryDealer> mDealer[2]; 187 188 sp<ANativeWindow> mNativeWindow; 189 sp<AMessage> mInputFormat; 190 sp<AMessage> mOutputFormat; 191 sp<AMessage> mBaseOutputFormat; 192 193 Vector<BufferInfo> mBuffers[2]; 194 bool mPortEOS[2]; 195 status_t mInputEOSResult; 196 197 List<sp<AMessage> > mDeferredQueue; 198 199 bool mSentFormat; 200 bool mIsVideo; 201 bool mIsEncoder; 202 bool mUseMetadataOnEncoderOutput; 203 bool mShutdownInProgress; 204 bool mExplicitShutdown; 205 206 // If "mKeepComponentAllocated" we only transition back to Loaded state 207 // and do not release the component instance. 208 bool mKeepComponentAllocated; 209 210 int32_t mEncoderDelay; 211 int32_t mEncoderPadding; 212 int32_t mRotationDegrees; 213 214 bool mChannelMaskPresent; 215 int32_t mChannelMask; 216 unsigned mDequeueCounter; 217 bool mStoreMetaDataInOutputBuffers; 218 int32_t mMetaDataBuffersToSubmit; 219 size_t mNumUndequeuedBuffers; 220 221 int64_t mRepeatFrameDelayUs; 222 int64_t mMaxPtsGapUs; 223 float mMaxFps; 224 225 int64_t mTimePerFrameUs; 226 int64_t mTimePerCaptureUs; 227 228 bool mCreateInputBuffersSuspended; 229 230 bool mTunneled; 231 232 status_t setCyclicIntraMacroblockRefresh(const sp<AMessage> &msg, int32_t mode); 233 status_t allocateBuffersOnPort(OMX_U32 portIndex); 234 status_t freeBuffersOnPort(OMX_U32 portIndex); 235 status_t freeBuffer(OMX_U32 portIndex, size_t i); 236 237 status_t handleSetSurface(const sp<Surface> &surface); 238 status_t setupNativeWindowSizeFormatAndUsage(ANativeWindow *nativeWindow /* nonnull */); 239 240 status_t configureOutputBuffersFromNativeWindow( 241 OMX_U32 *nBufferCount, OMX_U32 *nBufferSize, 242 OMX_U32 *nMinUndequeuedBuffers); 243 status_t allocateOutputMetaDataBuffers(); 244 status_t submitOutputMetaDataBuffer(); 245 void signalSubmitOutputMetaDataBufferIfEOS_workaround(); 246 status_t allocateOutputBuffersFromNativeWindow(); 247 status_t cancelBufferToNativeWindow(BufferInfo *info); 248 status_t freeOutputBuffersNotOwnedByComponent(); 249 BufferInfo *dequeueBufferFromNativeWindow(); 250 251 BufferInfo *findBufferByID( 252 uint32_t portIndex, IOMX::buffer_id bufferID, 253 ssize_t *index = NULL); 254 255 status_t setComponentRole(bool isEncoder, const char *mime); 256 status_t configureCodec(const char *mime, const sp<AMessage> &msg); 257 258 status_t configureTunneledVideoPlayback(int32_t audioHwSync, 259 const sp<ANativeWindow> &nativeWindow); 260 261 status_t setVideoPortFormatType( 262 OMX_U32 portIndex, 263 OMX_VIDEO_CODINGTYPE compressionFormat, 264 OMX_COLOR_FORMATTYPE colorFormat, 265 bool usingNativeBuffers = false); 266 267 status_t setSupportedOutputFormat(bool getLegacyFlexibleFormat); 268 269 status_t setupVideoDecoder( 270 const char *mime, const sp<AMessage> &msg, bool usingNativeBuffers); 271 272 status_t setupVideoEncoder( 273 const char *mime, const sp<AMessage> &msg); 274 275 status_t setVideoFormatOnPort( 276 OMX_U32 portIndex, 277 int32_t width, int32_t height, 278 OMX_VIDEO_CODINGTYPE compressionFormat, float frameRate = -1.0); 279 280 typedef struct drcParams { 281 int32_t drcCut; 282 int32_t drcBoost; 283 int32_t heavyCompression; 284 int32_t targetRefLevel; 285 int32_t encodedTargetLevel; 286 } drcParams_t; 287 288 status_t setupAACCodec( 289 bool encoder, 290 int32_t numChannels, int32_t sampleRate, int32_t bitRate, 291 int32_t aacProfile, bool isADTS, int32_t sbrMode, 292 int32_t maxOutputChannelCount, const drcParams_t& drc, 293 int32_t pcmLimiterEnable); 294 295 status_t setupAC3Codec(bool encoder, int32_t numChannels, int32_t sampleRate); 296 297 status_t setupEAC3Codec(bool encoder, int32_t numChannels, int32_t sampleRate); 298 299 status_t selectAudioPortFormat( 300 OMX_U32 portIndex, OMX_AUDIO_CODINGTYPE desiredFormat); 301 302 status_t setupAMRCodec(bool encoder, bool isWAMR, int32_t bitRate); 303 status_t setupG711Codec(bool encoder, int32_t sampleRate, int32_t numChannels); 304 305 status_t setupFlacCodec( 306 bool encoder, int32_t numChannels, int32_t sampleRate, int32_t compressionLevel); 307 308 status_t setupRawAudioFormat( 309 OMX_U32 portIndex, int32_t sampleRate, int32_t numChannels); 310 311 status_t setPriority(int32_t priority); 312 status_t setOperatingRate(float rateFloat, bool isVideo); 313 314 status_t setMinBufferSize(OMX_U32 portIndex, size_t size); 315 316 status_t setupMPEG4EncoderParameters(const sp<AMessage> &msg); 317 status_t setupH263EncoderParameters(const sp<AMessage> &msg); 318 status_t setupAVCEncoderParameters(const sp<AMessage> &msg); 319 status_t setupHEVCEncoderParameters(const sp<AMessage> &msg); 320 status_t setupVPXEncoderParameters(const sp<AMessage> &msg); 321 322 status_t verifySupportForProfileAndLevel(int32_t profile, int32_t level); 323 324 status_t configureBitrate( 325 int32_t bitrate, OMX_VIDEO_CONTROLRATETYPE bitrateMode); 326 327 status_t setupErrorCorrectionParameters(); 328 329 status_t initNativeWindow(); 330 331 // Returns true iff all buffers on the given port have status 332 // OWNED_BY_US or OWNED_BY_NATIVE_WINDOW. 333 bool allYourBuffersAreBelongToUs(OMX_U32 portIndex); 334 335 bool allYourBuffersAreBelongToUs(); 336 337 void waitUntilAllPossibleNativeWindowBuffersAreReturnedToUs(); 338 339 size_t countBuffersOwnedByComponent(OMX_U32 portIndex) const; 340 size_t countBuffersOwnedByNativeWindow() const; 341 342 void deferMessage(const sp<AMessage> &msg); 343 void processDeferredMessages(); 344 345 void sendFormatChange(const sp<AMessage> &reply); 346 status_t getPortFormat(OMX_U32 portIndex, sp<AMessage> ¬ify); 347 348 void signalError( 349 OMX_ERRORTYPE error = OMX_ErrorUndefined, 350 status_t internalError = UNKNOWN_ERROR); 351 352 static bool describeDefaultColorFormat(DescribeColorFormatParams &describeParams); 353 static bool describeColorFormat( 354 const sp<IOMX> &omx, IOMX::node_id node, 355 DescribeColorFormatParams &describeParams); 356 357 status_t requestIDRFrame(); 358 status_t setParameters(const sp<AMessage> ¶ms); 359 360 // Send EOS on input stream. 361 void onSignalEndOfInputStream(); 362 363 DISALLOW_EVIL_CONSTRUCTORS(ACodec); 364}; 365 366} // namespace android 367 368#endif // A_CODEC_H_ 369