/*
|
* Copyright 2018 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_M2VD_VDPU1_REG_H__
|
#define __HAL_M2VD_VDPU1_REG_H__
|
|
#include "rk_type.h"
|
|
#define M2VD_VDPU1_REG_NUM (101)
|
|
typedef struct {
|
struct {
|
RK_U32 build_version : 3;
|
RK_U32 product_IDen : 1;
|
RK_U32 minor_version : 8;
|
RK_U32 major_version : 4;
|
RK_U32 product_numer : 16;
|
} sw00;
|
|
struct {
|
RK_U32 dec_e : 1;
|
RK_U32 reserve0 : 3;
|
RK_U32 dec_irq_dis : 1;
|
RK_U32 reserve1 : 3;
|
RK_U32 dec_irq : 1;
|
RK_U32 reserve2 : 3;
|
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;
|
|
struct {
|
RK_U32 dec_max_burst : 5;
|
RK_U32 dec_scmd_dis : 1;
|
RK_U32 dec_adv_pre_dis : 1;
|
RK_U32 priority_mode : 1; //chang
|
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_data_disc_e : 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_rn_id : 8;
|
} 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_topfield_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 ref_frames : 5;
|
RK_U32 topfieldfirst_e : 1;
|
RK_U32 alt_scan_e : 1;
|
RK_U32 mb_height_off : 4;
|
RK_U32 pic_mb_height_p : 8;
|
RK_U32 mb_width_off : 4;
|
RK_U32 pic_mb_width : 9;
|
} sw04;
|
|
struct {
|
RK_U32 frame_pred_dct : 1;
|
RK_U32 intra_vlc_tab : 1;
|
RK_U32 intra_dc_prec : 2;
|
RK_U32 con_mv_e : 1;
|
RK_U32 reserve : 19;
|
RK_U32 qscale_type : 1;
|
RK_U32 reserve1 : 1;
|
RK_U32 stream_start_bit : 6;
|
} sw05;
|
|
struct {
|
RK_U32 stream_len : 24;
|
RK_U32 ch_8pix_ileav_e : 1;
|
RK_U32 init_qp : 6;
|
RK_U32 start_code_e : 1;
|
} sw06;
|
|
RK_U32 Reg07_11[5];
|
|
struct {
|
RK_U32 rlc_vlc_base : 32;
|
} sw12;
|
|
struct {
|
RK_U32 dec_out_base : 32;
|
} sw13;
|
|
struct {
|
RK_U32 refer0_base : 32;
|
} sw14;
|
|
struct {
|
RK_U32 refer1_base : 32;
|
} sw15;
|
|
struct {
|
RK_U32 refer2_base : 32;
|
} sw16;
|
|
struct {
|
RK_U32 refer3_base : 32;
|
} sw17;
|
|
struct {
|
RK_U32 reserve : 1;
|
RK_U32 mv_accuracy_bwd : 1;
|
RK_U32 mv_accuracy_fwd : 1;
|
RK_U32 fcode_bwd_ver : 4;
|
RK_U32 fcode_bwd_hor : 4;
|
RK_U32 fcode_fwd_ver : 4;
|
RK_U32 fcode_fwd_hor : 4;
|
RK_U32 alt_scan_flag_e : 1;
|
RK_U32 reserve1 : 12;
|
} sw18;
|
|
RK_U32 sw19_39[21];
|
|
struct {
|
RK_U32 qtable_base : 32;
|
} sw40;
|
|
struct {
|
RK_U32 dir_mv_base : 32;
|
} sw41;
|
|
RK_U32 sw42_47[6];
|
|
struct {
|
RK_U32 reserve : 15;
|
RK_U32 startmb_y : 8;
|
RK_U32 startmb_x : 9;
|
} sw48;
|
|
RK_U32 sw49_50[2];
|
|
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;
|
|
RK_U32 sw53_54[2];
|
|
struct {
|
RK_U32 apf_threshold : 14;
|
RK_U32 refbu2_picid : 5;
|
RK_U32 refbu2_thr : 12;
|
RK_U32 refbu2_buf_e : 1;
|
} sw55;
|
|
RK_U32 sw56_100[45];
|
|
} M2vdVdpu1Reg_t;
|
|
#endif // __HAL_M2VD_VDPU1_REG_H__
|