/*
|
* Copyright 2015 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 __HAL_AVSD_REG_H__
|
#define __HAL_AVSD_REG_H__
|
|
#include "mpp_debug.h"
|
#include "mpp_device.h"
|
|
#include "parser_api.h"
|
#include "hal_avsd_api.h"
|
#include "avsd_syntax.h"
|
|
#define AVSD_HAL_DBG_ERROR (0x00000001)
|
#define AVSD_HAL_DBG_ASSERT (0x00000002)
|
#define AVSD_HAL_DBG_WARNNING (0x00000004)
|
#define AVSD_HAL_DBG_TRACE (0x00000008)
|
|
#define AVSD_HAL_DBG_OFFSET (0x00010000)
|
|
extern RK_U32 avsd_hal_debug;
|
|
#define AVSD_HAL_DBG(level, fmt, ...)\
|
do {\
|
if (level & avsd_hal_debug)\
|
{ mpp_log(fmt, ## __VA_ARGS__); }\
|
} while (0)
|
|
#define AVSD_HAL_TRACE(fmt, ...)\
|
do {\
|
if (AVSD_HAL_DBG_TRACE & avsd_hal_debug)\
|
{ mpp_log_f(fmt, ## __VA_ARGS__); }\
|
} while (0)
|
|
#define INP_CHECK(ret, val, ...)\
|
do{\
|
if ((val)) { \
|
ret = MPP_ERR_INIT; \
|
AVSD_HAL_DBG(AVSD_HAL_DBG_WARNNING, "input empty(%d).\n", __LINE__); \
|
goto __RETURN; \
|
}\
|
} while (0)
|
|
#define FUN_CHECK(val)\
|
do{\
|
if ((val) < 0) {\
|
AVSD_HAL_DBG(AVSD_HAL_DBG_WARNNING, "Function error(%d).\n", __LINE__); \
|
goto __FAILED; \
|
}\
|
} while (0)
|
|
//!< memory malloc check
|
#define MEM_CHECK(ret, val, ...)\
|
do{\
|
if (!(val)) {\
|
ret = MPP_ERR_MALLOC; \
|
mpp_err_f("malloc buffer error(%d).\n", __LINE__); \
|
goto __FAILED; \
|
}\
|
} while (0)
|
|
#define FIELDPICTURE 0
|
#define FRAMEPICTURE 1
|
|
enum {
|
IFRAME = 0,
|
PFRAME = 1,
|
BFRAME = 2
|
};
|
|
typedef struct avsd_hal_picture_t {
|
RK_U32 valid;
|
RK_U32 pic_type;
|
RK_U32 pic_code_type;
|
RK_U32 picture_distance;
|
|
RK_S32 slot_idx;
|
} AvsdHalPic_t;
|
|
typedef struct avsd_hal_ctx_t {
|
MppBufSlots frame_slots;
|
MppBufSlots packet_slots;
|
MppBufferGroup buf_group;
|
MppCbCtx *dec_cb;
|
MppDev dev;
|
AvsdSyntax_t syn;
|
RK_U32 *p_regs;
|
MppBuffer mv_buf;
|
|
AvsdHalPic_t pic[3];
|
//!< add for control
|
RK_U32 first_field;
|
RK_U32 prev_pic_structure;
|
RK_U32 prev_pic_code_type;
|
RK_S32 future2prev_past_dist;
|
RK_S32 work0;
|
RK_S32 work1;
|
RK_S32 work_out;
|
RK_U32 data_offset;
|
|
RK_U32 frame_no;
|
} AvsdHalCtx_t;
|
|
#define AVSD_REGISTERS 60
|
|
typedef struct {
|
RK_U32 sw00;
|
struct {
|
RK_U32 dec_e : 1;
|
RK_U32 reserve0 : 3;
|
RK_U32 dec_irq_dis : 1;
|
RK_U32 dec_abort_e : 1;
|
RK_U32 reserve1 : 2;
|
RK_U32 dec_irq : 1;
|
RK_U32 reserve2 : 2;
|
RK_U32 dec_abort_int : 1;
|
RK_U32 dec_rdy_int : 1;
|
RK_U32 dec_bus_int : 1;
|
RK_U32 dec_buffer_int : 1;
|
RK_U32 dec_aso_int : 1;
|
RK_U32 dec_error_int : 1;
|
RK_U32 dec_slice_int : 1;
|
RK_U32 dec_timeout : 1;
|
RK_U32 reserve3 : 5;
|
RK_U32 dec_pic_inf : 1;
|
RK_U32 reserve4 : 7;
|
} sw01;
|
union {
|
struct {
|
RK_U32 dec_max_burst : 5;
|
RK_U32 dec_scmd_dis : 1;
|
RK_U32 dec_adv_pre_dis : 1;
|
RK_U32 tiled_mode_lsb : 1;
|
RK_U32 dec_out_endian : 1;
|
RK_U32 dec_in_endian : 1;
|
RK_U32 dec_clk_gate_e : 1;
|
RK_U32 dec_latency : 6;
|
RK_U32 dec_out_tiled_e : 1;
|
RK_U32 dec_2chan_dis : 1;
|
RK_U32 dec_outswap32_e : 1;
|
RK_U32 dec_inswap32_e : 1;
|
RK_U32 dec_strendian_e : 1;
|
RK_U32 dec_strswap32_e : 1;
|
RK_U32 dec_timeout_e : 1;
|
RK_U32 dec_axi_rd_id : 8;
|
};
|
struct {
|
RK_U32 reserve0 : 5;
|
RK_U32 priority_mode : 3;
|
RK_U32 reserve1 : 9;
|
RK_U32 tiled_mode_msb : 1;
|
RK_U32 dec_data_disc_e : 1;
|
RK_U32 reserve2 : 13;
|
};
|
} sw02;
|
struct {
|
RK_U32 dec_axi_wr_id : 8;
|
RK_U32 dec_ahb_hlock_e : 1;
|
RK_U32 picord_count_e : 1;
|
RK_U32 seq_mbaff_e : 1;
|
RK_U32 reftopfirst_e : 1;
|
RK_U32 write_mvs_e : 1;
|
RK_U32 pic_fixed_quant : 1;
|
RK_U32 filtering_dis : 1;
|
RK_U32 dec_out_dis : 1;
|
RK_U32 ref_topfield_e : 1;
|
RK_U32 sorenson_e : 1;
|
RK_U32 fwd_interlace_e : 1;
|
RK_U32 pic_topfiled_e : 1;
|
RK_U32 pic_inter_e : 1;
|
RK_U32 pic_b_e : 1;
|
RK_U32 pic_fieldmode_e : 1;
|
RK_U32 pic_interlace_e : 1;
|
RK_U32 pjpeg_e : 1;
|
RK_U32 divx3_e : 1;
|
RK_U32 skip_mode : 1;
|
RK_U32 rlc_mode_e : 1;
|
RK_U32 dec_mode : 4;
|
} sw03;
|
struct {
|
RK_U32 pic_refer_flag : 1;
|
RK_U32 reverse0 : 10;
|
RK_U32 pic_mb_height_p : 8;
|
RK_U32 mb_width_off : 4;
|
RK_U32 pic_mb_width : 9;
|
} sw04;
|
union {
|
struct {
|
RK_U32 fieldpic_flag_e : 1;
|
RK_S32 reserve0 : 31;
|
};
|
struct {
|
RK_U32 beta_offset : 5;
|
RK_U32 alpha_offset : 5;
|
RK_U32 reserve1 : 16;
|
RK_U32 strm_start_bit : 6;
|
};
|
} sw05;
|
|
struct {
|
RK_U32 stream_len : 24;
|
RK_U32 stream_len_ext : 1;
|
RK_U32 init_qp : 6;
|
RK_U32 start_code_e : 1;
|
} sw06;
|
struct {
|
RK_U32 reserve0 : 25;
|
RK_U32 avs_h264_h_ext : 1;
|
RK_U32 reserve1 : 6;
|
} sw07;
|
RK_U32 sw08;
|
RK_U32 sw09;
|
RK_U32 sw10;
|
RK_U32 sw11;
|
struct {
|
RK_U32 rlc_vlc_base : 32;
|
} sw12;
|
union {
|
struct {
|
RK_U32 dec_out_base : 32;
|
};
|
struct { //!< left move 10bit
|
RK_U32 reserve0 : 11;
|
RK_U32 dpb_ilace_mode : 1;
|
RK_U32 reserve1 : 20;
|
};
|
} sw13;
|
union {
|
RK_U32 refer0_base : 32;
|
struct { //!< left move 10bit
|
RK_U32 reserve0 : 10;
|
RK_U32 refer0_topc_e : 1;
|
RK_U32 refer0_field_e : 1;
|
RK_U32 reserve1 : 20;
|
};
|
} sw14;
|
union {
|
struct {
|
RK_U32 refer1_base : 32;
|
};
|
struct { //!< left move 10bit
|
RK_U32 reserve0 : 10;
|
RK_U32 refer1_topc_e : 1;
|
RK_U32 refer1_field_e : 1;
|
RK_U32 reserve1 : 20;
|
};
|
} sw15;
|
union {
|
struct {
|
RK_U32 refer2_base : 32;
|
};
|
struct { //!< left move 10bit
|
RK_U32 reserve0 : 10;
|
RK_U32 refer2_topc_e : 1;
|
RK_U32 refer2_field_e : 1;
|
RK_U32 reserve1 : 20;
|
};
|
} sw16;
|
union {
|
struct {
|
RK_U32 refer3_base : 32;
|
};
|
struct { //!< left move 10bit
|
RK_U32 reserve0 : 10;
|
RK_U32 refer3_topc_e : 1;
|
RK_U32 refer3_field_e : 1;
|
RK_U32 reserve1 : 20;
|
};
|
} sw17;
|
struct {
|
RK_U32 prev_anc_type : 1;
|
RK_U32 reverse0 : 31;
|
} sw18;
|
RK_U32 sw19_27[9];
|
struct {
|
RK_U32 ref_invd_cur_0 : 16;
|
RK_U32 ref_invd_cur_1 : 16;
|
} sw28;
|
struct {
|
RK_U32 ref_invd_cur_2 : 16;
|
RK_U32 ref_invd_cur_3 : 16;
|
} sw29;
|
struct {
|
RK_U32 ref_dist_cur_0 : 16;
|
RK_U32 ref_dist_cur_1 : 16;
|
} sw30;
|
struct {
|
RK_U32 ref_dist_cur_2 : 16;
|
RK_U32 ref_dist_cur_3 : 16;
|
} sw31;
|
|
struct {
|
RK_U32 ref_invd_col_0 : 16;
|
RK_U32 ref_invd_col_1 : 16;
|
} sw32;
|
struct {
|
RK_U32 ref_invd_col_2 : 16;
|
RK_U32 ref_invd_col_3 : 16;
|
} sw33;
|
struct {
|
RK_U32 reserve0 : 2;
|
RK_U32 pred_bc_tap_1_1 : 10;
|
RK_U32 pred_bc_tap_1_0 : 10;
|
RK_U32 pred_bc_tap_0_3 : 10;
|
} sw34;
|
struct {
|
RK_U32 reserve0 : 12;
|
RK_U32 pred_bc_tap_1_3 : 10;
|
RK_U32 pred_bc_tap_1_2 : 10;
|
} sw35;
|
RK_U32 sw36_40[5];
|
struct {
|
RK_U32 dir_mv_base : 32;
|
} sw41;
|
struct {
|
RK_U32 ref_delta_cur_3 : 3;
|
RK_U32 ref_delta_cur_2 : 3;
|
RK_U32 ref_delta_cur_1 : 3;
|
RK_U32 ref_delta_cur_0 : 3;
|
RK_U32 ref_delta_col_3 : 3;
|
RK_U32 ref_delta_col_2 : 3;
|
RK_U32 ref_delta_col_1 : 3;
|
RK_U32 ref_delta_col_0 : 3;
|
RK_U32 weight_qp_1 : 8;
|
} sw42;
|
struct {
|
RK_U32 weight_qp_5 : 8;
|
RK_U32 weight_qp_4 : 8;
|
RK_U32 weight_qp_3 : 8;
|
RK_U32 weight_qp_2 : 8;
|
} sw43;
|
struct {
|
RK_U32 weight_qp_0 : 8;
|
RK_U32 qp_delta_cr : 6;
|
RK_U32 qp_delta_cb : 6;
|
RK_U32 pb_field_enhance_e : 1;
|
RK_U32 no_fwd_ref_e : 1;
|
RK_U32 avs_aec_e : 1;
|
RK_U32 weight_qp_model : 2;
|
RK_U32 weight_qp_e : 1;
|
RK_U32 dec_avsp_ena : 1;
|
RK_U32 reserve0 : 5;
|
} sw44;
|
struct {
|
RK_U32 dir_mv_base2 : 32;
|
} sw45;
|
RK_U32 sw46;
|
RK_U32 sw47;
|
struct {
|
RK_U32 reserve0 : 14;
|
RK_U32 startmb_y : 9;
|
RK_U32 startmb_x : 9;
|
} sw48;
|
struct {
|
RK_U32 reserve0 : 2;
|
RK_U32 pred_bc_tap_0_2 : 10;
|
RK_U32 pred_bc_tap_0_1 : 10;
|
RK_U32 pred_bc_tap_0_0 : 10;
|
} sw49;
|
RK_U32 sw50;
|
struct {
|
RK_U32 refbu_y_offset : 9;
|
RK_U32 reserve0 : 3;
|
RK_U32 refbu_fparmod_e : 1;
|
RK_U32 refbu_eval_e : 1;
|
RK_U32 refbu_picid : 5;
|
RK_U32 refbu_thr : 12;
|
RK_U32 refbu_e : 1;
|
} sw51;
|
struct {
|
RK_U32 refbu_intra_sum : 16;
|
RK_U32 refbu_hit_sum : 16;
|
} sw52;
|
struct {
|
RK_U32 refbu_y_mv_sum : 22;
|
RK_U32 reserve0 : 10;
|
} sw53;
|
RK_U32 sw54;
|
struct {
|
RK_U32 apf_threshold : 14;
|
RK_U32 refbu2_picid : 5;
|
RK_U32 refbu2_thr : 12;
|
RK_U32 refbu2_buf_e : 1;
|
} sw55;
|
|
struct {
|
RK_U32 refbu_bot_sum : 16;
|
RK_U32 refbu_top_sum : 16;
|
};
|
RK_U32 sw57;
|
struct {
|
RK_U32 reserve0 : 31;
|
RK_U32 serv_merge_dis : 1;
|
} sw58;
|
RK_U32 sw59;
|
} AvsdRegs_t;
|
|
|
|
|
#ifdef __cplusplus
|
extern "C" {
|
#endif
|
|
MPP_RET set_defalut_parameters(AvsdHalCtx_t *p_hal);
|
MPP_RET set_regs_parameters(AvsdHalCtx_t *p_hal, HalDecTask *task);
|
MPP_RET update_parameters(AvsdHalCtx_t *p_hal);
|
#ifdef __cplusplus
|
}
|
#endif
|
|
#endif /*__HAL_AVSD_REG_H__*/
|