/* * Copyright 2016 Rockchip Electronics Co. LTD * * 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. */ #include #include "mpp_env.h" #include "mpp_debug.h" #include "mpp_platform.h" #include "mpp_hal.h" #include "hal_h263d_base.h" #include "hal_h263d_vdpu1.h" #include "hal_h263d_vdpu2.h" RK_U32 h263d_hal_debug = 0; void vpu_h263d_get_buffer_by_index(hal_h263_ctx *ctx, RK_S32 index, MppBuffer *buffer) { if (index >= 0) { mpp_buf_slot_get_prop(ctx->frm_slots, index, SLOT_BUFFER, buffer); mpp_assert(*buffer); } } static MPP_RET hal_h263d_gen_regs(void *hal, HalTaskInfo *task) { hal_h263_ctx *ctx = (hal_h263_ctx *)hal; return ctx->hal_api.reg_gen(hal, task); } static MPP_RET hal_h263d_start(void *hal, HalTaskInfo *task) { hal_h263_ctx *ctx = (hal_h263_ctx *)hal; return ctx->hal_api.start(hal, task); } static MPP_RET hal_h263d_wait(void *hal, HalTaskInfo *task) { hal_h263_ctx *ctx = (hal_h263_ctx *)hal; return ctx->hal_api.wait(hal, task); } static MPP_RET hal_h263d_deinit(void *hal) { hal_h263_ctx *ctx = (hal_h263_ctx *)hal; return ctx->hal_api.deinit(hal); } static MPP_RET hal_h263d_init(void *hal, MppHalCfg *cfg) { MppHalApi *p_api = NULL; hal_h263_ctx *p_hal = (hal_h263_ctx *)hal; VpuHwMode hw_mode = MODE_NULL; RK_U32 hw_flag = 0; mpp_env_get_u32("h263d_hal_debug", &h263d_hal_debug, 0); memset(p_hal, 0, sizeof(hal_h263_ctx)); p_api = &p_hal->hal_api; p_hal->frm_slots = cfg->frame_slots; p_hal->pkt_slots = cfg->packet_slots; hw_flag = mpp_get_vcodec_type(); if (hw_flag & HAVE_VDPU2) hw_mode = VDPU2_MODE; if (hw_flag & HAVE_VDPU1) hw_mode = VDPU1_MODE; switch (hw_mode) { case VDPU2_MODE : { mpp_log("the VDPU2_MODE is used currently!\n"); p_api->init = hal_vpu2_h263d_init; p_api->deinit = hal_vpu2_h263d_deinit; p_api->reg_gen = hal_vpu2_h263d_gen_regs; p_api->start = hal_vpu2_h263d_start; p_api->wait = hal_vpu2_h263d_wait; p_api->reset = NULL; p_api->flush = NULL; p_api->control = NULL; } break; case VDPU1_MODE : { mpp_log("the VDPU1_MODE is used currently!\n"); p_api->init = hal_vpu1_h263d_init; p_api->deinit = hal_vpu1_h263d_deinit; p_api->reg_gen = hal_vpu1_h263d_gen_regs; p_api->start = hal_vpu1_h263d_start; p_api->wait = hal_vpu1_h263d_wait; p_api->reset = NULL; p_api->flush = NULL; p_api->control = NULL; } break; default : { mpp_err("unknow vpu type:%d.", hw_mode); return MPP_ERR_INIT; } break; } return p_api->init(hal, cfg); } const MppHalApi hal_api_h263d = { "h263d_vpu", MPP_CTX_DEC, MPP_VIDEO_CodingH263, sizeof(hal_h263_ctx), 0, hal_h263d_init, hal_h263d_deinit, hal_h263d_gen_regs, hal_h263d_start, hal_h263d_wait, NULL, NULL, NULL, };