mirror of
https://github.com/nyanmisaka/mpp.git
synced 2025-10-05 01:02:39 +08:00

1. Use mem pool to alloc KmppObjImpl 2. Add kmpp_obj_put_impl to release KmppObjImpl header only. 3. Add grp_cfg and buf_cfg release operation. 4. Use MPP_SINGLETON to init kmpp_venc_cfg. Signed-off-by: Herman Chen <herman.chen@rock-chips.com> Change-Id: I865d4d990d7e89598b2f17d85460b809f7f602df
174 lines
4.6 KiB
C
174 lines
4.6 KiB
C
/* SPDX-License-Identifier: Apache-2.0 OR MIT */
|
|
/*
|
|
* Copyright (c) 2024 Rockchip Electronics Co., Ltd.
|
|
*/
|
|
|
|
#define MODULE_TAG "kmpp_venc_cfg"
|
|
|
|
#include <string.h>
|
|
#include <pthread.h>
|
|
|
|
#include "mpp_env.h"
|
|
#include "mpp_mem.h"
|
|
#include "mpp_debug.h"
|
|
#include "mpp_common.h"
|
|
#include "mpp_singleton.h"
|
|
|
|
#include "kmpp_obj.h"
|
|
#include "rk_venc_kcfg.h"
|
|
|
|
#define VENC_KCFG_DBG_FUNC (0x00000001)
|
|
#define VENC_KCFG_DBG_INFO (0x00000002)
|
|
#define VENC_KCFG_DBG_SET (0x00000004)
|
|
#define VENC_KCFG_DBG_GET (0x00000008)
|
|
|
|
#define venc_kcfg_dbg(flag, fmt, ...) _mpp_dbg_f(venc_kcfg_debug, flag, fmt, ## __VA_ARGS__)
|
|
|
|
#define venc_kcfg_dbg_func(fmt, ...) venc_kcfg_dbg(VENC_KCFG_DBG_FUNC, fmt, ## __VA_ARGS__)
|
|
#define venc_kcfg_dbg_info(fmt, ...) venc_kcfg_dbg(VENC_KCFG_DBG_INFO, fmt, ## __VA_ARGS__)
|
|
#define venc_kcfg_dbg_set(fmt, ...) venc_kcfg_dbg(VENC_KCFG_DBG_SET, fmt, ## __VA_ARGS__)
|
|
#define venc_kcfg_dbg_get(fmt, ...) venc_kcfg_dbg(VENC_KCFG_DBG_GET, fmt, ## __VA_ARGS__)
|
|
|
|
static RK_U32 venc_kcfg_debug = 0;
|
|
|
|
static char *kcfg_names[] = {
|
|
[MPP_VENC_KCFG_TYPE_INIT] = "KmppVencInitCfg",
|
|
[MPP_VENC_KCFG_TYPE_DEINIT] = "KmppVencDeinitCfg",
|
|
[MPP_VENC_KCFG_TYPE_RESET] = "KmppVencResetCfg",
|
|
[MPP_VENC_KCFG_TYPE_START] = "KmppVencStartCfg",
|
|
[MPP_VENC_KCFG_TYPE_STOP] = "KmppVencStopCfg",
|
|
};
|
|
static KmppObjDef kcfg_defs[MPP_VENC_KCFG_TYPE_BUTT] = {NULL};
|
|
|
|
static void mpp_venc_kcfg_def_init(void)
|
|
{
|
|
RK_U32 i;
|
|
|
|
for (i = 0; i < MPP_VENC_KCFG_TYPE_BUTT; i++) {
|
|
kmpp_objdef_get(&kcfg_defs[i], kcfg_names[i]);
|
|
}
|
|
}
|
|
|
|
static void mpp_venc_kcfg_def_deinit(void)
|
|
{
|
|
RK_U32 i;
|
|
|
|
for (i = 0; i < MPP_VENC_KCFG_TYPE_BUTT; i++) {
|
|
if (kcfg_defs[i]) {
|
|
kmpp_objdef_put(kcfg_defs[i]);
|
|
kcfg_defs[i] = NULL;
|
|
}
|
|
}
|
|
}
|
|
|
|
MPP_SINGLETON(MPP_SGLN_KMPP_VENC_CFG, kmpp_venc_cfg, mpp_venc_kcfg_def_init, mpp_venc_kcfg_def_deinit)
|
|
|
|
MPP_RET mpp_venc_kcfg_init(MppVencKcfg *cfg, MppVencKcfgType type)
|
|
{
|
|
KmppObj obj = NULL;
|
|
|
|
if (!cfg) {
|
|
mpp_err_f("invalid NULL input config\n");
|
|
return MPP_ERR_NULL_PTR;
|
|
}
|
|
|
|
if (type >= MPP_VENC_KCFG_TYPE_BUTT) {
|
|
mpp_err_f("invalid config type %d\n", type);
|
|
return MPP_ERR_VALUE;
|
|
}
|
|
|
|
mpp_env_get_u32("venc_kcfg_debug", &venc_kcfg_debug, 0);
|
|
|
|
if (kcfg_defs[type])
|
|
kmpp_obj_get_f(&obj, kcfg_defs[type]);
|
|
|
|
*cfg = obj;
|
|
|
|
return obj ? MPP_OK : MPP_NOK;
|
|
}
|
|
|
|
MPP_RET mpp_venc_kcfg_init_by_name(MppVencKcfg *cfg, const char *name)
|
|
{
|
|
KmppObj obj = NULL;
|
|
MppVencKcfgType type = MPP_VENC_KCFG_TYPE_BUTT;
|
|
RK_U32 i;
|
|
|
|
if (!cfg) {
|
|
mpp_err_f("invalid NULL input config\n");
|
|
return MPP_ERR_NULL_PTR;
|
|
}
|
|
|
|
for (i = 0; i < MPP_VENC_KCFG_TYPE_BUTT; i++) {
|
|
if (!strncmp(name, kcfg_names[i], strlen(kcfg_names[i]))) {
|
|
type = i;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (type >= MPP_VENC_KCFG_TYPE_BUTT) {
|
|
mpp_err_f("invalid config name %s\n", name);
|
|
return MPP_ERR_VALUE;
|
|
}
|
|
|
|
mpp_env_get_u32("venc_kcfg_debug", &venc_kcfg_debug, 0);
|
|
|
|
kmpp_obj_get_f(&obj, kcfg_defs[type]);
|
|
|
|
*cfg = obj;
|
|
|
|
return obj ? MPP_OK : MPP_NOK;
|
|
}
|
|
|
|
MPP_RET mpp_venc_kcfg_deinit(MppVencKcfg cfg)
|
|
{
|
|
KmppObj obj = cfg;
|
|
|
|
if (!cfg) {
|
|
mpp_err_f("invalid NULL input config\n");
|
|
return MPP_ERR_NULL_PTR;
|
|
}
|
|
|
|
return kmpp_obj_put_f(obj);
|
|
}
|
|
|
|
#define MPP_VENC_KCFG_ACCESS(set_type, get_type, cfg_type) \
|
|
MPP_RET mpp_venc_kcfg_set_##cfg_type(MppVencKcfg cfg, const char *name, set_type val) \
|
|
{ \
|
|
if (!cfg || !name) { \
|
|
mpp_err_f("invalid input cfg %p name %p\n", cfg, name); \
|
|
return MPP_ERR_NULL_PTR; \
|
|
} \
|
|
KmppObj obj = (KmppObj)cfg; \
|
|
MPP_RET ret = (MPP_RET)kmpp_obj_set_##cfg_type(obj, name, val); \
|
|
return ret; \
|
|
} \
|
|
MPP_RET mpp_venc_kcfg_get_##cfg_type(MppVencKcfg cfg, const char *name, get_type val) \
|
|
{ \
|
|
if (!cfg || !name) { \
|
|
mpp_err_f("invalid input cfg %p name %p\n", cfg, name); \
|
|
return MPP_ERR_NULL_PTR; \
|
|
} \
|
|
KmppObj obj = (KmppObj)cfg; \
|
|
MPP_RET ret = (MPP_RET)kmpp_obj_get_##cfg_type(obj, name, val); \
|
|
return ret; \
|
|
}
|
|
|
|
MPP_VENC_KCFG_ACCESS(RK_S32, RK_S32*, s32);
|
|
MPP_VENC_KCFG_ACCESS(RK_U32, RK_U32*, u32);
|
|
MPP_VENC_KCFG_ACCESS(RK_S64, RK_S64*, s64);
|
|
MPP_VENC_KCFG_ACCESS(RK_U64, RK_U64*, u64);
|
|
MPP_VENC_KCFG_ACCESS(void *, void **, ptr);
|
|
MPP_VENC_KCFG_ACCESS(void *, void *, st);
|
|
|
|
void mpp_venc_kcfg_show(MppVencKcfg cfg)
|
|
{
|
|
KmppObj obj = cfg;
|
|
|
|
if (!cfg) {
|
|
mpp_err_f("invalid NULL input config\n");
|
|
return;
|
|
}
|
|
|
|
kmpp_obj_udump(obj);
|
|
}
|