203 lines
5.7 KiB
C
Executable File
203 lines
5.7 KiB
C
Executable File
/*
|
|
* Copyright 2016 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_RC_DEFS_H__
|
|
#define __MPP_RC_DEFS_H__
|
|
|
|
#include "rk_venc_ref.h"
|
|
|
|
#define MAX_CPB_REFS (8)
|
|
|
|
typedef enum EncFrmType_e {
|
|
INTER_P_FRAME = 0,
|
|
INTER_B_FRAME = 1,
|
|
INTRA_FRAME = 2,
|
|
INTER_VI_FRAME = 3,
|
|
} EncFrmType;
|
|
|
|
/*
|
|
* EncFrmStatus controls record the encoding frame status and also control
|
|
* work flow of encoder. It is the communicat channel between encoder implement
|
|
* module, rate control module and hardware module.
|
|
*
|
|
* bit 0 ~ 31 frame status
|
|
* 0 ~ 15 current frame status
|
|
* 16 ~ 31 reference frame status
|
|
* bit 32 ~ 63 encoding flow control
|
|
*/
|
|
typedef union EncFrmStatus_u {
|
|
struct {
|
|
/*
|
|
* bit 0 ~ 31 frame status
|
|
*/
|
|
/* status flag */
|
|
RK_U32 valid : 1;
|
|
/*
|
|
* 0 - write the reconstructed frame pixel to memory
|
|
* 1 - do not write the reconstructed frame pixel to memory
|
|
*/
|
|
RK_U32 non_recn : 1;
|
|
|
|
/*
|
|
* 0 - normal frame and normal dpb management
|
|
* 1 - save recon frame as first pass extra frame. Used in two pass mode
|
|
*/
|
|
RK_U32 save_pass1 : 1;
|
|
|
|
/*
|
|
* 0 - use normal input source frame as input
|
|
* 1 - use the previously stored first pass recon frame as input frame
|
|
*/
|
|
RK_U32 use_pass1 : 1;
|
|
|
|
/* reference status flag */
|
|
/*
|
|
* 0 - inter frame
|
|
* 1 - intra frame
|
|
*/
|
|
RK_U32 is_intra : 1;
|
|
|
|
/*
|
|
* Valid when is_intra is true
|
|
* 0 - normal intra frame
|
|
* 1 - IDR frame
|
|
*/
|
|
RK_U32 is_idr : 1;
|
|
|
|
/*
|
|
* 0 - mark as reference frame
|
|
* 1 - mark as non-refernce frame
|
|
*/
|
|
RK_U32 is_non_ref : 1;
|
|
|
|
/*
|
|
* Valid when is_non_ref is false
|
|
* 0 - mark as short-term reference frame
|
|
* 1 - mark as long-term refernce frame
|
|
*/
|
|
RK_U32 is_lt_ref : 1;
|
|
|
|
/* bit 8 - 15 */
|
|
RK_U32 lt_idx : 4;
|
|
RK_U32 temporal_id : 4;
|
|
|
|
/* distance between current frame and reference frame */
|
|
MppEncRefMode ref_mode : 6;
|
|
RK_S32 ref_arg : 8;
|
|
RK_S32 ref_dist : 2;
|
|
|
|
/*
|
|
* bit 32 ~ 63 encoder flow control flags
|
|
*/
|
|
/*
|
|
* 0 - normal frame encoding
|
|
* 1 - current frame will be dropped
|
|
*/
|
|
RK_U32 drop : 1;
|
|
|
|
/*
|
|
* 0 - rate control module does not change frame type parameter
|
|
* 1 - rate control module changes frame type parameter reencode is needed
|
|
* to reprocess the dpb process. Also this means dpb module will follow
|
|
* the frame status parameter provided by rate control module.
|
|
*/
|
|
RK_U32 re_dpb_proc : 1;
|
|
|
|
/*
|
|
* 0 - current frame encoding is in normal flow
|
|
* 1 - current frame encoding is in reencode flow
|
|
*/
|
|
RK_U32 reencode : 1;
|
|
|
|
/*
|
|
* When true current frame size is super large then the frame should be reencoded.
|
|
*/
|
|
RK_U32 super_frame : 1;
|
|
|
|
/*
|
|
* When true currnet frame is force to encoded as software skip frame
|
|
*/
|
|
RK_U32 force_pskip : 1;
|
|
RK_U32 reserved1 : 3;
|
|
|
|
/* reencode times */
|
|
RK_U32 reencode_times : 8;
|
|
|
|
/* sequential index for each frame */
|
|
RK_U32 seq_idx : 16;
|
|
};
|
|
RK_U64 val;
|
|
} EncFrmStatus;
|
|
|
|
typedef struct EncCpbStatus_t {
|
|
RK_S32 seq_idx;
|
|
|
|
EncFrmStatus curr;
|
|
EncFrmStatus refr;
|
|
|
|
/* initial cpb status for current frame encoding */
|
|
EncFrmStatus init[MAX_CPB_REFS];
|
|
/* final cpb status after current frame encoding */
|
|
EncFrmStatus final[MAX_CPB_REFS];
|
|
} EncCpbStatus;
|
|
|
|
#define ENC_RC_FORCE_QP (0x00000001)
|
|
|
|
typedef struct EncRcForceCfg_t {
|
|
RK_U32 force_flag;
|
|
RK_S32 force_qp;
|
|
RK_U32 reserve[6];
|
|
} EncRcForceCfg;
|
|
|
|
/*
|
|
* communication channel between rc / hal / hardware
|
|
*
|
|
* rc -> hal bit_target / bit_max / bit_min
|
|
* hal -> hw quality_target / quality_max / quality_min
|
|
* hw -> rc / hal bit_real / quality_real / madi / madp
|
|
*/
|
|
typedef struct EncRcCommonInfo_t {
|
|
EncFrmType frame_type;
|
|
|
|
/* rc to hal */
|
|
RK_S32 bit_target;
|
|
RK_S32 bit_max;
|
|
RK_S32 bit_min;
|
|
|
|
RK_S32 quality_target;
|
|
RK_S32 quality_max;
|
|
RK_S32 quality_min;
|
|
|
|
/* rc from hardware */
|
|
RK_S32 bit_real;
|
|
RK_S32 quality_real;
|
|
RK_S32 madi;
|
|
RK_S32 madp;
|
|
|
|
RK_U32 iblk4_prop; // scale 256
|
|
RK_S32 reserve[15];
|
|
} EncRcTaskInfo;
|
|
|
|
typedef struct EncRcTask_s {
|
|
EncCpbStatus cpb;
|
|
EncFrmStatus frm;
|
|
EncRcTaskInfo info;
|
|
EncRcForceCfg force;
|
|
MppFrame frame;
|
|
} EncRcTask;
|
|
|
|
#endif /* __MPP_RC_DEFS_H__ */
|