diff options
| author | Tianmi Chen <tianmi.chen@intel.com> | 2012-12-06 14:42:38 +0800 |
|---|---|---|
| committer | Patrick Tjin <pattjin@google.com> | 2014-07-21 22:02:49 -0700 |
| commit | ab82a0fd294f033d336bc53cdffe8d1708d947cc (patch) | |
| tree | 49909fa7c449bd300c7a11c2a06fc970cccf4115 /videocodec/OMXVideoDecoderVP8.cpp | |
| parent | 581979066482365350af7089402ab028c9e912dd (diff) | |
| download | android_hardware_intel_common_omx-components-ab82a0fd294f033d336bc53cdffe8d1708d947cc.tar.gz android_hardware_intel_common_omx-components-ab82a0fd294f033d336bc53cdffe8d1708d947cc.tar.bz2 android_hardware_intel_common_omx-components-ab82a0fd294f033d336bc53cdffe8d1708d947cc.zip | |
[PORT FROM MAIN]omx-components: Add VP8 middleware support for Merrifield
BZ: 73094
Add VP8 middleware support for Merrifield
Change-Id: I6c49dced2f7603a4ad30f959deb69fc31158bd7b
Signed-off-by: Tianmi Chen <tianmi.chen@intel.com>
Reviewed-on: http://android.intel.com:8080/82329
Reviewed-by: Ding, Haitao <haitao.ding@intel.com>
Tested-by: Ding, Haitao <haitao.ding@intel.com>
Reviewed-by: cactus <cactus@intel.com>
Tested-by: cactus <cactus@intel.com>
Diffstat (limited to 'videocodec/OMXVideoDecoderVP8.cpp')
| -rw-r--r-- | videocodec/OMXVideoDecoderVP8.cpp | 112 |
1 files changed, 112 insertions, 0 deletions
diff --git a/videocodec/OMXVideoDecoderVP8.cpp b/videocodec/OMXVideoDecoderVP8.cpp new file mode 100644 index 0000000..2b24b3e --- /dev/null +++ b/videocodec/OMXVideoDecoderVP8.cpp @@ -0,0 +1,112 @@ +/* +* Copyright (c) 2012 Intel Corporation. All rights reserved. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + + +// #define LOG_NDEBUG 0 +#define LOG_TAG "OMXVideoDecoder" +#include <utils/Log.h> +#include "OMXVideoDecoderVP8.h" + +// Be sure to have an equal string in VideoDecoderHost.cpp (libmix) +static const char* VP8_MIME_TYPE = "video/x-vnd.on2.vp8"; + +OMXVideoDecoderVP8::OMXVideoDecoderVP8() { + LOGV("OMXVideoDecoderVP8 is constructed."); + mVideoDecoder = createVideoDecoder(VP8_MIME_TYPE); + if (!mVideoDecoder) { + LOGE("createVideoDecoder failed for \"%s\"", VP8_MIME_TYPE); + } + BuildHandlerList(); +} + +OMXVideoDecoderVP8::~OMXVideoDecoderVP8() { + LOGV("OMXVideoDecoderVP8 is destructed."); +} + +OMX_ERRORTYPE OMXVideoDecoderVP8::InitInputPortFormatSpecific(OMX_PARAM_PORTDEFINITIONTYPE *paramPortDefinitionInput) { + // OMX_PARAM_PORTDEFINITIONTYPE + paramPortDefinitionInput->nBufferCountActual = INPORT_ACTUAL_BUFFER_COUNT; + paramPortDefinitionInput->nBufferCountMin = INPORT_MIN_BUFFER_COUNT; + paramPortDefinitionInput->nBufferSize = INPORT_BUFFER_SIZE; + paramPortDefinitionInput->format.video.cMIMEType = (OMX_STRING)VP8_MIME_TYPE; + paramPortDefinitionInput->format.video.eCompressionFormat = OMX_VIDEO_CodingVPX; + + // OMX_VIDEO_PARAM_VP8TYPE + memset(&mParamVp8, 0, sizeof(mParamVp8)); + SetTypeHeader(&mParamVp8, sizeof(mParamVp8)); + mParamVp8.nPortIndex = INPORT_INDEX; + mParamVp8.eProfile = OMX_VIDEO_VP8ProfileMain; + mParamVp8.eLevel = OMX_VIDEO_VP8Level_Version0; + + return OMX_ErrorNone; +} + +OMX_ERRORTYPE OMXVideoDecoderVP8::ProcessorInit(void) { + return OMXVideoDecoderBase::ProcessorInit(); +} + +OMX_ERRORTYPE OMXVideoDecoderVP8::ProcessorDeinit(void) { + return OMXVideoDecoderBase::ProcessorDeinit(); +} + +OMX_ERRORTYPE OMXVideoDecoderVP8::ProcessorProcess( + OMX_BUFFERHEADERTYPE ***pBuffers, + buffer_retain_t *retains, + OMX_U32 numberBuffers) { + + return OMXVideoDecoderBase::ProcessorProcess(pBuffers, retains, numberBuffers); +} + +OMX_ERRORTYPE OMXVideoDecoderVP8::PrepareConfigBuffer(VideoConfigBuffer *p) { + return OMXVideoDecoderBase::PrepareConfigBuffer(p); +} + +OMX_ERRORTYPE OMXVideoDecoderVP8::PrepareDecodeBuffer(OMX_BUFFERHEADERTYPE *buffer, buffer_retain_t *retain, VideoDecodeBuffer *p) { + return OMXVideoDecoderBase::PrepareDecodeBuffer(buffer, retain, p); +} + +OMX_ERRORTYPE OMXVideoDecoderVP8::BuildHandlerList(void) { + OMXVideoDecoderBase::BuildHandlerList(); + AddHandler(OMX_IndexParamVideoVp8, GetParamVideoVp8, SetParamVideoVp8); + return OMX_ErrorNone; +} + +OMX_ERRORTYPE OMXVideoDecoderVP8::GetParamVideoVp8(OMX_PTR pStructure) { + OMX_ERRORTYPE ret; + OMX_VIDEO_PARAM_VP8TYPE *p = (OMX_VIDEO_PARAM_VP8TYPE *)pStructure; + CHECK_TYPE_HEADER(p); + CHECK_PORT_INDEX(p, INPORT_INDEX); + + memcpy(p, &mParamVp8, sizeof(*p)); + return OMX_ErrorNone; +} + +OMX_ERRORTYPE OMXVideoDecoderVP8::SetParamVideoVp8(OMX_PTR pStructure) { + OMX_ERRORTYPE ret; + OMX_VIDEO_PARAM_VP8TYPE *p = (OMX_VIDEO_PARAM_VP8TYPE *)pStructure; + CHECK_TYPE_HEADER(p); + CHECK_PORT_INDEX(p, INPORT_INDEX); + CHECK_SET_PARAM_STATE(); + + // TODO: do we need to check if port is enabled? + memcpy(&mParamVp8, p, sizeof(mParamVp8)); + return OMX_ErrorNone; +} + + +DECLARE_OMX_COMPONENT("OMX.Intel.VideoDecoder.VPX", "video_decoder.vpx", OMXVideoDecoderVP8); + + |
