diff options
Diffstat (limited to 'media/omx')
-rw-r--r-- | media/omx/omx_video_decoder.cc | 87 | ||||
-rw-r--r-- | media/omx/omx_video_decoder.h | 2 |
2 files changed, 46 insertions, 43 deletions
diff --git a/media/omx/omx_video_decoder.cc b/media/omx/omx_video_decoder.cc index 1b2f416..b5857ed 100644 --- a/media/omx/omx_video_decoder.cc +++ b/media/omx/omx_video_decoder.cc @@ -2,6 +2,7 @@ // source code is governed by a BSD-style license that can be found in the // LICENSE file. +#include "base/logging.h" #include "base/message_loop.h" #include "base/stl_util-inl.h" #include "media/omx/input_buffer.h" @@ -9,6 +10,13 @@ namespace media { +template <typename T> +static void ResetPortHeader(const OmxVideoDecoder& dec, T* param) { + memset(param, 0, sizeof(T)); + param->nVersion.nVersion = dec.current_omx_spec_version(); + param->nSize = sizeof(T); +} + OmxVideoDecoder::OmxVideoDecoder(MessageLoop* message_loop) : input_buffer_count_(0), input_buffer_size_(0), @@ -272,7 +280,7 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { // TODO(hclam): move this out. OMX_ERRORTYPE omxresult = OMX_Init(); if (omxresult != OMX_ErrorNone) { - printf("Error - Failed to Init OpenMAX core\n"); + LOG(ERROR) << "Error - Failed to Init OpenMAX core"; StateTransitionTask(kError); return; } @@ -284,7 +292,7 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { omxresult = OMX_GetHandle((OMX_HANDLETYPE*)(&decoder_handle_), (OMX_STRING)component, this, &callback); if (omxresult != OMX_ErrorNone) { - printf("Failed to Load the component: %s\n", component); + LOG(ERROR) << "Failed to Load the component: " << component; StateTransitionTask(kError); return; } @@ -292,13 +300,11 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { // 3. Get the port information. This will obtain information about the // number of ports and index of the first port. OMX_PORT_PARAM_TYPE port_param; - memset(&port_param, 0, sizeof(port_param)); - port_param.nVersion.nVersion = current_omx_spec_version(); - port_param.nSize = sizeof(port_param); + ResetPortHeader(*this, &port_param); omxresult = OMX_GetParameter(decoder_handle_, OMX_IndexParamVideoInit, &port_param); if (omxresult != OMX_ErrorNone) { - printf("ERROR - Failed to get Port Param\n"); + LOG(ERROR) << "ERROR - Failed to get Port Param"; StateTransitionTask(kError); return; } @@ -307,7 +313,7 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { // 4. Device specific configurations. if (!DeviceSpecificConfig()) { - printf("Error - device specific configurations failed\n"); + LOG(ERROR) << "Error - device specific configurations failed"; StateTransitionTask(kError); return; } @@ -317,20 +323,18 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { // Note that port_param.nStartPortNumber defines the index of the // input port. OMX_PARAM_PORTDEFINITIONTYPE port_format; - memset(&port_format, 0, sizeof(port_format)); - port_format.nVersion.nVersion = current_omx_spec_version(); - port_format.nSize = sizeof(port_format); + ResetPortHeader(*this, &port_format); port_format.nPortIndex = input_port_; omxresult = OMX_GetParameter(decoder_handle_, OMX_IndexParamPortDefinition, &port_format); if (omxresult != OMX_ErrorNone) { - printf("Error - GetParameter failed\n"); + LOG(ERROR) << "Error - GetParameter failed"; StateTransitionTask(kError); return; } if(OMX_DirInput != port_format.eDir) { - printf ("Error - Expect Input Port\n"); + LOG(ERROR) << "Error - Expect Input Port"; StateTransitionTask(kError); return; } @@ -343,7 +347,7 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { else if (codec_ == kCodecVc1) port_format.format.video.eCompressionFormat = OMX_VIDEO_CodingWMV; else - printf("Error: Unsupported codec %d\n", codec_); + LOG(ERROR) << "Error: Unsupported codec " << codec_; // Assume QCIF. port_format.format.video.nFrameWidth = 176; port_format.format.video.nFrameHeight = 144; @@ -351,7 +355,7 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { OMX_IndexParamPortDefinition, &port_format); if (omxresult != OMX_ErrorNone) { - printf("Error - SetParameter failed\n"); + LOG(ERROR) << "Error - SetParameter failed"; StateTransitionTask(kError); return; } @@ -367,12 +371,12 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { OMX_IndexParamPortDefinition, &port_format); if (omxresult != OMX_ErrorNone) { - printf("Error - GetParameter failed\n"); + LOG(ERROR) << "Error - GetParameter failed"; StateTransitionTask(kError); return; } if (OMX_DirInput != port_format.eDir) { - printf("Error - Expect input port\n"); + LOG(ERROR) << "Error - Expect input port"; StateTransitionTask(kError); return; } @@ -380,18 +384,18 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { input_buffer_size_ = port_format.nBufferSize; // 8. Obtain the information about the output port. - memset(&port_format, 0, sizeof(port_format)); + ResetPortHeader(*this, &port_format); port_format.nPortIndex = output_port_; omxresult = OMX_GetParameter(decoder_handle_, OMX_IndexParamPortDefinition, &port_format); if (omxresult != OMX_ErrorNone) { - printf("Error - GetParameter failed\n"); + LOG(ERROR) << "Error - GetParameter failed"; StateTransitionTask(kError); return; } if (OMX_DirOutput != port_format.eDir) { - printf("Error - Expect Output Port\n"); + LOG(ERROR) << "Error - Expect Output Port"; StateTransitionTask(kError); return; } @@ -407,7 +411,7 @@ void OmxVideoDecoder::Transition_EmptyToLoaded() { omxresult = OMX_SetConfig(decoder_handle_, OMX_IndexConfigVideoNalSize, (OMX_PTR)&naluSize); if (omxresult != OMX_ErrorNone) { - printf("Error - SetConfig failed\n"); + LOG(ERROR) << "Error - SetConfig failed"; StateTransitionTask(kError); return; } @@ -431,21 +435,21 @@ void OmxVideoDecoder::Transition_LoadedToIdle() { OMX_CommandStateSet, OMX_StateIdle, 0); if (omxresult != OMX_ErrorNone) { - printf("Error - SendCommand failed\n"); + LOG(ERROR) << "Error - SendCommand failed"; StateTransitionTask(kError); return; } // 2. Allocate buffer for the input port. if (!AllocateInputBuffers()) { - printf("Error - OMX_AllocateBuffer Input buffer error\n"); + LOG(ERROR) << "Error - OMX_AllocateBuffer Input buffer error"; StateTransitionTask(kError); return; } // 3. Allocate buffer for the output port. if (!AllocateOutputBuffers()) { - printf("Error - OMX_AllocateBuffer Output buffer error\n"); + LOG(ERROR) << "Error - OMX_AllocateBuffer Output buffer error"; StateTransitionTask(kError); return; } @@ -463,7 +467,7 @@ void OmxVideoDecoder::Transition_IdleToExecuting() { OMX_CommandStateSet, OMX_StateExecuting, 0); if (omxresult != OMX_ErrorNone) { - printf("Error - SendCommand failed\n"); + LOG(ERROR) << "Error - SendCommand failed"; StateTransitionTask(kError); return; } @@ -482,7 +486,7 @@ void OmxVideoDecoder::Transition_ExecutingToDisable() { OMX_CommandPortDisable, output_port_, 0); if (omxresult != OMX_ErrorNone) { - printf("Error - SendCommand failed\n"); + LOG(ERROR) << "Error - SendCommand failed"; StateTransitionTask(kError); return; } @@ -505,25 +509,24 @@ void OmxVideoDecoder::Transition_DisableToEnable() { OMX_CommandPortEnable, output_port_, 0); if (omxresult != OMX_ErrorNone) { - printf("Error - SendCommand failed\n"); + LOG(ERROR) << "Error - SendCommand failed"; StateTransitionTask(kError); return; } // AllocateBuffers. OMX_PARAM_PORTDEFINITIONTYPE port_format; - memset(&port_format, 0, sizeof(port_format)); + ResetPortHeader(*this, &port_format); port_format.nPortIndex = output_port_; - omxresult = OMX_GetParameter(decoder_handle_, OMX_IndexParamPortDefinition, &port_format); if (omxresult != OMX_ErrorNone) { - printf("Error - GetParameter failed\n"); + LOG(ERROR) << "Error - GetParameter failed"; StateTransitionTask(kError); return; } if (OMX_DirOutput != port_format.eDir) { - printf("Error - Expect Output Port\n"); + LOG(ERROR) << "Error - Expect Output Port"; StateTransitionTask(kError); return; } @@ -532,7 +535,7 @@ void OmxVideoDecoder::Transition_DisableToEnable() { output_buffer_count_ = port_format.nBufferCountActual; output_buffer_size_ = port_format.nBufferSize; if (!AllocateOutputBuffers()) { - printf("Error - OMX_AllocateBuffer Output buffer error\n"); + LOG(ERROR) << "Error - OMX_AllocateBuffer Output buffer error"; StateTransitionTask(kError); return; } @@ -549,7 +552,7 @@ void OmxVideoDecoder::Transition_DisableToIdle() { OMX_CommandStateSet, OMX_StateIdle, 0); if (omxresult != OMX_ErrorNone) { - printf("Error - SendCommand failed\n"); + LOG(ERROR) << "Error - SendCommand failed"; StateTransitionTask(kError); return; } @@ -574,7 +577,7 @@ void OmxVideoDecoder::Transition_EnableToIdle() { OMX_CommandStateSet, OMX_StateIdle, 0); if (omxresult != OMX_ErrorNone) { - printf("Error - SendCommand failed\n"); + LOG(ERROR) << "Error - SendCommand failed"; StateTransitionTask(kError); return; } @@ -591,7 +594,7 @@ void OmxVideoDecoder::Transition_ExecutingToIdle() { OMX_CommandStateSet, OMX_StateIdle, 0); if (omxresult != OMX_ErrorNone) { - printf("Error - SendCommand failed\n"); + LOG(ERROR) << "Error - SendCommand failed"; StateTransitionTask(kError); return; } @@ -610,7 +613,7 @@ void OmxVideoDecoder::Transition_IdleToLoaded() { OMX_CommandStateSet, OMX_StateLoaded, 0); if (omxresult != OMX_ErrorNone) { - printf("Error - SendCommand failed\n"); + LOG(ERROR) << "Error - SendCommand failed"; StateTransitionTask(kError); return; } @@ -630,7 +633,7 @@ void OmxVideoDecoder::Transition_LoadedToEmpty() { // Free the decoder handle. OMX_ERRORTYPE result = OMX_FreeHandle(decoder_handle_); if (result != OMX_ErrorNone) { - printf("Error - Terminate: OMX_FreeHandle error. Error code: %d\n", result); + LOG(ERROR) << "Error - Terminate: OMX_FreeHandle error. Error code: " << result; } decoder_handle_ = NULL; @@ -677,7 +680,7 @@ void OmxVideoDecoder::Transition_Error() { if (decoder_handle_) { OMX_ERRORTYPE result = OMX_FreeHandle(decoder_handle_); if (result != OMX_ErrorNone) - printf("Error - OMX_FreeHandle error. Error code: %d\n", result); + LOG(ERROR) << "Error - OMX_FreeHandle error. Error code: " << result; decoder_handle_ = NULL; } @@ -914,7 +917,7 @@ void OmxVideoDecoder::EmptyBufferTask() { // Give this buffer to OMX. OMX_ERRORTYPE ret = OMX_EmptyThisBuffer(decoder_handle_, omx_buffer); if (ret != OMX_ErrorNone) { - printf("ERROR - OMX_EmptyThisBuffer failed with result %d\n", ret); + LOG(ERROR) << "ERROR - OMX_EmptyThisBuffer failed with result " << ret; StateTransitionTask(kError); return; } @@ -964,7 +967,7 @@ void OmxVideoDecoder::FillBufferTask() { omx_buffer->nFlags &= ~OMX_BUFFERFLAG_EOS; OMX_ERRORTYPE ret = OMX_FillThisBuffer(decoder_handle_, omx_buffer); if (OMX_ErrorNone != ret) { - printf("Error - OMX_FillThisBuffer failed with result %d\n", ret); + LOG(ERROR) << "Error - OMX_FillThisBuffer failed with result " << ret; StateTransitionTask(kError); return; } @@ -1003,7 +1006,7 @@ void OmxVideoDecoder::InitialFillBuffer() { OMX_ERRORTYPE ret = OMX_FillThisBuffer(decoder_handle_, omx_buffer); if (OMX_ErrorNone != ret) { - printf("Error - OMX_FillThisBuffer failed with result %d\n", ret); + LOG(ERROR) << "Error - OMX_FillThisBuffer failed with result " << ret; StateTransitionTask(kError); return; } @@ -1028,7 +1031,7 @@ void OmxVideoDecoder::EventHandlerInternal(OMX_HANDLETYPE component, } else if (cmd == OMX_CommandStateSet) { PostDoneStateTransitionTask(); } else { - printf("Unknown command completed\n"); + LOG(ERROR) << "Unknown command completed\n"; } break; } @@ -1042,7 +1045,7 @@ void OmxVideoDecoder::EventHandlerInternal(OMX_HANDLETYPE component, PostStateTransitionTask(kPortSettingDisable); break; default: - printf("Warning - Unknown event received\n"); + LOG(ERROR) << "Warning - Unknown event received\n"; break; } } diff --git a/media/omx/omx_video_decoder.h b/media/omx/omx_video_decoder.h index baf3c51..1d247f2 100644 --- a/media/omx/omx_video_decoder.h +++ b/media/omx/omx_video_decoder.h @@ -137,7 +137,7 @@ class OmxVideoDecoder : public base::RefCountedThreadSafe<OmxVideoDecoder> { int output_port() { return output_port_; } // Subclass can provide a different value. - virtual int current_omx_spec_version() { return 0x00000101; } + virtual int current_omx_spec_version() const { return 0x00000101; } protected: // Returns the component name given the codec. |