xref: /rockchip-linux_mpp/mpp/codec/enc/vp8/vp8e_api_v2.c (revision 437bfbeb9567cca9cd9080e3f6954aa9d6a94f18)
1*437bfbebSnyanmisaka /*
2*437bfbebSnyanmisaka  * Copyright 2015 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 #define MODULE_TAG  "vp8e_api_v2"
17*437bfbebSnyanmisaka 
18*437bfbebSnyanmisaka #include <string.h>
19*437bfbebSnyanmisaka #include <limits.h>
20*437bfbebSnyanmisaka 
21*437bfbebSnyanmisaka #include "mpp_env.h"
22*437bfbebSnyanmisaka #include "mpp_mem.h"
23*437bfbebSnyanmisaka #include "mpp_debug.h"
24*437bfbebSnyanmisaka #include "mpp_common.h"
25*437bfbebSnyanmisaka #include "mpp_rc.h"
26*437bfbebSnyanmisaka #include "mpp_enc_cfg.h"
27*437bfbebSnyanmisaka 
28*437bfbebSnyanmisaka #include "vp8e_api_v2.h"
29*437bfbebSnyanmisaka #include "vp8e_syntax.h"
30*437bfbebSnyanmisaka 
31*437bfbebSnyanmisaka #define VP8E_DBG_FUNCTION            (0x00000001)
32*437bfbebSnyanmisaka #define VP8E_DBG_CFG                 (0x00000002)
33*437bfbebSnyanmisaka 
34*437bfbebSnyanmisaka #define vp8e_dbg_cfg(fmt, ...)    _mpp_dbg_f(vp8e_debug, VP8E_DBG_CFG, fmt, ## __VA_ARGS__)
35*437bfbebSnyanmisaka #define vp8e_dbg_fun(fmt, ...)    _mpp_dbg_f(vp8e_debug, VP8E_DBG_FUNCTION, fmt, ## __VA_ARGS__)
36*437bfbebSnyanmisaka 
37*437bfbebSnyanmisaka RK_U32 vp8e_debug = 0;
38*437bfbebSnyanmisaka #define VP8E_SYN_BUTT 2
39*437bfbebSnyanmisaka 
40*437bfbebSnyanmisaka typedef struct {
41*437bfbebSnyanmisaka     /* config from mpp_enc */
42*437bfbebSnyanmisaka     MppEncCfgSet    *cfg;
43*437bfbebSnyanmisaka 
44*437bfbebSnyanmisaka     /* internal rate control config*/
45*437bfbebSnyanmisaka     Vp8eRc          *rc;
46*437bfbebSnyanmisaka 
47*437bfbebSnyanmisaka     Vp8eSyntax      vp8e_syntax[VP8E_SYN_BUTT];
48*437bfbebSnyanmisaka } Vp8eCtx;
49*437bfbebSnyanmisaka 
vp8e_init(void * ctx,EncImplCfg * ctrl_cfg)50*437bfbebSnyanmisaka static MPP_RET vp8e_init(void *ctx, EncImplCfg *ctrl_cfg)
51*437bfbebSnyanmisaka {
52*437bfbebSnyanmisaka     MPP_RET ret = MPP_OK;
53*437bfbebSnyanmisaka     Vp8eCtx *p = (Vp8eCtx *)ctx;
54*437bfbebSnyanmisaka 
55*437bfbebSnyanmisaka     MppEncRcCfg *rc_cfg = &ctrl_cfg->cfg->rc;
56*437bfbebSnyanmisaka     MppEncPrepCfg *prep = &ctrl_cfg->cfg->prep;
57*437bfbebSnyanmisaka 
58*437bfbebSnyanmisaka     vp8e_dbg_fun("enter\n");
59*437bfbebSnyanmisaka     if (NULL == ctx || NULL == ctrl_cfg) {
60*437bfbebSnyanmisaka         mpp_err_f("Init failed, contex or controller cfg is null!\n");
61*437bfbebSnyanmisaka         ret = MPP_NOK;
62*437bfbebSnyanmisaka         goto __ERR_RET;
63*437bfbebSnyanmisaka     }
64*437bfbebSnyanmisaka 
65*437bfbebSnyanmisaka     p->cfg = ctrl_cfg->cfg;
66*437bfbebSnyanmisaka 
67*437bfbebSnyanmisaka     /*
68*437bfbebSnyanmisaka      * default prep:
69*437bfbebSnyanmisaka      * 720p
70*437bfbebSnyanmisaka      * YUV420SP
71*437bfbebSnyanmisaka      */
72*437bfbebSnyanmisaka     prep->width = 1280;
73*437bfbebSnyanmisaka     prep->height = 720;
74*437bfbebSnyanmisaka     prep->hor_stride = 1280;
75*437bfbebSnyanmisaka     prep->ver_stride = 720;
76*437bfbebSnyanmisaka     prep->format = MPP_FMT_YUV420SP;
77*437bfbebSnyanmisaka     prep->rotation = MPP_ENC_ROT_0;
78*437bfbebSnyanmisaka     prep->rotation_ext = MPP_ENC_ROT_0;
79*437bfbebSnyanmisaka     prep->mirroring = 0;
80*437bfbebSnyanmisaka     prep->mirroring_ext = 0;
81*437bfbebSnyanmisaka     prep->denoise = 0;
82*437bfbebSnyanmisaka 
83*437bfbebSnyanmisaka     /*
84*437bfbebSnyanmisaka      * default rc_cfg:
85*437bfbebSnyanmisaka      * CBR
86*437bfbebSnyanmisaka      * 2Mbps +-25%
87*437bfbebSnyanmisaka      * 30fps
88*437bfbebSnyanmisaka      * gop 60
89*437bfbebSnyanmisaka      */
90*437bfbebSnyanmisaka     rc_cfg->rc_mode = MPP_ENC_RC_MODE_CBR;
91*437bfbebSnyanmisaka     rc_cfg->quality = MPP_ENC_RC_QUALITY_MEDIUM;
92*437bfbebSnyanmisaka     rc_cfg->bps_target = 2000 * 1000;
93*437bfbebSnyanmisaka     rc_cfg->bps_max = rc_cfg->bps_target * 5 / 4;
94*437bfbebSnyanmisaka     rc_cfg->bps_min = rc_cfg->bps_target * 3 / 4;
95*437bfbebSnyanmisaka     rc_cfg->fps_in_flex = 0;
96*437bfbebSnyanmisaka     rc_cfg->fps_in_num = 30;
97*437bfbebSnyanmisaka     rc_cfg->fps_in_denom = 1;
98*437bfbebSnyanmisaka     rc_cfg->fps_out_flex = 0;
99*437bfbebSnyanmisaka     rc_cfg->fps_out_num = 30;
100*437bfbebSnyanmisaka     rc_cfg->fps_out_denom = 1;
101*437bfbebSnyanmisaka     rc_cfg->gop = 60;
102*437bfbebSnyanmisaka     rc_cfg->max_reenc_times = 1;
103*437bfbebSnyanmisaka     rc_cfg->fqp_min_i = INT_MAX;
104*437bfbebSnyanmisaka     rc_cfg->fqp_min_p = INT_MAX;
105*437bfbebSnyanmisaka     rc_cfg->fqp_max_i = INT_MAX;
106*437bfbebSnyanmisaka     rc_cfg->fqp_max_p = INT_MAX;
107*437bfbebSnyanmisaka 
108*437bfbebSnyanmisaka     p->rc = mpp_calloc(Vp8eRc, 1);
109*437bfbebSnyanmisaka     memset(p->rc, 0, sizeof(Vp8eRc));
110*437bfbebSnyanmisaka     p->rc->frame_coded = 1;
111*437bfbebSnyanmisaka     if (NULL == p->rc) {
112*437bfbebSnyanmisaka         mpp_err_f("failed to malloc vp8_rc\n");
113*437bfbebSnyanmisaka         ret = MPP_ERR_MALLOC;
114*437bfbebSnyanmisaka         goto __ERR_RET;
115*437bfbebSnyanmisaka     }
116*437bfbebSnyanmisaka 
117*437bfbebSnyanmisaka     mpp_env_get_u32("vp8e_debug", &vp8e_debug, 0);
118*437bfbebSnyanmisaka 
119*437bfbebSnyanmisaka     vp8e_dbg_fun("leave ret %d\n", ret);
120*437bfbebSnyanmisaka     return ret;
121*437bfbebSnyanmisaka 
122*437bfbebSnyanmisaka __ERR_RET:
123*437bfbebSnyanmisaka     vp8e_dbg_fun("leave ret %d\n", ret);
124*437bfbebSnyanmisaka     return ret;
125*437bfbebSnyanmisaka }
126*437bfbebSnyanmisaka 
vp8e_deinit(void * ctx)127*437bfbebSnyanmisaka static MPP_RET vp8e_deinit(void *ctx)
128*437bfbebSnyanmisaka {
129*437bfbebSnyanmisaka     Vp8eCtx *p = (Vp8eCtx *)ctx;
130*437bfbebSnyanmisaka 
131*437bfbebSnyanmisaka     vp8e_dbg_fun("enter\n");
132*437bfbebSnyanmisaka 
133*437bfbebSnyanmisaka     if (p->rc)
134*437bfbebSnyanmisaka         mpp_free(p->rc);
135*437bfbebSnyanmisaka 
136*437bfbebSnyanmisaka     vp8e_dbg_fun("leave\n");
137*437bfbebSnyanmisaka     return MPP_OK;
138*437bfbebSnyanmisaka }
139*437bfbebSnyanmisaka 
vp8e_start(void * ctx,HalEncTask * task)140*437bfbebSnyanmisaka static MPP_RET vp8e_start(void *ctx, HalEncTask *task)
141*437bfbebSnyanmisaka {
142*437bfbebSnyanmisaka     (void)ctx;
143*437bfbebSnyanmisaka     (void)task;
144*437bfbebSnyanmisaka 
145*437bfbebSnyanmisaka     return MPP_OK;
146*437bfbebSnyanmisaka }
147*437bfbebSnyanmisaka 
vp8e_proc_dpb(void * ctx,HalEncTask * task)148*437bfbebSnyanmisaka static MPP_RET vp8e_proc_dpb(void *ctx, HalEncTask *task)
149*437bfbebSnyanmisaka {
150*437bfbebSnyanmisaka     (void)ctx;
151*437bfbebSnyanmisaka     EncRcTask    *rc_task = task->rc_task;
152*437bfbebSnyanmisaka     EncCpbStatus *cpb = &task->rc_task->cpb;
153*437bfbebSnyanmisaka     rc_task->frm.val = cpb->curr.val;
154*437bfbebSnyanmisaka     return MPP_OK;
155*437bfbebSnyanmisaka }
156*437bfbebSnyanmisaka 
vp8e_proc_cfg(void * ctx,MpiCmd cmd,void * param)157*437bfbebSnyanmisaka static MPP_RET vp8e_proc_cfg(void *ctx, MpiCmd cmd, void *param)
158*437bfbebSnyanmisaka {
159*437bfbebSnyanmisaka     MPP_RET ret = MPP_OK;
160*437bfbebSnyanmisaka 
161*437bfbebSnyanmisaka     vp8e_dbg_fun("enter ctx %p cmd %x param %p\n", ctx, cmd, param);
162*437bfbebSnyanmisaka     switch (cmd) {
163*437bfbebSnyanmisaka     case MPP_ENC_SET_CFG : {
164*437bfbebSnyanmisaka     } break;
165*437bfbebSnyanmisaka     default: {
166*437bfbebSnyanmisaka         mpp_err("No correspond cmd found, and can not config!");
167*437bfbebSnyanmisaka         ret = MPP_NOK;
168*437bfbebSnyanmisaka     } break;
169*437bfbebSnyanmisaka     }
170*437bfbebSnyanmisaka 
171*437bfbebSnyanmisaka     vp8e_dbg_fun("leave ret %d\n", ret);
172*437bfbebSnyanmisaka     return ret;
173*437bfbebSnyanmisaka }
174*437bfbebSnyanmisaka 
vp8e_proc_hal(void * ctx,HalEncTask * task)175*437bfbebSnyanmisaka static MPP_RET vp8e_proc_hal(void *ctx, HalEncTask *task)
176*437bfbebSnyanmisaka {
177*437bfbebSnyanmisaka     Vp8eCtx *p = (Vp8eCtx *)ctx;
178*437bfbebSnyanmisaka     Vp8eSyntax *syntax = &p->vp8e_syntax[0];
179*437bfbebSnyanmisaka     RK_U32 syn_num = 0;
180*437bfbebSnyanmisaka 
181*437bfbebSnyanmisaka     syntax[syn_num].type = VP8E_SYN_CFG;
182*437bfbebSnyanmisaka     syntax[syn_num].data = p->cfg;
183*437bfbebSnyanmisaka     syn_num++;
184*437bfbebSnyanmisaka     syntax[syn_num].type = VP8E_SYN_RC;
185*437bfbebSnyanmisaka     syntax[syn_num].data = p->rc;
186*437bfbebSnyanmisaka     syn_num++;
187*437bfbebSnyanmisaka     task->syntax.data = syntax;
188*437bfbebSnyanmisaka     task->syntax.number = syn_num;
189*437bfbebSnyanmisaka 
190*437bfbebSnyanmisaka     task->valid = 1;
191*437bfbebSnyanmisaka     return MPP_OK;
192*437bfbebSnyanmisaka }
193*437bfbebSnyanmisaka 
194*437bfbebSnyanmisaka const EncImplApi api_vp8e = {
195*437bfbebSnyanmisaka     .name       = "vp8_control",
196*437bfbebSnyanmisaka     .coding     = MPP_VIDEO_CodingVP8,
197*437bfbebSnyanmisaka     .ctx_size   = sizeof(Vp8eCtx),
198*437bfbebSnyanmisaka     .flag       = 0,
199*437bfbebSnyanmisaka     .init       = vp8e_init,
200*437bfbebSnyanmisaka     .deinit     = vp8e_deinit,
201*437bfbebSnyanmisaka     .proc_cfg   = vp8e_proc_cfg,
202*437bfbebSnyanmisaka     .gen_hdr    = NULL,
203*437bfbebSnyanmisaka     .start      = vp8e_start,
204*437bfbebSnyanmisaka     .proc_dpb   = vp8e_proc_dpb,
205*437bfbebSnyanmisaka     .proc_hal   = vp8e_proc_hal,
206*437bfbebSnyanmisaka     .add_prefix = NULL,
207*437bfbebSnyanmisaka     .sw_enc     = NULL,
208*437bfbebSnyanmisaka };
209