xref: /rockchip-linux_mpp/mpp/hal/rkdec/h265d/hal_h265d_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_h265d_api"
18*437bfbebSnyanmisaka 
19*437bfbebSnyanmisaka #include <stdio.h>
20*437bfbebSnyanmisaka #include <string.h>
21*437bfbebSnyanmisaka 
22*437bfbebSnyanmisaka #include "mpp_env.h"
23*437bfbebSnyanmisaka #include "mpp_mem.h"
24*437bfbebSnyanmisaka #include "mpp_debug.h"
25*437bfbebSnyanmisaka 
26*437bfbebSnyanmisaka #include "hal_h265d_ctx.h"
27*437bfbebSnyanmisaka #include "hal_h265d_api.h"
28*437bfbebSnyanmisaka #include "hal_h265d_rkv.h"
29*437bfbebSnyanmisaka #include "hal_h265d_vdpu34x.h"
30*437bfbebSnyanmisaka #include "hal_h265d_vdpu382.h"
31*437bfbebSnyanmisaka #include "hal_h265d_vdpu383.h"
32*437bfbebSnyanmisaka #include "hal_h265d_vdpu384a.h"
33*437bfbebSnyanmisaka 
34*437bfbebSnyanmisaka RK_U32 hal_h265d_debug = 0;
35*437bfbebSnyanmisaka 
hal_h265d_init(void * ctx,MppHalCfg * cfg)36*437bfbebSnyanmisaka MPP_RET hal_h265d_init(void *ctx, MppHalCfg *cfg)
37*437bfbebSnyanmisaka {
38*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
39*437bfbebSnyanmisaka     HalH265dCtx *p = (HalH265dCtx *)ctx;
40*437bfbebSnyanmisaka     MppClientType client_type = VPU_CLIENT_BUTT;
41*437bfbebSnyanmisaka     RK_U32 vcodec_type = mpp_get_vcodec_type();
42*437bfbebSnyanmisaka     RockchipSocType soc = mpp_get_soc_type();
43*437bfbebSnyanmisaka     RK_U32 hw_id = 0;
44*437bfbebSnyanmisaka 
45*437bfbebSnyanmisaka     if (!(vcodec_type & (HAVE_RKVDEC | HAVE_HEVC_DEC))) {
46*437bfbebSnyanmisaka         mpp_err_f("Can not found valid H.265 decoder hardware on platform %08x\n", vcodec_type);
47*437bfbebSnyanmisaka         return ret;
48*437bfbebSnyanmisaka     }
49*437bfbebSnyanmisaka 
50*437bfbebSnyanmisaka     client_type = (vcodec_type & HAVE_HEVC_DEC) ?
51*437bfbebSnyanmisaka                   VPU_CLIENT_HEVC_DEC : VPU_CLIENT_RKVDEC;
52*437bfbebSnyanmisaka 
53*437bfbebSnyanmisaka     ret = mpp_dev_init(&cfg->dev, client_type);
54*437bfbebSnyanmisaka     if (ret) {
55*437bfbebSnyanmisaka         mpp_err("mpp_dev_init failed ret: %d\n", ret);
56*437bfbebSnyanmisaka         return ret;
57*437bfbebSnyanmisaka     }
58*437bfbebSnyanmisaka     cfg->hw_info = mpp_get_dec_hw_info_by_client_type(client_type);
59*437bfbebSnyanmisaka     p->hw_info = cfg->hw_info;
60*437bfbebSnyanmisaka 
61*437bfbebSnyanmisaka     hw_id = mpp_get_client_hw_id(client_type);
62*437bfbebSnyanmisaka     p->dev = cfg->dev;
63*437bfbebSnyanmisaka     p->is_v341 = (soc == ROCKCHIP_SOC_RK3228H || (soc == ROCKCHIP_SOC_RK3328));
64*437bfbebSnyanmisaka     p->is_v345 = (hw_id == HWID_VDPU345);
65*437bfbebSnyanmisaka     p->is_v34x = (hw_id == HWID_VDPU34X || hw_id == HWID_VDPU38X);
66*437bfbebSnyanmisaka     p->is_v383 = (hw_id == HWID_VDPU383);
67*437bfbebSnyanmisaka     p->is_v384a = (hw_id == HWID_VDPU384A);
68*437bfbebSnyanmisaka     p->client_type = client_type;
69*437bfbebSnyanmisaka 
70*437bfbebSnyanmisaka     if (hw_id == HWID_VDPU382_RK3528 || hw_id == HWID_VDPU382_RK3562)
71*437bfbebSnyanmisaka         p->api = &hal_h265d_vdpu382;
72*437bfbebSnyanmisaka     else if (p->is_v34x)
73*437bfbebSnyanmisaka         p->api = &hal_h265d_vdpu34x;
74*437bfbebSnyanmisaka     else if (p->is_v383)
75*437bfbebSnyanmisaka         p->api = &hal_h265d_vdpu383;
76*437bfbebSnyanmisaka     else if (p->is_v384a)
77*437bfbebSnyanmisaka         p->api = &hal_h265d_vdpu384a;
78*437bfbebSnyanmisaka     else
79*437bfbebSnyanmisaka         p->api = &hal_h265d_rkv;
80*437bfbebSnyanmisaka 
81*437bfbebSnyanmisaka     cfg->support_fast_mode = 1;
82*437bfbebSnyanmisaka 
83*437bfbebSnyanmisaka     p->cfg = cfg->cfg;
84*437bfbebSnyanmisaka     p->slots = cfg->frame_slots;
85*437bfbebSnyanmisaka     p->dec_cb = cfg->dec_cb;
86*437bfbebSnyanmisaka     p->fast_mode = cfg->cfg->base.fast_parse;
87*437bfbebSnyanmisaka     p->packet_slots = cfg->packet_slots;
88*437bfbebSnyanmisaka 
89*437bfbebSnyanmisaka     mpp_env_get_u32("hal_h265d_debug", &hal_h265d_debug, 0);
90*437bfbebSnyanmisaka 
91*437bfbebSnyanmisaka     ret = p->api->init(ctx, cfg);
92*437bfbebSnyanmisaka 
93*437bfbebSnyanmisaka     return ret;
94*437bfbebSnyanmisaka }
95*437bfbebSnyanmisaka 
hal_h265d_deinit(void * ctx)96*437bfbebSnyanmisaka MPP_RET hal_h265d_deinit(void *ctx)
97*437bfbebSnyanmisaka {
98*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
99*437bfbebSnyanmisaka     HalH265dCtx *p = (HalH265dCtx *)ctx;
100*437bfbebSnyanmisaka 
101*437bfbebSnyanmisaka     if (p && p->api && p->api->deinit)
102*437bfbebSnyanmisaka         ret = p->api->deinit(ctx);
103*437bfbebSnyanmisaka 
104*437bfbebSnyanmisaka     if (p->dev) {
105*437bfbebSnyanmisaka         mpp_dev_deinit(p->dev);
106*437bfbebSnyanmisaka         p->dev = NULL;
107*437bfbebSnyanmisaka     }
108*437bfbebSnyanmisaka 
109*437bfbebSnyanmisaka     return ret;
110*437bfbebSnyanmisaka }
111*437bfbebSnyanmisaka 
hal_h265d_gen_regs(void * ctx,HalTaskInfo * task)112*437bfbebSnyanmisaka MPP_RET hal_h265d_gen_regs(void *ctx, HalTaskInfo *task)
113*437bfbebSnyanmisaka {
114*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
115*437bfbebSnyanmisaka     HalH265dCtx *p = (HalH265dCtx *)ctx;
116*437bfbebSnyanmisaka 
117*437bfbebSnyanmisaka     if (p && p->api && p->api->reg_gen)
118*437bfbebSnyanmisaka         ret = p->api->reg_gen(ctx, task);
119*437bfbebSnyanmisaka 
120*437bfbebSnyanmisaka     return ret;
121*437bfbebSnyanmisaka }
122*437bfbebSnyanmisaka 
hal_h265d_start(void * ctx,HalTaskInfo * task)123*437bfbebSnyanmisaka MPP_RET hal_h265d_start(void *ctx, HalTaskInfo *task)
124*437bfbebSnyanmisaka {
125*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
126*437bfbebSnyanmisaka     HalH265dCtx *p = (HalH265dCtx *)ctx;
127*437bfbebSnyanmisaka 
128*437bfbebSnyanmisaka     if (p && p->api && p->api->start)
129*437bfbebSnyanmisaka         ret = p->api->start(ctx, task);
130*437bfbebSnyanmisaka 
131*437bfbebSnyanmisaka     return ret;
132*437bfbebSnyanmisaka }
133*437bfbebSnyanmisaka 
hal_h265d_wait(void * ctx,HalTaskInfo * task)134*437bfbebSnyanmisaka MPP_RET hal_h265d_wait(void *ctx, HalTaskInfo *task)
135*437bfbebSnyanmisaka {
136*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
137*437bfbebSnyanmisaka     HalH265dCtx *p = (HalH265dCtx *)ctx;
138*437bfbebSnyanmisaka 
139*437bfbebSnyanmisaka     if (p && p->api && p->api->wait)
140*437bfbebSnyanmisaka         ret = p->api->wait(ctx, task);
141*437bfbebSnyanmisaka 
142*437bfbebSnyanmisaka     return ret;
143*437bfbebSnyanmisaka }
144*437bfbebSnyanmisaka 
hal_h265d_reset(void * ctx)145*437bfbebSnyanmisaka MPP_RET hal_h265d_reset(void *ctx)
146*437bfbebSnyanmisaka {
147*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
148*437bfbebSnyanmisaka     HalH265dCtx *p = (HalH265dCtx *)ctx;
149*437bfbebSnyanmisaka 
150*437bfbebSnyanmisaka     if (p && p->api && p->api->reset)
151*437bfbebSnyanmisaka         ret = p->api->reset(ctx);
152*437bfbebSnyanmisaka 
153*437bfbebSnyanmisaka     return ret;
154*437bfbebSnyanmisaka }
155*437bfbebSnyanmisaka 
hal_h265d_flush(void * ctx)156*437bfbebSnyanmisaka MPP_RET hal_h265d_flush(void *ctx)
157*437bfbebSnyanmisaka {
158*437bfbebSnyanmisaka     MPP_RET ret = MPP_NOK;
159*437bfbebSnyanmisaka     HalH265dCtx *p = (HalH265dCtx *)ctx;
160*437bfbebSnyanmisaka 
161*437bfbebSnyanmisaka     if (p && p->api && p->api->flush)
162*437bfbebSnyanmisaka         ret = p->api->flush(ctx);
163*437bfbebSnyanmisaka 
164*437bfbebSnyanmisaka     return ret;
165*437bfbebSnyanmisaka }
166*437bfbebSnyanmisaka 
hal_h265d_control(void * ctx,MpiCmd cmd,void * param)167*437bfbebSnyanmisaka MPP_RET hal_h265d_control(void *ctx, MpiCmd cmd, void *param)
168*437bfbebSnyanmisaka {
169*437bfbebSnyanmisaka     MPP_RET ret = MPP_OK;
170*437bfbebSnyanmisaka     HalH265dCtx *p = (HalH265dCtx *)ctx;
171*437bfbebSnyanmisaka 
172*437bfbebSnyanmisaka     if (p && p->api && p->api->control)
173*437bfbebSnyanmisaka         ret = p->api->control(ctx, cmd, param);
174*437bfbebSnyanmisaka 
175*437bfbebSnyanmisaka     return ret;
176*437bfbebSnyanmisaka }
177*437bfbebSnyanmisaka 
178*437bfbebSnyanmisaka const MppHalApi hal_api_h265d = {
179*437bfbebSnyanmisaka     .name = "h265d_rkdec",
180*437bfbebSnyanmisaka     .type = MPP_CTX_DEC,
181*437bfbebSnyanmisaka     .coding = MPP_VIDEO_CodingHEVC,
182*437bfbebSnyanmisaka     .ctx_size = sizeof(HalH265dCtx),
183*437bfbebSnyanmisaka     .flag = 0,
184*437bfbebSnyanmisaka     .init = hal_h265d_init,
185*437bfbebSnyanmisaka     .deinit = hal_h265d_deinit,
186*437bfbebSnyanmisaka     .reg_gen = hal_h265d_gen_regs,
187*437bfbebSnyanmisaka     .start = hal_h265d_start,
188*437bfbebSnyanmisaka     .wait = hal_h265d_wait,
189*437bfbebSnyanmisaka     .reset = hal_h265d_reset,
190*437bfbebSnyanmisaka     .flush = hal_h265d_flush,
191*437bfbebSnyanmisaka     .control = hal_h265d_control,
192*437bfbebSnyanmisaka };
193