/* * Copyright 2015 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. */ #define MODULE_TAG "mpp_dec" #include #include "mpp_mem.h" #include "mpp_log.h" #include "mpp_common.h" #include "mpp_parser.h" #include "h263d_api.h" #include "h264d_api.h" #include "h265d_api.h" #include "vp9d_api.h" #include "avsd_api.h" #include "m2vd_api.h" #include "mpg4d_api.h" #include "vp8d_api.h" #include "jpegd_api.h" #include "av1d_api.h" // for test and demo #include "dummy_dec_api.h" /* * all decoder static register here */ static const ParserApi *parsers[] = { #if HAVE_AVSD &api_avsd_parser, #endif #if HAVE_H263D &api_h263d_parser, #endif #if HAVE_H264D &api_h264d_parser, #endif #if HAVE_H265D &api_h265d_parser, #endif #if HAVE_MPEG2D &api_m2vd_parser, #endif #if HAVE_MPEG4D &api_mpg4d_parser, #endif #if HAVE_VP8D &api_vp8d_parser, #endif #if HAVE_VP9D &api_vp9d_parser, #endif #if HAVE_JPEGD &api_jpegd_parser, #endif &dummy_dec_parser, #if HAVE_AV1D &api_av1d_parser, #endif }; typedef struct ParserImpl_t { const ParserApi *api; void *ctx; } ParserImpl; MPP_RET mpp_parser_init(Parser *prs, ParserCfg *cfg) { if (NULL == prs || NULL == cfg) { mpp_err_f("found NULL input parser %p config %p\n", prs, cfg); return MPP_ERR_NULL_PTR; } *prs = NULL; RK_U32 i; for (i = 0; i < MPP_ARRAY_ELEMS(parsers); i++) { const ParserApi *api = parsers[i]; if (cfg->coding == api->coding) { ParserImpl *p = mpp_calloc(ParserImpl, 1); void *ctx = mpp_calloc_size(void, api->ctx_size); if (NULL == ctx || NULL == p) { mpp_err_f("failed to alloc parser context\n"); mpp_free(p); mpp_free(ctx); return MPP_ERR_MALLOC; } MPP_RET ret = api->init(ctx, cfg); if (MPP_OK != ret) { mpp_err_f("failed to init parser\n"); mpp_free(p); mpp_free(ctx); return ret; } p->api = api; p->ctx = ctx; *prs = p; return MPP_OK; } } return MPP_NOK; } MPP_RET mpp_parser_deinit(Parser prs) { if (NULL == prs) { mpp_err_f("found NULL input\n"); return MPP_ERR_NULL_PTR; } ParserImpl *p = (ParserImpl *)prs; if (p->api->deinit) p->api->deinit(p->ctx); mpp_free(p->ctx); mpp_free(p); return MPP_OK; } MPP_RET mpp_parser_prepare(Parser prs, MppPacket pkt, HalDecTask *task) { if (NULL == prs || NULL == pkt) { mpp_err_f("found NULL input\n"); return MPP_ERR_NULL_PTR; } ParserImpl *p = (ParserImpl *)prs; if (!p->api->prepare) return MPP_OK; return p->api->prepare(p->ctx, pkt, task); } MPP_RET mpp_parser_parse(Parser prs, HalDecTask *task) { if (NULL == prs || NULL == task) { mpp_err_f("found NULL input\n"); return MPP_ERR_NULL_PTR; } ParserImpl *p = (ParserImpl *)prs; if (!p->api->parse) return MPP_OK; return p->api->parse(p->ctx, task); } MPP_RET mpp_parser_callback(void *prs, void *err_info) { if (NULL == prs) { mpp_err_f("found NULL input\n"); return MPP_ERR_NULL_PTR; } ParserImpl *p = (ParserImpl *)prs; if (!p->api->callback) return MPP_OK; return p->api->callback(p->ctx, err_info); } MPP_RET mpp_parser_reset(Parser prs) { if (NULL == prs) { mpp_err_f("found NULL input\n"); return MPP_ERR_NULL_PTR; } ParserImpl *p = (ParserImpl *)prs; if (!p->api->reset) return MPP_OK; return p->api->reset(p->ctx); } MPP_RET mpp_parser_flush(Parser prs) { if (NULL == prs) { mpp_err_f("found NULL input\n"); return MPP_ERR_NULL_PTR; } ParserImpl *p = (ParserImpl *)prs; if (!p->api->flush) return MPP_OK; return p->api->flush(p->ctx); } MPP_RET mpp_parser_control(Parser prs, MpiCmd cmd, void *para) { if (NULL == prs) { mpp_err_f("found NULL input\n"); return MPP_ERR_NULL_PTR; } ParserImpl *p = (ParserImpl *)prs; if (!p->api->control) return MPP_OK; return p->api->control(p->ctx, cmd, para); }