HxNvr/resources/libraries/mpp/osal/mpp_device.h

157 lines
4.0 KiB
C
Raw Normal View History

2024-01-30 18:59:29 +08:00
/*
* Copyright 2020 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.
*/
#ifndef __MPP_DEVICE_H__
#define __MPP_DEVICE_H__
#include "mpp_err.h"
#include "mpp_dev_defs.h"
#include "mpp_callback.h"
typedef enum MppDevIoctlCmd_e {
/* device batch mode config */
MPP_DEV_BATCH_ON,
MPP_DEV_BATCH_OFF,
MPP_DEV_DELIMIT,
MPP_DEV_SET_CB_CTX,
/* hardware operation setup config */
MPP_DEV_REG_WR,
MPP_DEV_REG_RD,
MPP_DEV_REG_OFFSET,
MPP_DEV_REG_OFFS,
MPP_DEV_RCB_INFO,
MPP_DEV_SET_INFO,
MPP_DEV_SET_ERR_REF_HACK,
MPP_DEV_CMD_SEND,
MPP_DEV_CMD_POLL,
MPP_DEV_IOCTL_CMD_BUTT,
} MppDevIoctlCmd;
/* for MPP_DEV_REG_WR */
typedef struct MppDevRegWrCfg_t {
void *reg;
RK_U32 size;
RK_U32 offset;
} MppDevRegWrCfg;
/* for MPP_DEV_REG_RD */
typedef struct MppDevRegRdCfg_t {
void *reg;
RK_U32 size;
RK_U32 offset;
} MppDevRegRdCfg;
/* for MPP_DEV_REG_OFFSET */
typedef struct MppDevRegOffsetCfg_t {
RK_U32 reg_idx;
RK_U32 offset;
} MppDevRegOffsetCfg;
/* for multi MPP_DEV_REG_OFFSET */
typedef struct MppDevRegOffsCfg_t {
RK_S32 size;
RK_S32 count;
MppDevRegOffsetCfg cfgs[];
} MppDevRegOffCfgs;
/* for MPP_DEV_RCB_INFO */
typedef struct MppDevRcbInfoCfg_t {
RK_U32 reg_idx;
RK_U32 size;
} MppDevRcbInfoCfg;
/* for MPP_DEV_SET_INFO */
typedef struct MppDevSetInfoCfg_t {
RK_U32 type;
RK_U32 flag;
RK_U64 data;
} MppDevInfoCfg;
typedef union MppDevPollEncSliceInfo_u {
RK_U32 val;
struct {
RK_U32 length : 31;
RK_U32 last : 1;
};
} MppDevPollEncSliceInfo;
/* for MPP_DEV_POLL */
typedef struct MppDevPollCfg_t {
RK_S32 poll_type;
RK_S32 poll_ret;
RK_S32 count_max;
RK_S32 count_ret;
MppDevPollEncSliceInfo slice_info[];
} MppDevPollCfg;
typedef struct MppDevApi_t {
const char *name;
RK_U32 ctx_size;
MPP_RET (*init)(void *ctx, MppClientType type);
MPP_RET (*deinit)(void *ctx);
/* bat mode function */
MPP_RET (*attach)(void *ctx);
MPP_RET (*detach)(void *ctx);
MPP_RET (*delimit)(void *ctx);
MPP_RET (*set_cb_ctx)(void *ctx, MppCbCtx *cb);
/* config the cmd on preparing */
MPP_RET (*reg_wr)(void *ctx, MppDevRegWrCfg *cfg);
MPP_RET (*reg_rd)(void *ctx, MppDevRegRdCfg *cfg);
MPP_RET (*reg_offset)(void *ctx, MppDevRegOffsetCfg *cfg);
MPP_RET (*reg_offs)(void *ctx, MppDevRegOffCfgs *cfg);
MPP_RET (*rcb_info)(void *ctx, MppDevRcbInfoCfg *cfg);
MPP_RET (*set_info)(void *ctx, MppDevInfoCfg *cfg);
MPP_RET (*set_err_ref_hack)(void *ctx, RK_U32 *enable);
/* send cmd to hardware */
MPP_RET (*cmd_send)(void *ctx);
/* poll cmd from hardware */
MPP_RET (*cmd_poll)(void *ctx, MppDevPollCfg *cfg);
} MppDevApi;
typedef void* MppDev;
#ifdef __cplusplus
extern "C" {
#endif
MPP_RET mpp_dev_init(MppDev *ctx, MppClientType type);
MPP_RET mpp_dev_deinit(MppDev ctx);
MPP_RET mpp_dev_ioctl(MppDev ctx, RK_S32 cmd, void *param);
/* special helper function for large address offset config */
MPP_RET mpp_dev_set_reg_offset(MppDev dev, RK_S32 index, RK_U32 offset);
/* register offset multi config */
MPP_RET mpp_dev_multi_offset_init(MppDevRegOffCfgs **cfgs, RK_S32 size);
MPP_RET mpp_dev_multi_offset_deinit(MppDevRegOffCfgs *cfgs);
MPP_RET mpp_dev_multi_offset_reset(MppDevRegOffCfgs *cfgs);
MPP_RET mpp_dev_multi_offset_update(MppDevRegOffCfgs *cfgs, RK_S32 index, RK_U32 offset);
#ifdef __cplusplus
}
#endif
#endif /* __MPP_DEVICE_H__ */