xref: /rockchip-linux_mpp/mpp/hal/rkdec/vp9d/hal_vp9d_api.c (revision 437bfbeb9567cca9cd9080e3f6954aa9d6a94f18)
1*437bfbebSnyanmisaka /*
2*437bfbebSnyanmisaka  * Copyright 2020 Rockchip Electronics Co. LTD
3*437bfbebSnyanmisaka  *
4*437bfbebSnyanmisaka  * Licensed under the Apache License, Version 2.0 (the "License");
5*437bfbebSnyanmisaka  * you may not use this file except in compliance with the License.
6*437bfbebSnyanmisaka  * You may obtain a copy of the License at
7*437bfbebSnyanmisaka  *
8*437bfbebSnyanmisaka  *      http://www.apache.org/licenses/LICENSE-2.0
9*437bfbebSnyanmisaka  *
10*437bfbebSnyanmisaka  * Unless required by applicable law or agreed to in writing, software
11*437bfbebSnyanmisaka  * distributed under the License is distributed on an "AS IS" BASIS,
12*437bfbebSnyanmisaka  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*437bfbebSnyanmisaka  * See the License for the specific language governing permissions and
14*437bfbebSnyanmisaka  * limitations under the License.
15*437bfbebSnyanmisaka  */
16*437bfbebSnyanmisaka 
17*437bfbebSnyanmisaka #define MODULE_TAG "hal_vp9d_api"
18*437bfbebSnyanmisaka 
19*437bfbebSnyanmisaka #include <string.h>
20*437bfbebSnyanmisaka 
21*437bfbebSnyanmisaka #include "mpp_env.h"
22*437bfbebSnyanmisaka 
23*437bfbebSnyanmisaka #include "hal_vp9d_debug.h"
24*437bfbebSnyanmisaka #include "hal_vp9d_api.h"
25*437bfbebSnyanmisaka #include "hal_vp9d_ctx.h"
26*437bfbebSnyanmisaka #include "hal_vp9d_rkv.h"
27*437bfbebSnyanmisaka #include "hal_vp9d_vdpu34x.h"
28*437bfbebSnyanmisaka #include "hal_vp9d_vdpu382.h"
29*437bfbebSnyanmisaka #include "hal_vp9d_vdpu383.h"
30*437bfbebSnyanmisaka 
31*437bfbebSnyanmisaka RK_U32 hal_vp9d_debug = 0;
32*437bfbebSnyanmisaka 
hal_vp9d_init(void * ctx,MppHalCfg * cfg)33*437bfbebSnyanmisaka MPP_RET hal_vp9d_init(void *ctx, MppHalCfg *cfg)
34*437bfbebSnyanmisaka {
35*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
36*437bfbebSnyanmisaka     HalVp9dCtx *p = (HalVp9dCtx *)ctx;
37*437bfbebSnyanmisaka     MppClientType client_type = VPU_CLIENT_RKVDEC;
38*437bfbebSnyanmisaka     RK_U32 hw_id = 0;
39*437bfbebSnyanmisaka 
40*437bfbebSnyanmisaka     ret = mpp_dev_init(&cfg->dev, client_type);
41*437bfbebSnyanmisaka     if (ret) {
42*437bfbebSnyanmisaka         mpp_err("mpp_dev_init failed ret: %d\n", ret);
43*437bfbebSnyanmisaka         return ret;
44*437bfbebSnyanmisaka     }
45*437bfbebSnyanmisaka     cfg->hw_info = mpp_get_dec_hw_info_by_client_type(client_type);
46*437bfbebSnyanmisaka     p->hw_info = cfg->hw_info;
47*437bfbebSnyanmisaka 
48*437bfbebSnyanmisaka     hw_id = mpp_get_client_hw_id(client_type);
49*437bfbebSnyanmisaka     p->dev = cfg->dev;
50*437bfbebSnyanmisaka     p->hw_id = hw_id;
51*437bfbebSnyanmisaka     p->client_type = client_type;
52*437bfbebSnyanmisaka     if (hw_id == HWID_VDPU383) {
53*437bfbebSnyanmisaka         p->api = &hal_vp9d_vdpu383;
54*437bfbebSnyanmisaka         cfg->support_fast_mode = 1;
55*437bfbebSnyanmisaka     } else if (hw_id == HWID_VDPU382_RK3528 || hw_id == HWID_VDPU382_RK3562) {
56*437bfbebSnyanmisaka         p->api = &hal_vp9d_vdpu382;
57*437bfbebSnyanmisaka         cfg->support_fast_mode = 1;
58*437bfbebSnyanmisaka     } else if (hw_id == HWID_VDPU34X || hw_id == HWID_VDPU38X) {
59*437bfbebSnyanmisaka         p->api = &hal_vp9d_vdpu34x;
60*437bfbebSnyanmisaka         cfg->support_fast_mode = 1;
61*437bfbebSnyanmisaka         if (mpp_get_soc_type() == ROCKCHIP_SOC_RK3588)
62*437bfbebSnyanmisaka             cfg->support_fast_mode = 0;
63*437bfbebSnyanmisaka     } else {
64*437bfbebSnyanmisaka         p->api = &hal_vp9d_rkv;
65*437bfbebSnyanmisaka         cfg->support_fast_mode = 0;
66*437bfbebSnyanmisaka     }
67*437bfbebSnyanmisaka 
68*437bfbebSnyanmisaka 
69*437bfbebSnyanmisaka     p->slots = cfg->frame_slots;
70*437bfbebSnyanmisaka     p->dec_cb = cfg->dec_cb;
71*437bfbebSnyanmisaka     p->fast_mode = cfg->cfg->base.fast_parse && cfg->support_fast_mode;
72*437bfbebSnyanmisaka     p->packet_slots = cfg->packet_slots;
73*437bfbebSnyanmisaka 
74*437bfbebSnyanmisaka     mpp_env_get_u32("hal_vp9d_debug", &hal_vp9d_debug, 0);
75*437bfbebSnyanmisaka 
76*437bfbebSnyanmisaka     ret = p->api->init(ctx, cfg);
77*437bfbebSnyanmisaka 
78*437bfbebSnyanmisaka     return ret;
79*437bfbebSnyanmisaka }
80*437bfbebSnyanmisaka 
hal_vp9d_deinit(void * ctx)81*437bfbebSnyanmisaka MPP_RET hal_vp9d_deinit(void *ctx)
82*437bfbebSnyanmisaka {
83*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
84*437bfbebSnyanmisaka     HalVp9dCtx *p = (HalVp9dCtx *)ctx;
85*437bfbebSnyanmisaka 
86*437bfbebSnyanmisaka     if (p && p->api && p->api->deinit)
87*437bfbebSnyanmisaka         ret = p->api->deinit(ctx);
88*437bfbebSnyanmisaka 
89*437bfbebSnyanmisaka     if (p->dev) {
90*437bfbebSnyanmisaka         mpp_dev_deinit(p->dev);
91*437bfbebSnyanmisaka         p->dev = NULL;
92*437bfbebSnyanmisaka     }
93*437bfbebSnyanmisaka 
94*437bfbebSnyanmisaka     return ret;
95*437bfbebSnyanmisaka }
96*437bfbebSnyanmisaka 
hal_vp9d_gen_regs(void * ctx,HalTaskInfo * task)97*437bfbebSnyanmisaka MPP_RET hal_vp9d_gen_regs(void *ctx, HalTaskInfo *task)
98*437bfbebSnyanmisaka {
99*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
100*437bfbebSnyanmisaka     HalVp9dCtx *p = (HalVp9dCtx *)ctx;
101*437bfbebSnyanmisaka 
102*437bfbebSnyanmisaka     if (p && p->api && p->api->reg_gen)
103*437bfbebSnyanmisaka         ret = p->api->reg_gen(ctx, task);
104*437bfbebSnyanmisaka 
105*437bfbebSnyanmisaka     return ret;
106*437bfbebSnyanmisaka }
107*437bfbebSnyanmisaka 
hal_vp9d_start(void * ctx,HalTaskInfo * task)108*437bfbebSnyanmisaka MPP_RET hal_vp9d_start(void *ctx, HalTaskInfo *task)
109*437bfbebSnyanmisaka {
110*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
111*437bfbebSnyanmisaka     HalVp9dCtx *p = (HalVp9dCtx *)ctx;
112*437bfbebSnyanmisaka 
113*437bfbebSnyanmisaka     if (p && p->api && p->api->start)
114*437bfbebSnyanmisaka         ret = p->api->start(ctx, task);
115*437bfbebSnyanmisaka 
116*437bfbebSnyanmisaka     return ret;
117*437bfbebSnyanmisaka }
118*437bfbebSnyanmisaka 
hal_vp9d_wait(void * ctx,HalTaskInfo * task)119*437bfbebSnyanmisaka MPP_RET hal_vp9d_wait(void *ctx, HalTaskInfo *task)
120*437bfbebSnyanmisaka {
121*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
122*437bfbebSnyanmisaka     HalVp9dCtx *p = (HalVp9dCtx *)ctx;
123*437bfbebSnyanmisaka 
124*437bfbebSnyanmisaka     if (p && p->api && p->api->wait)
125*437bfbebSnyanmisaka         ret = p->api->wait(ctx, task);
126*437bfbebSnyanmisaka 
127*437bfbebSnyanmisaka     return ret;
128*437bfbebSnyanmisaka }
129*437bfbebSnyanmisaka 
hal_vp9d_reset(void * ctx)130*437bfbebSnyanmisaka MPP_RET hal_vp9d_reset(void *ctx)
131*437bfbebSnyanmisaka {
132*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
133*437bfbebSnyanmisaka     HalVp9dCtx *p = (HalVp9dCtx *)ctx;
134*437bfbebSnyanmisaka 
135*437bfbebSnyanmisaka     if (p && p->api && p->api->reset)
136*437bfbebSnyanmisaka         ret = p->api->reset(ctx);
137*437bfbebSnyanmisaka 
138*437bfbebSnyanmisaka     return ret;
139*437bfbebSnyanmisaka }
140*437bfbebSnyanmisaka 
hal_vp9d_flush(void * ctx)141*437bfbebSnyanmisaka MPP_RET hal_vp9d_flush(void *ctx)
142*437bfbebSnyanmisaka {
143*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
144*437bfbebSnyanmisaka     HalVp9dCtx *p = (HalVp9dCtx *)ctx;
145*437bfbebSnyanmisaka 
146*437bfbebSnyanmisaka     if (p && p->api && p->api->flush)
147*437bfbebSnyanmisaka         ret = p->api->flush(ctx);
148*437bfbebSnyanmisaka 
149*437bfbebSnyanmisaka     return ret;
150*437bfbebSnyanmisaka }
151*437bfbebSnyanmisaka 
hal_vp9d_control(void * ctx,MpiCmd cmd,void * param)152*437bfbebSnyanmisaka MPP_RET hal_vp9d_control(void *ctx, MpiCmd cmd, void *param)
153*437bfbebSnyanmisaka {
154*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
155*437bfbebSnyanmisaka     HalVp9dCtx *p = (HalVp9dCtx *)ctx;
156*437bfbebSnyanmisaka 
157*437bfbebSnyanmisaka     if (p && p->api && p->api->control)
158*437bfbebSnyanmisaka         ret = p->api->control(ctx, cmd, param);
159*437bfbebSnyanmisaka 
160*437bfbebSnyanmisaka     return ret;
161*437bfbebSnyanmisaka }
162*437bfbebSnyanmisaka 
163*437bfbebSnyanmisaka const MppHalApi hal_api_vp9d = {
164*437bfbebSnyanmisaka     .name = "vp9d_rkdec",
165*437bfbebSnyanmisaka     .type = MPP_CTX_DEC,
166*437bfbebSnyanmisaka     .coding = MPP_VIDEO_CodingVP9,
167*437bfbebSnyanmisaka     .ctx_size = sizeof(HalVp9dCtx),
168*437bfbebSnyanmisaka     .flag = 0,
169*437bfbebSnyanmisaka     .init = hal_vp9d_init,
170*437bfbebSnyanmisaka     .deinit = hal_vp9d_deinit,
171*437bfbebSnyanmisaka     .reg_gen = hal_vp9d_gen_regs,
172*437bfbebSnyanmisaka     .start = hal_vp9d_start,
173*437bfbebSnyanmisaka     .wait = hal_vp9d_wait,
174*437bfbebSnyanmisaka     .reset = hal_vp9d_reset,
175*437bfbebSnyanmisaka     .flush = hal_vp9d_flush,
176*437bfbebSnyanmisaka     .control = hal_vp9d_control,
177*437bfbebSnyanmisaka };
178