[osal]: Add multi register offset config function

Add new multi config mode function.

Change-Id: I37c9c319e93e96fbd3d2bb5d598aef8d1b8fe2c8
Signed-off-by: Herman Chen <herman.chen@rock-chips.com>
This commit is contained in:
Herman Chen
2022-02-09 17:04:32 +08:00
parent c4c6a540e2
commit fe11f99415
4 changed files with 129 additions and 1 deletions

View File

@@ -151,6 +151,10 @@ MPP_RET mpp_dev_ioctl(MppDev ctx, RK_S32 cmd, void *param)
if (api->reg_offset)
ret = api->reg_offset(impl_ctx, param);
} break;
case MPP_DEV_REG_OFFS : {
if (api->reg_offs)
ret = api->reg_offs(impl_ctx, param);
} break;
case MPP_DEV_RCB_INFO : {
if (api->rcb_info)
ret = api->rcb_info(impl_ctx, param);
@@ -182,7 +186,74 @@ MPP_RET mpp_dev_set_reg_offset(MppDev dev, RK_S32 index, RK_U32 offset)
trans_cfg.reg_idx = index;
trans_cfg.offset = offset;
mpp_dev_ioctl(dev, MPP_DEV_REG_OFFSET, &trans_cfg);
return mpp_dev_ioctl(dev, MPP_DEV_REG_OFFSET, &trans_cfg);
}
/* register offset multi config */
MPP_RET mpp_dev_multi_offset_init(MppDevRegOffCfgs **cfgs, RK_S32 size)
{
RK_S32 cfg_size = sizeof(MppDevRegOffCfgs) + size * sizeof(MppDevRegOffsetCfg);
MppDevRegOffCfgs *p = NULL;
if (NULL == cfgs || size <= 0) {
mpp_err_f("invalid pointer %p size %d\n", cfgs, size);
return MPP_NOK;
}
p = mpp_calloc_size(MppDevRegOffCfgs, cfg_size);
if (p)
p->size = size;
*cfgs = p;
return (p) ? MPP_OK : MPP_NOK;
}
MPP_RET mpp_dev_multi_offset_deinit(MppDevRegOffCfgs *cfgs)
{
MPP_FREE(cfgs);
return MPP_OK;
}
MPP_RET mpp_dev_multi_offset_reset(MppDevRegOffCfgs *cfgs)
{
if (cfgs) {
memset(cfgs->cfgs, 0, cfgs->count * sizeof(cfgs->cfgs[0]));
cfgs->count = 0;
}
return MPP_OK;
}
MPP_RET mpp_dev_multi_offset_update(MppDevRegOffCfgs *cfgs, RK_S32 index, RK_U32 offset)
{
MppDevRegOffsetCfg *cfg;
RK_S32 count;
RK_S32 i;
if (NULL == cfgs)
return MPP_NOK;
if (cfgs->count >= cfgs->size) {
mpp_err_f("invalid cfgs count %d : %d\n", cfgs->count, cfgs->size);
return MPP_NOK;
}
count = cfgs->count;
cfg = cfgs->cfgs;
for (i = 0; i < count; i++, cfg++) {
if (cfg->reg_idx == (RK_U32)index) {
cfg->offset = offset;
return MPP_OK;
}
}
cfg->reg_idx = index;
cfg->offset = offset;
cfgs->count++;
return MPP_OK;
}

View File

@@ -477,6 +477,45 @@ MPP_RET mpp_service_reg_offset(void *ctx, MppDevRegOffsetCfg *cfg)
return MPP_OK;
}
MPP_RET mpp_service_reg_offsets(void *ctx, MppDevRegOffCfgs *cfgs)
{
MppDevMppService *p = (MppDevMppService *)ctx;
RegOffsetInfo *info;
RK_S32 i;
if (cfgs->count <= 0)
return MPP_OK;
if (p->reg_offset_count >= MAX_REG_OFFSET ||
p->reg_offset_count + cfgs->count >= MAX_REG_OFFSET) {
mpp_err_f("reach max offset definition\n", MAX_REG_OFFSET);
return MPP_NOK;
}
for (i = 0; i < cfgs->count; i++) {
MppDevRegOffsetCfg *cfg = &cfgs->cfgs[i];
RK_S32 j;
for (j = 0; j < p->reg_offset_count; j++) {
info = &p->reg_offset_info[p->reg_offset_pos + j];
if (info->reg_idx == cfg->reg_idx) {
mpp_err_f("reg[%d] offset has been set, cover old %d -> %d\n",
info->reg_idx, info->offset, cfg->offset);
info->offset = cfg->offset;
continue;
}
}
info = mpp_service_next_reg_offset(p);;
info->reg_idx = cfg->reg_idx;
info->offset = cfg->offset;
p->reg_offset_count++;
}
return MPP_OK;
}
MPP_RET mpp_service_rcb_info(void *ctx, MppDevRcbInfoCfg *cfg)
{
MppDevMppService *p = (MppDevMppService *)ctx;
@@ -636,6 +675,7 @@ const MppDevApi mpp_service_api = {
mpp_service_reg_wr,
mpp_service_reg_rd,
mpp_service_reg_offset,
mpp_service_reg_offsets,
mpp_service_rcb_info,
mpp_service_set_info,
mpp_service_cmd_send,

View File

@@ -707,6 +707,7 @@ const MppDevApi vcodec_service_api = {
vcodec_service_reg_rd,
vcodec_service_fd_trans,
NULL,
NULL,
vcodec_service_set_info,
vcodec_service_cmd_send,
vcodec_service_cmd_poll,