xref: /OK3568_Linux_fs/external/mpp/osal/inc/mpp_device.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Copyright 2020 Rockchip Electronics Co. LTD
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Licensed under the Apache License, Version 2.0 (the "License");
5*4882a593Smuzhiyun  * you may not use this file except in compliance with the License.
6*4882a593Smuzhiyun  * You may obtain a copy of the License at
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  *      http://www.apache.org/licenses/LICENSE-2.0
9*4882a593Smuzhiyun  *
10*4882a593Smuzhiyun  * Unless required by applicable law or agreed to in writing, software
11*4882a593Smuzhiyun  * distributed under the License is distributed on an "AS IS" BASIS,
12*4882a593Smuzhiyun  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4882a593Smuzhiyun  * See the License for the specific language governing permissions and
14*4882a593Smuzhiyun  * limitations under the License.
15*4882a593Smuzhiyun  */
16*4882a593Smuzhiyun 
17*4882a593Smuzhiyun #ifndef __MPP_DEVICE_H__
18*4882a593Smuzhiyun #define __MPP_DEVICE_H__
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun #include "mpp_err.h"
21*4882a593Smuzhiyun #include "mpp_dev_defs.h"
22*4882a593Smuzhiyun #include "mpp_callback.h"
23*4882a593Smuzhiyun 
24*4882a593Smuzhiyun typedef enum MppDevIoctlCmd_e {
25*4882a593Smuzhiyun     /* device batch mode config */
26*4882a593Smuzhiyun     MPP_DEV_BATCH_ON,
27*4882a593Smuzhiyun     MPP_DEV_BATCH_OFF,
28*4882a593Smuzhiyun     MPP_DEV_DELIMIT,
29*4882a593Smuzhiyun     MPP_DEV_SET_CB_CTX,
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun     /* hardware operation setup config */
32*4882a593Smuzhiyun     MPP_DEV_REG_WR,
33*4882a593Smuzhiyun     MPP_DEV_REG_RD,
34*4882a593Smuzhiyun     MPP_DEV_REG_OFFSET,
35*4882a593Smuzhiyun     MPP_DEV_REG_OFFS,
36*4882a593Smuzhiyun     MPP_DEV_RCB_INFO,
37*4882a593Smuzhiyun     MPP_DEV_SET_INFO,
38*4882a593Smuzhiyun     MPP_DEV_SET_ERR_REF_HACK,
39*4882a593Smuzhiyun 
40*4882a593Smuzhiyun     MPP_DEV_CMD_SEND,
41*4882a593Smuzhiyun     MPP_DEV_CMD_POLL,
42*4882a593Smuzhiyun 
43*4882a593Smuzhiyun     MPP_DEV_IOCTL_CMD_BUTT,
44*4882a593Smuzhiyun } MppDevIoctlCmd;
45*4882a593Smuzhiyun 
46*4882a593Smuzhiyun /* for MPP_DEV_REG_WR */
47*4882a593Smuzhiyun typedef struct MppDevRegWrCfg_t {
48*4882a593Smuzhiyun     void    *reg;
49*4882a593Smuzhiyun     RK_U32  size;
50*4882a593Smuzhiyun     RK_U32  offset;
51*4882a593Smuzhiyun } MppDevRegWrCfg;
52*4882a593Smuzhiyun 
53*4882a593Smuzhiyun /* for MPP_DEV_REG_RD */
54*4882a593Smuzhiyun typedef struct MppDevRegRdCfg_t {
55*4882a593Smuzhiyun     void    *reg;
56*4882a593Smuzhiyun     RK_U32  size;
57*4882a593Smuzhiyun     RK_U32  offset;
58*4882a593Smuzhiyun } MppDevRegRdCfg;
59*4882a593Smuzhiyun 
60*4882a593Smuzhiyun /* for MPP_DEV_REG_OFFSET */
61*4882a593Smuzhiyun typedef struct MppDevRegOffsetCfg_t {
62*4882a593Smuzhiyun     RK_U32  reg_idx;
63*4882a593Smuzhiyun     RK_U32  offset;
64*4882a593Smuzhiyun } MppDevRegOffsetCfg;
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun /* for multi MPP_DEV_REG_OFFSET */
67*4882a593Smuzhiyun typedef struct MppDevRegOffsCfg_t {
68*4882a593Smuzhiyun     RK_S32  size;
69*4882a593Smuzhiyun     RK_S32  count;
70*4882a593Smuzhiyun     MppDevRegOffsetCfg cfgs[];
71*4882a593Smuzhiyun } MppDevRegOffCfgs;
72*4882a593Smuzhiyun 
73*4882a593Smuzhiyun /* for MPP_DEV_RCB_INFO */
74*4882a593Smuzhiyun typedef struct MppDevRcbInfoCfg_t {
75*4882a593Smuzhiyun     RK_U32  reg_idx;
76*4882a593Smuzhiyun     RK_U32  size;
77*4882a593Smuzhiyun } MppDevRcbInfoCfg;
78*4882a593Smuzhiyun 
79*4882a593Smuzhiyun /* for MPP_DEV_SET_INFO */
80*4882a593Smuzhiyun typedef struct MppDevSetInfoCfg_t {
81*4882a593Smuzhiyun     RK_U32  type;
82*4882a593Smuzhiyun     RK_U32  flag;
83*4882a593Smuzhiyun     RK_U64  data;
84*4882a593Smuzhiyun } MppDevInfoCfg;
85*4882a593Smuzhiyun 
86*4882a593Smuzhiyun typedef union MppDevPollEncSliceInfo_u {
87*4882a593Smuzhiyun     RK_U32  val;
88*4882a593Smuzhiyun     struct {
89*4882a593Smuzhiyun         RK_U32  length  : 31;
90*4882a593Smuzhiyun         RK_U32  last    : 1;
91*4882a593Smuzhiyun     };
92*4882a593Smuzhiyun } MppDevPollEncSliceInfo;
93*4882a593Smuzhiyun 
94*4882a593Smuzhiyun /* for MPP_DEV_POLL */
95*4882a593Smuzhiyun typedef struct MppDevPollCfg_t {
96*4882a593Smuzhiyun     RK_S32  poll_type;
97*4882a593Smuzhiyun     RK_S32  poll_ret;
98*4882a593Smuzhiyun     RK_S32  count_max;
99*4882a593Smuzhiyun     RK_S32  count_ret;
100*4882a593Smuzhiyun     MppDevPollEncSliceInfo slice_info[];
101*4882a593Smuzhiyun } MppDevPollCfg;
102*4882a593Smuzhiyun 
103*4882a593Smuzhiyun typedef struct MppDevApi_t {
104*4882a593Smuzhiyun     const char  *name;
105*4882a593Smuzhiyun     RK_U32      ctx_size;
106*4882a593Smuzhiyun     MPP_RET     (*init)(void *ctx, MppClientType type);
107*4882a593Smuzhiyun     MPP_RET     (*deinit)(void *ctx);
108*4882a593Smuzhiyun 
109*4882a593Smuzhiyun     /* bat mode function */
110*4882a593Smuzhiyun     MPP_RET     (*attach)(void *ctx);
111*4882a593Smuzhiyun     MPP_RET     (*detach)(void *ctx);
112*4882a593Smuzhiyun     MPP_RET     (*delimit)(void *ctx);
113*4882a593Smuzhiyun     MPP_RET     (*set_cb_ctx)(void *ctx, MppCbCtx *cb);
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun     /* config the cmd on preparing */
116*4882a593Smuzhiyun     MPP_RET     (*reg_wr)(void *ctx, MppDevRegWrCfg *cfg);
117*4882a593Smuzhiyun     MPP_RET     (*reg_rd)(void *ctx, MppDevRegRdCfg *cfg);
118*4882a593Smuzhiyun     MPP_RET     (*reg_offset)(void *ctx, MppDevRegOffsetCfg *cfg);
119*4882a593Smuzhiyun     MPP_RET     (*reg_offs)(void *ctx, MppDevRegOffCfgs *cfg);
120*4882a593Smuzhiyun     MPP_RET     (*rcb_info)(void *ctx, MppDevRcbInfoCfg *cfg);
121*4882a593Smuzhiyun     MPP_RET     (*set_info)(void *ctx, MppDevInfoCfg *cfg);
122*4882a593Smuzhiyun     MPP_RET     (*set_err_ref_hack)(void *ctx, RK_U32 *enable);
123*4882a593Smuzhiyun 
124*4882a593Smuzhiyun     /* send cmd to hardware */
125*4882a593Smuzhiyun     MPP_RET     (*cmd_send)(void *ctx);
126*4882a593Smuzhiyun 
127*4882a593Smuzhiyun     /* poll cmd from hardware */
128*4882a593Smuzhiyun     MPP_RET     (*cmd_poll)(void *ctx, MppDevPollCfg *cfg);
129*4882a593Smuzhiyun } MppDevApi;
130*4882a593Smuzhiyun 
131*4882a593Smuzhiyun typedef void* MppDev;
132*4882a593Smuzhiyun 
133*4882a593Smuzhiyun #ifdef __cplusplus
134*4882a593Smuzhiyun extern "C" {
135*4882a593Smuzhiyun #endif
136*4882a593Smuzhiyun 
137*4882a593Smuzhiyun MPP_RET mpp_dev_init(MppDev *ctx, MppClientType type);
138*4882a593Smuzhiyun MPP_RET mpp_dev_deinit(MppDev ctx);
139*4882a593Smuzhiyun 
140*4882a593Smuzhiyun MPP_RET mpp_dev_ioctl(MppDev ctx, RK_S32 cmd, void *param);
141*4882a593Smuzhiyun 
142*4882a593Smuzhiyun /* special helper function for large address offset config */
143*4882a593Smuzhiyun MPP_RET mpp_dev_set_reg_offset(MppDev dev, RK_S32 index, RK_U32 offset);
144*4882a593Smuzhiyun 
145*4882a593Smuzhiyun /* register offset multi config */
146*4882a593Smuzhiyun MPP_RET mpp_dev_multi_offset_init(MppDevRegOffCfgs **cfgs, RK_S32 size);
147*4882a593Smuzhiyun MPP_RET mpp_dev_multi_offset_deinit(MppDevRegOffCfgs *cfgs);
148*4882a593Smuzhiyun 
149*4882a593Smuzhiyun MPP_RET mpp_dev_multi_offset_reset(MppDevRegOffCfgs *cfgs);
150*4882a593Smuzhiyun MPP_RET mpp_dev_multi_offset_update(MppDevRegOffCfgs *cfgs, RK_S32 index, RK_U32 offset);
151*4882a593Smuzhiyun 
152*4882a593Smuzhiyun #ifdef __cplusplus
153*4882a593Smuzhiyun }
154*4882a593Smuzhiyun #endif
155*4882a593Smuzhiyun 
156*4882a593Smuzhiyun #endif /* __MPP_DEVICE_H__ */
157