fix[mpp_venc_kcfg]: Revert to mpp interface

Signed-off-by: Herman Chen <herman.chen@rock-chips.com>
Change-Id: I546667e2647e5d5cdb0adb14e448577b1d0b7a0b
This commit is contained in:
Herman Chen
2025-04-01 18:20:17 +08:00
parent 7706b5129d
commit a091f3ae02
3 changed files with 70 additions and 70 deletions

View File

@@ -9,40 +9,40 @@
#include "rk_type.h"
#include "mpp_err.h"
typedef void* KmppVenccfg;
typedef void* MppVencKcfg;
#ifdef __cplusplus
extern "C" {
#endif
typedef enum {
KMPP_VENC_CFG_TYPE_INIT,
KMPP_VENC_CFG_TYPE_DEINIT,
KMPP_VENC_CFG_TYPE_RESET,
KMPP_VENC_CFG_TYPE_START,
KMPP_VENC_CFG_TYPE_STOP,
KMPP_VENC_CFG_TYPE_BUTT,
MPP_VENC_KCFG_TYPE_INIT,
MPP_VENC_KCFG_TYPE_DEINIT,
MPP_VENC_KCFG_TYPE_RESET,
MPP_VENC_KCFG_TYPE_START,
MPP_VENC_KCFG_TYPE_STOP,
MPP_VENC_KCFG_TYPE_BUTT,
} MppVencKcfgType;
MPP_RET kmpp_venc_cfg_init(KmppVenccfg *cfg, MppVencKcfgType type);
MPP_RET kmpp_venc_cfg_init_by_name(KmppVenccfg *cfg, const char *name);
MPP_RET kmpp_venc_cfg_deinit(KmppVenccfg cfg);
MPP_RET mpp_venc_kcfg_init(MppVencKcfg *cfg, MppVencKcfgType type);
MPP_RET mpp_venc_kcfg_init_by_name(MppVencKcfg *cfg, const char *name);
MPP_RET mpp_venc_kcfg_deinit(MppVencKcfg cfg);
MPP_RET kmpp_venc_cfg_set_s32(KmppVenccfg cfg, const char *name, RK_S32 val);
MPP_RET kmpp_venc_cfg_set_u32(KmppVenccfg cfg, const char *name, RK_U32 val);
MPP_RET kmpp_venc_cfg_set_s64(KmppVenccfg cfg, const char *name, RK_S64 val);
MPP_RET kmpp_venc_cfg_set_u64(KmppVenccfg cfg, const char *name, RK_U64 val);
MPP_RET kmpp_venc_cfg_set_ptr(KmppVenccfg cfg, const char *name, void *val);
MPP_RET kmpp_venc_cfg_set_st(KmppVenccfg cfg, const char *name, void *val);
MPP_RET mpp_venc_kcfg_set_s32(MppVencKcfg cfg, const char *name, RK_S32 val);
MPP_RET mpp_venc_kcfg_set_u32(MppVencKcfg cfg, const char *name, RK_U32 val);
MPP_RET mpp_venc_kcfg_set_s64(MppVencKcfg cfg, const char *name, RK_S64 val);
MPP_RET mpp_venc_kcfg_set_u64(MppVencKcfg cfg, const char *name, RK_U64 val);
MPP_RET mpp_venc_kcfg_set_ptr(MppVencKcfg cfg, const char *name, void *val);
MPP_RET mpp_venc_kcfg_set_st(MppVencKcfg cfg, const char *name, void *val);
MPP_RET kmpp_venc_cfg_get_s32(KmppVenccfg cfg, const char *name, RK_S32 *val);
MPP_RET kmpp_venc_cfg_get_u32(KmppVenccfg cfg, const char *name, RK_U32 *val);
MPP_RET kmpp_venc_cfg_get_s64(KmppVenccfg cfg, const char *name, RK_S64 *val);
MPP_RET kmpp_venc_cfg_get_u64(KmppVenccfg cfg, const char *name, RK_U64 *val);
MPP_RET kmpp_venc_cfg_get_ptr(KmppVenccfg cfg, const char *name, void **val);
MPP_RET kmpp_venc_cfg_get_st(KmppVenccfg cfg, const char *name, void *val);
MPP_RET mpp_venc_kcfg_get_s32(MppVencKcfg cfg, const char *name, RK_S32 *val);
MPP_RET mpp_venc_kcfg_get_u32(MppVencKcfg cfg, const char *name, RK_U32 *val);
MPP_RET mpp_venc_kcfg_get_s64(MppVencKcfg cfg, const char *name, RK_S64 *val);
MPP_RET mpp_venc_kcfg_get_u64(MppVencKcfg cfg, const char *name, RK_U64 *val);
MPP_RET mpp_venc_kcfg_get_ptr(MppVencKcfg cfg, const char *name, void **val);
MPP_RET mpp_venc_kcfg_get_st(MppVencKcfg cfg, const char *name, void *val);
void kmpp_venc_cfg_show(KmppVenccfg cfg);
void mpp_venc_kcfg_show(MppVencKcfg cfg);
#ifdef __cplusplus
}

View File

@@ -31,19 +31,19 @@
static RK_U32 venc_kcfg_debug = 0;
static char *kcfg_names[] = {
[KMPP_VENC_CFG_TYPE_INIT] = "KmppVencInitCfg",
[KMPP_VENC_CFG_TYPE_DEINIT] = "KmppVencDeinitCfg",
[KMPP_VENC_CFG_TYPE_RESET] = "KmppVencResetCfg",
[KMPP_VENC_CFG_TYPE_START] = "KmppVencStartCfg",
[KMPP_VENC_CFG_TYPE_STOP] = "KmppVencStopCfg",
[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[KMPP_VENC_CFG_TYPE_BUTT] = {NULL};
static KmppObjDef kcfg_defs[MPP_VENC_KCFG_TYPE_BUTT] = {NULL};
static pthread_mutex_t lock;
static void kmpp_venc_cfg_def_init() __attribute__((constructor));
static void kmpp_venc_cfg_def_deinit() __attribute__((destructor));
static void mpp_venc_kcfg_def_init() __attribute__((constructor));
static void mpp_venc_kcfg_def_deinit() __attribute__((destructor));
static void kmpp_venc_cfg_def_init(void)
static void mpp_venc_kcfg_def_init(void)
{
pthread_mutexattr_t attr;
@@ -53,12 +53,12 @@ static void kmpp_venc_cfg_def_init(void)
pthread_mutexattr_destroy(&attr);
}
static void kmpp_venc_cfg_def_deinit(void)
static void mpp_venc_kcfg_def_deinit(void)
{
RK_U32 i;
pthread_mutex_lock(&lock);
for (i = 0; i < KMPP_VENC_CFG_TYPE_BUTT; 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;
@@ -68,7 +68,7 @@ static void kmpp_venc_cfg_def_deinit(void)
pthread_mutex_destroy(&lock);
}
MPP_RET kmpp_venc_cfg_init(KmppVenccfg *cfg, MppVencKcfgType type)
MPP_RET mpp_venc_kcfg_init(MppVencKcfg *cfg, MppVencKcfgType type)
{
KmppObj obj = NULL;
@@ -77,7 +77,7 @@ MPP_RET kmpp_venc_cfg_init(KmppVenccfg *cfg, MppVencKcfgType type)
return MPP_ERR_NULL_PTR;
}
if (type >= KMPP_VENC_CFG_TYPE_BUTT) {
if (type >= MPP_VENC_KCFG_TYPE_BUTT) {
mpp_err_f("invalid config type %d\n", type);
return MPP_ERR_VALUE;
}
@@ -103,10 +103,10 @@ MPP_RET kmpp_venc_cfg_init(KmppVenccfg *cfg, MppVencKcfgType type)
return obj ? MPP_OK : MPP_NOK;
}
MPP_RET kmpp_venc_cfg_init_by_name(KmppVenccfg *cfg, const char *name)
MPP_RET mpp_venc_kcfg_init_by_name(MppVencKcfg *cfg, const char *name)
{
KmppObj obj = NULL;
MppVencKcfgType type = KMPP_VENC_CFG_TYPE_BUTT;
MppVencKcfgType type = MPP_VENC_KCFG_TYPE_BUTT;
RK_U32 i;
if (!cfg) {
@@ -114,14 +114,14 @@ MPP_RET kmpp_venc_cfg_init_by_name(KmppVenccfg *cfg, const char *name)
return MPP_ERR_NULL_PTR;
}
for (i = 0; i < KMPP_VENC_CFG_TYPE_BUTT; i++) {
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 >= KMPP_VENC_CFG_TYPE_BUTT) {
if (type >= MPP_VENC_KCFG_TYPE_BUTT) {
mpp_err_f("invalid config name %s\n", name);
return MPP_ERR_VALUE;
}
@@ -135,7 +135,7 @@ MPP_RET kmpp_venc_cfg_init_by_name(KmppVenccfg *cfg, const char *name)
return obj ? MPP_OK : MPP_NOK;
}
MPP_RET kmpp_venc_cfg_deinit(KmppVenccfg cfg)
MPP_RET mpp_venc_kcfg_deinit(MppVencKcfg cfg)
{
KmppObj obj = cfg;
@@ -147,8 +147,8 @@ MPP_RET kmpp_venc_cfg_deinit(KmppVenccfg cfg)
return kmpp_obj_put_f(obj);
}
#define KMPP_VENC_CFG_ACCESS(set_type, get_type, cfg_type) \
MPP_RET kmpp_venc_cfg_set_##cfg_type(KmppVenccfg cfg, const char *name, set_type val) \
#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); \
@@ -158,7 +158,7 @@ MPP_RET kmpp_venc_cfg_deinit(KmppVenccfg cfg)
MPP_RET ret = (MPP_RET)kmpp_obj_set_##cfg_type(obj, name, val); \
return ret; \
} \
MPP_RET kmpp_venc_cfg_get_##cfg_type(KmppVenccfg cfg, const char *name, get_type val) \
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); \
@@ -169,14 +169,14 @@ MPP_RET kmpp_venc_cfg_deinit(KmppVenccfg cfg)
return ret; \
}
KMPP_VENC_CFG_ACCESS(RK_S32, RK_S32*, s32);
KMPP_VENC_CFG_ACCESS(RK_U32, RK_U32*, u32);
KMPP_VENC_CFG_ACCESS(RK_S64, RK_S64*, s64);
KMPP_VENC_CFG_ACCESS(RK_U64, RK_U64*, u64);
KMPP_VENC_CFG_ACCESS(void *, void **, ptr);
KMPP_VENC_CFG_ACCESS(void *, void *, st);
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 kmpp_venc_cfg_show(KmppVenccfg cfg)
void mpp_venc_kcfg_show(MppVencKcfg cfg)
{
KmppObj obj = cfg;

View File

@@ -100,7 +100,7 @@ typedef struct {
CamSource *cam_ctx;
MppEncRoiCtx roi_ctx;
KmppVenccfg init_kcfg;
MppVencKcfg init_kcfg;
// resources
size_t header_size;
@@ -204,11 +204,11 @@ static RK_S32 get_mdinfo_size(MpiEncTestData *p, MppCodingType type)
static MPP_RET kmpp_cfg_init(MpiEncMultiCtxInfo *info)
{
KmppVenccfg init_kcfg = NULL;
MppVencKcfg init_kcfg = NULL;
MpiEncTestData *p = &info->ctx;
MPP_RET ret = MPP_NOK;
kmpp_venc_cfg_init(&init_kcfg, KMPP_VENC_CFG_TYPE_INIT);
mpp_venc_kcfg_init(&init_kcfg, MPP_VENC_KCFG_TYPE_INIT);
if (!init_kcfg) {
mpp_err_f("kmpp_venc_init_cfg_init failed\n");
return ret;
@@ -216,21 +216,21 @@ static MPP_RET kmpp_cfg_init(MpiEncMultiCtxInfo *info)
p->init_kcfg = init_kcfg;
kmpp_venc_cfg_set_u32(init_kcfg, "type", MPP_CTX_ENC);
kmpp_venc_cfg_set_u32(init_kcfg, "coding", p->type);
kmpp_venc_cfg_set_s32(init_kcfg, "chan_id", 0);
kmpp_venc_cfg_set_s32(init_kcfg, "online", 0);
kmpp_venc_cfg_set_u32(init_kcfg, "buf_size", 0);
kmpp_venc_cfg_set_u32(init_kcfg, "max_strm_cnt", 0);
kmpp_venc_cfg_set_u32(init_kcfg, "shared_buf_en", 0);
kmpp_venc_cfg_set_u32(init_kcfg, "smart_en", 0);
kmpp_venc_cfg_set_u32(init_kcfg, "max_width", p->width);
kmpp_venc_cfg_set_u32(init_kcfg, "max_height", p->height);
kmpp_venc_cfg_set_u32(init_kcfg, "max_lt_cnt", 0);
kmpp_venc_cfg_set_u32(init_kcfg, "qpmap_en", 0);
kmpp_venc_cfg_set_u32(init_kcfg, "chan_dup", 0);
kmpp_venc_cfg_set_u32(init_kcfg, "tmvp_enable", 0);
kmpp_venc_cfg_set_u32(init_kcfg, "only_smartp", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "type", MPP_CTX_ENC);
mpp_venc_kcfg_set_u32(init_kcfg, "coding", p->type);
mpp_venc_kcfg_set_s32(init_kcfg, "chan_id", 0);
mpp_venc_kcfg_set_s32(init_kcfg, "online", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "buf_size", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "max_strm_cnt", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "shared_buf_en", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "smart_en", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "max_width", p->width);
mpp_venc_kcfg_set_u32(init_kcfg, "max_height", p->height);
mpp_venc_kcfg_set_u32(init_kcfg, "max_lt_cnt", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "qpmap_en", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "chan_dup", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "tmvp_enable", 0);
mpp_venc_kcfg_set_u32(init_kcfg, "only_smartp", 0);
ret = p->mpi->control(p->ctx, MPP_SET_VENC_INIT_KCFG, init_kcfg);
if (ret)
@@ -1178,7 +1178,7 @@ MPP_TEST_OUT:
p->roi_ctx = NULL;
}
if (p->init_kcfg)
kmpp_venc_cfg_deinit(p->init_kcfg);
mpp_venc_kcfg_deinit(p->init_kcfg);
test_ctx_deinit(p);