aboutsummaryrefslogtreecommitdiffstats
path: root/videocodec/OMXVideoDecoderVP8.cpp
diff options
context:
space:
mode:
authorTianmi Chen <tianmi.chen@intel.com>2012-12-06 14:42:38 +0800
committerPatrick Tjin <pattjin@google.com>2014-07-21 22:02:49 -0700
commitab82a0fd294f033d336bc53cdffe8d1708d947cc (patch)
tree49909fa7c449bd300c7a11c2a06fc970cccf4115 /videocodec/OMXVideoDecoderVP8.cpp
parent581979066482365350af7089402ab028c9e912dd (diff)
downloadandroid_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.cpp112
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);
+
+