You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1192 lines
66 KiB
1192 lines
66 KiB
|
7 months ago
|
//-----------------------------------------------------------------------------
|
||
|
|
// COPYRIGHT (C) 2020 CHIPS&MEDIA INC. ALL RIGHTS RESERVED
|
||
|
|
//
|
||
|
|
// This file is distributed under BSD 3 clause and LGPL2.1 (dual license)
|
||
|
|
// SPDX License Identifier: BSD-3-Clause
|
||
|
|
// SPDX License Identifier: LGPL-2.1-only
|
||
|
|
//
|
||
|
|
// The entire notice above must be reproduced on all authorized copies.
|
||
|
|
//
|
||
|
|
// Description :
|
||
|
|
//-----------------------------------------------------------------------------
|
||
|
|
|
||
|
|
#include "../../config.h"
|
||
|
|
|
||
|
|
#ifndef __WAVE5_REGISTER_DEFINE_H__
|
||
|
|
#define __WAVE5_REGISTER_DEFINE_H__
|
||
|
|
|
||
|
|
typedef enum {
|
||
|
|
W5_INIT_VPU = 0x0001,
|
||
|
|
W5_WAKEUP_VPU = 0x0002,
|
||
|
|
W5_SLEEP_VPU = 0x0004,
|
||
|
|
W5_CREATE_INSTANCE = 0x0008, /* queuing command */
|
||
|
|
W5_FLUSH_INSTANCE = 0x0010,
|
||
|
|
W5_DESTROY_INSTANCE= 0x0020, /* queuing command */
|
||
|
|
W5_INIT_SEQ = 0x0040, /* queuing command */
|
||
|
|
W5_SET_FB = 0x0080,
|
||
|
|
W5_DEC_PIC = 0x0100, /* queuing command */
|
||
|
|
W5_ENC_PIC = 0x0100, /* queuing command */
|
||
|
|
W5_ENC_SET_PARAM = 0x0200, /* queuing command */
|
||
|
|
W5_QUERY = 0x4000,
|
||
|
|
W5_UPDATE_BS = 0x8000,
|
||
|
|
W5_MAX_VPU_COMD = 0x10000,
|
||
|
|
} W5_VPU_COMMAND;
|
||
|
|
|
||
|
|
typedef enum {
|
||
|
|
GET_VPU_INFO = 0,
|
||
|
|
SET_WRITE_PROT = 1,
|
||
|
|
GET_RESULT = 2,
|
||
|
|
UPDATE_DISP_FLAG = 3,
|
||
|
|
GET_BW_REPORT = 4,
|
||
|
|
GET_BS_RD_PTR = 5, // for decoder
|
||
|
|
GET_BS_WR_PTR = 6, // for encoder
|
||
|
|
GET_SRC_BUF_FLAG = 7, // for encoder
|
||
|
|
SET_BS_RD_PTR = 8, // for decoder
|
||
|
|
GET_DEBUG_INFO = 0x61,
|
||
|
|
} QUERY_OPT;
|
||
|
|
|
||
|
|
#define W5_REG_BASE 0x00000000
|
||
|
|
#define W5_CMD_REG_BASE 0x00000100
|
||
|
|
#define W5_CMD_REG_END 0x00000200
|
||
|
|
|
||
|
|
/*
|
||
|
|
* Common
|
||
|
|
*/
|
||
|
|
/* Power On Configuration
|
||
|
|
* PO_DEBUG_MODE [0] 1 - Power On with debug mode
|
||
|
|
* USE_PO_CONF [3] 1 - Use Power-On-Configuration
|
||
|
|
*/
|
||
|
|
#define W5_PO_CONF (W5_REG_BASE + 0x0000)
|
||
|
|
#define W5_VCPU_CUR_PC (W5_REG_BASE + 0x0004)
|
||
|
|
#define W5_VCPU_CUR_LR (W5_REG_BASE + 0x0008)
|
||
|
|
#define W5_VPU_PDBG_STEP_MASK_V (W5_REG_BASE + 0x000C)
|
||
|
|
#define W5_VPU_PDBG_CTRL (W5_REG_BASE + 0x0010) // vCPU debugger ctrl register
|
||
|
|
#define W5_VPU_PDBG_IDX_REG (W5_REG_BASE + 0x0014) // vCPU debugger index register
|
||
|
|
#define W5_VPU_PDBG_WDATA_REG (W5_REG_BASE + 0x0018) // vCPU debugger write data register
|
||
|
|
#define W5_VPU_PDBG_RDATA_REG (W5_REG_BASE + 0x001C) // vCPU debugger read data register
|
||
|
|
|
||
|
|
#define W5_VPU_FIO_CTRL_ADDR (W5_REG_BASE + 0x0020)
|
||
|
|
#define W5_VPU_FIO_DATA (W5_REG_BASE + 0x0024)
|
||
|
|
#define W5_VPU_VINT_REASON_USR (W5_REG_BASE + 0x0030)
|
||
|
|
#define W5_VPU_VINT_REASON_CLR (W5_REG_BASE + 0x0034)
|
||
|
|
#define W5_VPU_HOST_INT_REQ (W5_REG_BASE + 0x0038)
|
||
|
|
#define W5_VPU_VINT_CLEAR (W5_REG_BASE + 0x003C)
|
||
|
|
#define W5_VPU_HINT_CLEAR (W5_REG_BASE + 0x0040)
|
||
|
|
#define W5_VPU_VPU_INT_STS (W5_REG_BASE + 0x0044)
|
||
|
|
#define W5_VPU_VINT_ENABLE (W5_REG_BASE + 0x0048)
|
||
|
|
#define W5_VPU_VINT_REASON (W5_REG_BASE + 0x004C)
|
||
|
|
#define W5_VPU_RESET_REQ (W5_REG_BASE + 0x0050)
|
||
|
|
#define W5_RST_BLOCK_CCLK(_core) (1<<_core)
|
||
|
|
#define W5_RST_BLOCK_CCLK_ALL (0xff)
|
||
|
|
#define W5_RST_BLOCK_BCLK(_core) (0x100<<_core)
|
||
|
|
#define W5_RST_BLOCK_BCLK_ALL (0xff00)
|
||
|
|
#define W5_RST_BLOCK_ACLK(_core) (0x10000<<_core)
|
||
|
|
#define W5_RST_BLOCK_ACLK_ALL (0xff0000)
|
||
|
|
#define W5_RST_BLOCK_VCPU_ALL (0x3f000000)
|
||
|
|
#define W5_RST_BLOCK_ALL (0x3fffffff)
|
||
|
|
#define W5_VPU_RESET_STATUS (W5_REG_BASE + 0x0054)
|
||
|
|
|
||
|
|
#define W5_VCPU_RESTART (W5_REG_BASE + 0x0058)
|
||
|
|
#define W5_VPU_CLK_MASK (W5_REG_BASE + 0x005C)
|
||
|
|
|
||
|
|
|
||
|
|
/* REMAP_CTRL
|
||
|
|
* PAGE SIZE: [8:0] 0x001 - 4K
|
||
|
|
* 0x002 - 8K
|
||
|
|
* 0x004 - 16K
|
||
|
|
* ...
|
||
|
|
* 0x100 - 1M
|
||
|
|
* REGION ATTR1 [10] 0 - Normal
|
||
|
|
* 1 - Make Bus error for the region
|
||
|
|
* REGION ATTR2 [11] 0 - Normal
|
||
|
|
* 1 - Bypass region
|
||
|
|
* REMAP INDEX [15:12] - 0 ~ 3
|
||
|
|
* ENDIAN [19:16] - See EndianMode in vdi.h
|
||
|
|
* AXI-ID [23:20] - Upper AXI-ID
|
||
|
|
* BUS_ERROR [29] 0 - bypass
|
||
|
|
* 1 - Make BUS_ERROR for unmapped region
|
||
|
|
* BYPASS_ALL [30] 1 - Bypass all
|
||
|
|
* ENABLE [31] 1 - Update control register[30:16]
|
||
|
|
*/
|
||
|
|
#define W5_VPU_REMAP_CTRL (W5_REG_BASE + 0x0060)
|
||
|
|
#define W5_VPU_REMAP_VADDR (W5_REG_BASE + 0x0064)
|
||
|
|
#define W5_VPU_REMAP_PADDR (W5_REG_BASE + 0x0068)
|
||
|
|
#define W5_VPU_REMAP_CORE_START (W5_REG_BASE + 0x006C)
|
||
|
|
#define W5_VPU_BUSY_STATUS (W5_REG_BASE + 0x0070)
|
||
|
|
#define W5_VPU_HALT_STATUS (W5_REG_BASE + 0x0074)
|
||
|
|
#define W5_VPU_VCPU_STATUS (W5_REG_BASE + 0x0078)
|
||
|
|
#define W5_VPU_RET_PRODUCT_VERSION (W5_REG_BASE + 0x0094)
|
||
|
|
/*
|
||
|
|
assign vpu_config0 = {conf_map_converter_reg, // [31]
|
||
|
|
conf_map_converter_sig, // [30]
|
||
|
|
8'd0, // [29:22]
|
||
|
|
conf_std_switch_en, // [21]
|
||
|
|
conf_bg_detect, // [20]
|
||
|
|
conf_3dnr_en, // [19]
|
||
|
|
conf_one_axi_en, // [18]
|
||
|
|
conf_sec_axi_en, // [17]
|
||
|
|
conf_bus_info, // [16]
|
||
|
|
conf_afbc_en, // [15]
|
||
|
|
conf_afbc_version_id, // [14:12]
|
||
|
|
conf_fbc_en, // [11]
|
||
|
|
conf_fbc_version_id, // [10:08]
|
||
|
|
conf_scaler_en, // [07]
|
||
|
|
conf_scaler_version_id, // [06:04]
|
||
|
|
conf_bwb_en, // [03]
|
||
|
|
3'd0}; // [02:00]
|
||
|
|
*/
|
||
|
|
#define W5_VPU_RET_VPU_CONFIG0 (W5_REG_BASE + 0x0098)
|
||
|
|
/*
|
||
|
|
assign vpu_config1 = {4'd0, // [31:28]
|
||
|
|
conf_perf_timer_en, // [27]
|
||
|
|
conf_multi_core_en, // [26]
|
||
|
|
conf_gcu_en, // [25]
|
||
|
|
conf_cu_report, // [24]
|
||
|
|
4'd0, // [23:20]
|
||
|
|
conf_vcore_id_3, // [19]
|
||
|
|
conf_vcore_id_2, // [18]
|
||
|
|
conf_vcore_id_1, // [17]
|
||
|
|
conf_vcore_id_0, // [16]
|
||
|
|
conf_bwb_opt, // [15]
|
||
|
|
7'd0, // [14:08]
|
||
|
|
conf_cod_std_en_reserved_7, // [7]
|
||
|
|
conf_cod_std_en_reserved_6, // [6]
|
||
|
|
conf_cod_std_en_reserved_5, // [5]
|
||
|
|
conf_cod_std_en_reserved_4, // [4]
|
||
|
|
conf_cod_std_en_reserved_3, // [3]
|
||
|
|
conf_cod_std_en_reserved_2, // [2]
|
||
|
|
conf_cod_std_en_vp9, // [1]
|
||
|
|
conf_cod_std_en_hevc}; // [0]
|
||
|
|
}
|
||
|
|
*/
|
||
|
|
#define W5_VPU_RET_VPU_CONFIG1 (W5_REG_BASE + 0x009C)
|
||
|
|
|
||
|
|
#define W5_VPU_DBG_REG0 (W5_REG_BASE + 0x00f0)
|
||
|
|
#define W5_VPU_DBG_REG1 (W5_REG_BASE + 0x00f4)
|
||
|
|
#define W5_VPU_DBG_REG2 (W5_REG_BASE + 0x00f8)
|
||
|
|
#define W5_VPU_DBG_REG3 (W5_REG_BASE + 0x00fc)
|
||
|
|
|
||
|
|
#ifdef SUPPORT_SW_UART_V2
|
||
|
|
#define W5_SW_UART_STATUS W5_VPU_DBG_REG0
|
||
|
|
#define W5_SW_UART_TX_DATA W5_VPU_DBG_REG1
|
||
|
|
#endif
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* PRODUCT INFORMATION */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_PRODUCT_NAME (W5_REG_BASE + 0x1040)
|
||
|
|
#define W5_PRODUCT_NUMBER (W5_REG_BASE + 0x1044)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* DECODER/ENCODER COMMON */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_COMMAND (W5_REG_BASE + 0x0100)
|
||
|
|
#define W5_COMMAND_OPTION (W5_REG_BASE + 0x0104)
|
||
|
|
#define W5_QUERY_OPTION (W5_REG_BASE + 0x0104)
|
||
|
|
#define W5_RET_SUCCESS (W5_REG_BASE + 0x0108)
|
||
|
|
#define W5_RET_FAIL_REASON (W5_REG_BASE + 0x010C)
|
||
|
|
#define W5_RET_QUEUE_FAIL_REASON (W5_REG_BASE + 0x0110)
|
||
|
|
#define W5_CMD_INSTANCE_INFO (W5_REG_BASE + 0x0110)
|
||
|
|
|
||
|
|
#define W5_RET_QUEUE_STATUS (W5_REG_BASE + 0x01E0)
|
||
|
|
#define W5_RET_BS_EMPTY_INST (W5_REG_BASE + 0x01E4)
|
||
|
|
#define W5_RET_QUEUE_CMD_DONE_INST (W5_REG_BASE + 0x01E8)
|
||
|
|
#define W5_RET_STAGE0_INSTANCE_INFO (W5_REG_BASE + 0x01EC)
|
||
|
|
#define W5_RET_STAGE1_INSTANCE_INFO (W5_REG_BASE + 0x01F0)
|
||
|
|
#define W5_RET_STAGE2_INSTANCE_INFO (W5_REG_BASE + 0x01F4)
|
||
|
|
|
||
|
|
#define W5_RET_SEQ_DONE_INSTANCE_INFO (W5_REG_BASE + 0x01FC)
|
||
|
|
|
||
|
|
#define W5_BS_OPTION (W5_REG_BASE + 0x0120)
|
||
|
|
|
||
|
|
#define W5_RET_VLC_BUF_SIZE (W5_REG_BASE + 0x01B0) // return info when QUERY (GET_RESULT) for en/decoder
|
||
|
|
#define W5_RET_PARAM_BUF_SIZE (W5_REG_BASE + 0x01B4) // return info when QUERY (GET_RESULT) for en/decoder
|
||
|
|
|
||
|
|
#define W5_CMD_SET_FB_ADDR_TASK_BUF (W5_REG_BASE + 0x01D4) // set when SET_FB for en/decoder
|
||
|
|
#define W5_CMD_SET_FB_TASK_BUF_SIZE (W5_REG_BASE + 0x01D8)
|
||
|
|
/************************************************************************/
|
||
|
|
/* INIT_VPU - COMMON */
|
||
|
|
/************************************************************************/
|
||
|
|
/* Note: W5_ADDR_CODE_BASE should be aligned to 4KB */
|
||
|
|
#define W5_ADDR_CODE_BASE (W5_REG_BASE + 0x0110)
|
||
|
|
#define W5_CODE_SIZE (W5_REG_BASE + 0x0114)
|
||
|
|
#define W5_CODE_PARAM (W5_REG_BASE + 0x0118)
|
||
|
|
#define W5_ADDR_TEMP_BASE (W5_REG_BASE + 0x011C)
|
||
|
|
#define W5_TEMP_SIZE (W5_REG_BASE + 0x0120)
|
||
|
|
#define W5_ADDR_SEC_AXI (W5_REG_BASE + 0x0124)
|
||
|
|
#define W5_SEC_AXI_SIZE (W5_REG_BASE + 0x0128)
|
||
|
|
#define W5_HW_OPTION (W5_REG_BASE + 0x012C)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* CREATE_INSTANCE - COMMON */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_ADDR_WORK_BASE (W5_REG_BASE + 0x0114)
|
||
|
|
#define W5_WORK_SIZE (W5_REG_BASE + 0x0118)
|
||
|
|
#define W5_CMD_DEC_BS_START_ADDR (W5_REG_BASE + 0x011C)
|
||
|
|
#define W5_CMD_DEC_BS_SIZE (W5_REG_BASE + 0x0120)
|
||
|
|
#define W5_CMD_BS_PARAM (W5_REG_BASE + 0x0124)
|
||
|
|
#define W5_CMD_NUM_CQ_DEPTH_M1 (W5_REG_BASE + 0x013C)
|
||
|
|
#define W5_CMD_ERR_CONCEAL (W5_REG_BASE + 0x0140)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* DECODER - INIT_SEQ */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_BS_RD_PTR (W5_REG_BASE + 0x0118)
|
||
|
|
#define W5_BS_WR_PTR (W5_REG_BASE + 0x011C)
|
||
|
|
/************************************************************************/
|
||
|
|
/* SET_FRAME_BUF */
|
||
|
|
/************************************************************************/
|
||
|
|
/* SET_FB_OPTION 0x00 REGISTER FRAMEBUFFERS
|
||
|
|
0x01 UPDATE FRAMEBUFFER, just one framebuffer(linear, fbc and mvcol)
|
||
|
|
*/
|
||
|
|
#define W5_SFB_OPTION (W5_REG_BASE + 0x0104)
|
||
|
|
#define W5_COMMON_PIC_INFO (W5_REG_BASE + 0x0118)
|
||
|
|
#define W5_PIC_SIZE (W5_REG_BASE + 0x011C)
|
||
|
|
#define W5_SET_FB_NUM (W5_REG_BASE + 0x0120)
|
||
|
|
#define W5_EXTRA_PIC_INFO (W5_REG_BASE + 0x0124)
|
||
|
|
|
||
|
|
#define W5_ADDR_LUMA_BASE0 (W5_REG_BASE + 0x0134)
|
||
|
|
#define W5_ADDR_CB_BASE0 (W5_REG_BASE + 0x0138)
|
||
|
|
#define W5_ADDR_CR_BASE0 (W5_REG_BASE + 0x013C)
|
||
|
|
#define W5_ADDR_FBC_Y_OFFSET0 (W5_REG_BASE + 0x013C) // Compression offset table for Luma
|
||
|
|
#define W5_ADDR_FBC_C_OFFSET0 (W5_REG_BASE + 0x0140) // Compression offset table for Chroma
|
||
|
|
#define W5_ADDR_LUMA_BASE1 (W5_REG_BASE + 0x0144)
|
||
|
|
#define W5_ADDR_CB_ADDR1 (W5_REG_BASE + 0x0148)
|
||
|
|
#define W5_ADDR_CR_ADDR1 (W5_REG_BASE + 0x014C)
|
||
|
|
#define W5_ADDR_FBC_Y_OFFSET1 (W5_REG_BASE + 0x014C) // Compression offset table for Luma
|
||
|
|
#define W5_ADDR_FBC_C_OFFSET1 (W5_REG_BASE + 0x0150) // Compression offset table for Chroma
|
||
|
|
#define W5_ADDR_LUMA_BASE2 (W5_REG_BASE + 0x0154)
|
||
|
|
#define W5_ADDR_CB_ADDR2 (W5_REG_BASE + 0x0158)
|
||
|
|
#define W5_ADDR_CR_ADDR2 (W5_REG_BASE + 0x015C)
|
||
|
|
#define W5_ADDR_FBC_Y_OFFSET2 (W5_REG_BASE + 0x015C) // Compression offset table for Luma
|
||
|
|
#define W5_ADDR_FBC_C_OFFSET2 (W5_REG_BASE + 0x0160) // Compression offset table for Chroma
|
||
|
|
#define W5_ADDR_LUMA_BASE3 (W5_REG_BASE + 0x0164)
|
||
|
|
#define W5_ADDR_CB_ADDR3 (W5_REG_BASE + 0x0168)
|
||
|
|
#define W5_ADDR_CR_ADDR3 (W5_REG_BASE + 0x016C)
|
||
|
|
#define W5_ADDR_FBC_Y_OFFSET3 (W5_REG_BASE + 0x016C) // Compression offset table for Luma
|
||
|
|
#define W5_ADDR_FBC_C_OFFSET3 (W5_REG_BASE + 0x0170) // Compression offset table for Chroma
|
||
|
|
#define W5_ADDR_LUMA_BASE4 (W5_REG_BASE + 0x0174)
|
||
|
|
#define W5_ADDR_CB_ADDR4 (W5_REG_BASE + 0x0178)
|
||
|
|
#define W5_ADDR_CR_ADDR4 (W5_REG_BASE + 0x017C)
|
||
|
|
#define W5_ADDR_FBC_Y_OFFSET4 (W5_REG_BASE + 0x017C) // Compression offset table for Luma
|
||
|
|
#define W5_ADDR_FBC_C_OFFSET4 (W5_REG_BASE + 0x0180) // Compression offset table for Chroma
|
||
|
|
#define W5_ADDR_LUMA_BASE5 (W5_REG_BASE + 0x0184)
|
||
|
|
#define W5_ADDR_CB_ADDR5 (W5_REG_BASE + 0x0188)
|
||
|
|
#define W5_ADDR_CR_ADDR5 (W5_REG_BASE + 0x018C)
|
||
|
|
#define W5_ADDR_FBC_Y_OFFSET5 (W5_REG_BASE + 0x018C) // Compression offset table for Luma
|
||
|
|
#define W5_ADDR_FBC_C_OFFSET5 (W5_REG_BASE + 0x0190) // Compression offset table for Chroma
|
||
|
|
#define W5_ADDR_LUMA_BASE6 (W5_REG_BASE + 0x0194)
|
||
|
|
#define W5_ADDR_CB_ADDR6 (W5_REG_BASE + 0x0198)
|
||
|
|
#define W5_ADDR_CR_ADDR6 (W5_REG_BASE + 0x019C)
|
||
|
|
#define W5_ADDR_FBC_Y_OFFSET6 (W5_REG_BASE + 0x019C) // Compression offset table for Luma
|
||
|
|
#define W5_ADDR_FBC_C_OFFSET6 (W5_REG_BASE + 0x01A0) // Compression offset table for Chroma
|
||
|
|
#define W5_ADDR_LUMA_BASE7 (W5_REG_BASE + 0x01A4)
|
||
|
|
#define W5_ADDR_CB_ADDR7 (W5_REG_BASE + 0x01A8)
|
||
|
|
#define W5_ADDR_CR_ADDR7 (W5_REG_BASE + 0x01AC)
|
||
|
|
#define W5_ADDR_FBC_Y_OFFSET7 (W5_REG_BASE + 0x01AC) // Compression offset table for Luma
|
||
|
|
#define W5_ADDR_FBC_C_OFFSET7 (W5_REG_BASE + 0x01B0) // Compression offset table for Chroma
|
||
|
|
#define W5_ADDR_MV_COL0 (W5_REG_BASE + 0x01B4)
|
||
|
|
#define W5_ADDR_MV_COL1 (W5_REG_BASE + 0x01B8)
|
||
|
|
#define W5_ADDR_MV_COL2 (W5_REG_BASE + 0x01BC)
|
||
|
|
#define W5_ADDR_MV_COL3 (W5_REG_BASE + 0x01C0)
|
||
|
|
#define W5_ADDR_MV_COL4 (W5_REG_BASE + 0x01C4)
|
||
|
|
#define W5_ADDR_MV_COL5 (W5_REG_BASE + 0x01C8)
|
||
|
|
#define W5_ADDR_MV_COL6 (W5_REG_BASE + 0x01CC)
|
||
|
|
#define W5_ADDR_MV_COL7 (W5_REG_BASE + 0x01D0)
|
||
|
|
|
||
|
|
/* UPDATE_FB */
|
||
|
|
/* CMD_SET_FB_STRIDE [15:0] - FBC framebuffer stride
|
||
|
|
[31:15] - Linear framebuffer stride
|
||
|
|
*/
|
||
|
|
#define W5_CMD_SET_FB_STRIDE (W5_REG_BASE + 0x0118)
|
||
|
|
#define W5_CMD_SET_FB_INDEX (W5_REG_BASE + 0x0120)
|
||
|
|
#define W5_ADDR_LUMA_BASE (W5_REG_BASE + 0x0134)
|
||
|
|
#define W5_ADDR_CB_BASE (W5_REG_BASE + 0x0138)
|
||
|
|
#define W5_ADDR_CR_BASE (W5_REG_BASE + 0x013C)
|
||
|
|
#define W5_ADDR_MV_COL (W5_REG_BASE + 0x0140)
|
||
|
|
#define W5_ADDR_FBC_Y_BASE (W5_REG_BASE + 0x0144)
|
||
|
|
#define W5_ADDR_FBC_C_BASE (W5_REG_BASE + 0x0148)
|
||
|
|
#define W5_ADDR_FBC_Y_OFFSET (W5_REG_BASE + 0x014C)
|
||
|
|
#define W5_ADDR_FBC_C_OFFSET (W5_REG_BASE + 0x0150)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* DECODER - DEC_PIC */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_CMD_DEC_VCORE_INFO (W5_REG_BASE + 0x0194)
|
||
|
|
/* Sequence change enable mask register
|
||
|
|
* CMD_SEQ_CHANGE_ENABLE_FLAG [5] profile_idc
|
||
|
|
* [16] pic_width/height_in_luma_sample
|
||
|
|
* [19] sps_max_dec_pic_buffering, max_num_reorder, max_latency_increase
|
||
|
|
*/
|
||
|
|
#define W5_CMD_SEQ_CHANGE_ENABLE_FLAG (W5_REG_BASE + 0x0128)
|
||
|
|
#define W5_CMD_DEC_USER_MASK (W5_REG_BASE + 0x012C)
|
||
|
|
#define W5_CMD_DEC_TEMPORAL_ID_PLUS1 (W5_REG_BASE + 0x0130)
|
||
|
|
#define W5_CMD_DEC_REL_TEMPORAL_ID (W5_REG_BASE + 0x0130)
|
||
|
|
#define W5_CMD_DEC_FORCE_FB_LATENCY_PLUS1 (W5_REG_BASE + 0x0134)
|
||
|
|
#define W5_USE_SEC_AXI (W5_REG_BASE + 0x0150)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* DECODER - QUERY : GET_VPU_INFO */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_RET_FW_VERSION (W5_REG_BASE + 0x0118)
|
||
|
|
#define W5_RET_PRODUCT_NAME (W5_REG_BASE + 0x011C)
|
||
|
|
#define W5_RET_PRODUCT_VERSION (W5_REG_BASE + 0x0120)
|
||
|
|
#define W5_RET_STD_DEF0 (W5_REG_BASE + 0x0124)
|
||
|
|
#define W5_RET_STD_DEF1 (W5_REG_BASE + 0x0128)
|
||
|
|
#define W5_RET_CONF_FEATURE (W5_REG_BASE + 0x012C)
|
||
|
|
#define W5_RET_CONF_DATE (W5_REG_BASE + 0x0130)
|
||
|
|
#define W5_RET_CONF_REVISION (W5_REG_BASE + 0x0134)
|
||
|
|
#define W5_RET_CONF_TYPE (W5_REG_BASE + 0x0138)
|
||
|
|
#define W5_RET_PRODUCT_ID (W5_REG_BASE + 0x013C)
|
||
|
|
#define W5_RET_CUSTOMER_ID (W5_REG_BASE + 0x0140)
|
||
|
|
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* DECODER - QUERY : GET_RESULT */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_CMD_DEC_ADDR_REPORT_BASE (W5_REG_BASE + 0x0114)
|
||
|
|
#define W5_CMD_DEC_REPORT_SIZE (W5_REG_BASE + 0x0118)
|
||
|
|
#define W5_CMD_DEC_REPORT_PARAM (W5_REG_BASE + 0x011C)
|
||
|
|
|
||
|
|
#define W5_RET_DEC_BS_RD_PTR (W5_REG_BASE + 0x011C)
|
||
|
|
#define W5_RET_DEC_SEQ_PARAM (W5_REG_BASE + 0x0120)
|
||
|
|
#define W5_RET_DEC_COLOR_SAMPLE_INFO (W5_REG_BASE + 0x0124)
|
||
|
|
#define W5_RET_DEC_ASPECT_RATIO (W5_REG_BASE + 0x0128)
|
||
|
|
#define W5_RET_DEC_BIT_RATE (W5_REG_BASE + 0x012C)
|
||
|
|
#define W5_RET_DEC_FRAME_RATE_NR (W5_REG_BASE + 0x0130)
|
||
|
|
#define W5_RET_DEC_FRAME_RATE_DR (W5_REG_BASE + 0x0134)
|
||
|
|
#define W5_RET_DEC_NUM_REQUIRED_FB (W5_REG_BASE + 0x0138)
|
||
|
|
#define W5_RET_DEC_NUM_REORDER_DELAY (W5_REG_BASE + 0x013C)
|
||
|
|
#define W5_RET_DEC_SUB_LAYER_INFO (W5_REG_BASE + 0x0140)
|
||
|
|
#define W5_RET_DEC_NOTIFICATION (W5_REG_BASE + 0x0144)
|
||
|
|
#define W5_RET_DEC_USERDATA_IDC (W5_REG_BASE + 0x0148)
|
||
|
|
#define W5_RET_DEC_PIC_SIZE (W5_REG_BASE + 0x014C)
|
||
|
|
#define W5_RET_DEC_CROP_TOP_BOTTOM (W5_REG_BASE + 0x0150)
|
||
|
|
#define W5_RET_DEC_CROP_LEFT_RIGHT (W5_REG_BASE + 0x0154)
|
||
|
|
#define W5_RET_DEC_AU_START_POS (W5_REG_BASE + 0x0158)
|
||
|
|
#define W5_RET_DEC_AU_END_POS (W5_REG_BASE + 0x015C)
|
||
|
|
#define W5_RET_DEC_PIC_TYPE (W5_REG_BASE + 0x0160)
|
||
|
|
#define W5_RET_DEC_PIC_POC (W5_REG_BASE + 0x0164)
|
||
|
|
#define W5_RET_DEC_RECOVERY_POINT (W5_REG_BASE + 0x0168)
|
||
|
|
#define W5_RET_DEC_DEBUG_INDEX (W5_REG_BASE + 0x016C)
|
||
|
|
#define W5_RET_DEC_DECODED_INDEX (W5_REG_BASE + 0x0170)
|
||
|
|
#define W5_RET_DEC_DISPLAY_INDEX (W5_REG_BASE + 0x0174)
|
||
|
|
#define W5_RET_DEC_REALLOC_INDEX (W5_REG_BASE + 0x0178)
|
||
|
|
#define W5_RET_DEC_DISP_IDC (W5_REG_BASE + 0x017C)
|
||
|
|
#define W5_RET_DEC_ERR_CTB_NUM (W5_REG_BASE + 0x0180)
|
||
|
|
#define W5_RET_DEC_PIC_PARAM (W5_REG_BASE + 0x01A0)
|
||
|
|
|
||
|
|
#define W5_RET_DEC_HOST_CMD_TICK (W5_REG_BASE + 0x01B8)
|
||
|
|
#define W5_RET_DEC_SEEK_START_TICK (W5_REG_BASE + 0x01BC)
|
||
|
|
#define W5_RET_DEC_SEEK_END_TICK (W5_REG_BASE + 0x01C0)
|
||
|
|
#define W5_RET_DEC_PARSING_START_TICK (W5_REG_BASE + 0x01C4)
|
||
|
|
#define W5_RET_DEC_PARSING_END_TICK (W5_REG_BASE + 0x01C8)
|
||
|
|
#define W5_RET_DEC_DECODING_START_TICK (W5_REG_BASE + 0x01CC)
|
||
|
|
#define W5_RET_DEC_DECODING_ENC_TICK (W5_REG_BASE + 0x01D0)
|
||
|
|
#ifdef SUPPORT_SW_UART
|
||
|
|
#define W5_SW_UART_STATUS (W5_REG_BASE + 0x01D4)
|
||
|
|
#define W5_SW_UART_TX_DATA (W5_REG_BASE + 0x01D8)
|
||
|
|
//#define W5_RET_DEC_WARN_INFO (W5_REG_BASE + 0x01D4)
|
||
|
|
//#define W5_RET_DEC_ERR_INFO (W5_REG_BASE + 0x01D8)
|
||
|
|
#else
|
||
|
|
#define W5_RET_DEC_WARN_INFO (W5_REG_BASE + 0x01D4)
|
||
|
|
#define W5_RET_DEC_ERR_INFO (W5_REG_BASE + 0x01D8)
|
||
|
|
#endif
|
||
|
|
#define W5_RET_DEC_DECODING_SUCCESS (W5_REG_BASE + 0x01DC)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* DECODER - FLUSH_INSTANCE */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_CMD_FLUSH_INST_OPT (W5_REG_BASE + 0x104)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* DECODER - QUERY : UPDATE_DISP_FLAG */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_CMD_DEC_SET_DISP_IDC (W5_REG_BASE + 0x0118)
|
||
|
|
#define W5_CMD_DEC_CLR_DISP_IDC (W5_REG_BASE + 0x011C)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* DECODER - QUERY : SET_BS_RD_PTR */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_RET_QUERY_DEC_SET_BS_RD_PTR (W5_REG_BASE + 0x011C)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* DECODER - QUERY : GET_BS_RD_PTR */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_RET_QUERY_DEC_BS_RD_PTR (W5_REG_BASE + 0x011C)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* QUERY : GET_DEBUG_INFO */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_RET_QUERY_DEBUG_PRI_REASON (W5_REG_BASE + 0x114)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* GDI register for Debugging */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_GDI_BASE 0x8800
|
||
|
|
#define W5_GDI_BUS_CTRL (W5_GDI_BASE + 0x0F0)
|
||
|
|
#define W5_GDI_BUS_STATUS (W5_GDI_BASE + 0x0F4)
|
||
|
|
|
||
|
|
#define W5_BACKBONE_BASE_VCPU 0xFE00
|
||
|
|
#define W5_BACKBONE_BUS_CTRL_VCPU (W5_BACKBONE_BASE_VCPU + 0x010)
|
||
|
|
#define W5_BACKBONE_BUS_STATUS_VCPU (W5_BACKBONE_BASE_VCPU + 0x014)
|
||
|
|
#define W5_BACKBONE_PROG_AXI_ID (W5_BACKBONE_BASE_VCPU + 0x00C)
|
||
|
|
|
||
|
|
#define W5_BACKBONE_BASE_VCORE0 0x8E00
|
||
|
|
#define W5_BACKBONE_BUS_CTRL_VCORE0 (W5_BACKBONE_BASE_VCORE0 + 0x010)
|
||
|
|
#define W5_BACKBONE_BUS_STATUS_VCORE0 (W5_BACKBONE_BASE_VCORE0 + 0x014)
|
||
|
|
|
||
|
|
#define W5_BACKBONE_BASE_VCORE1 0x9E00 // for dual-core product
|
||
|
|
#define W5_BACKBONE_BUS_CTRL_VCORE1 (W5_BACKBONE_BASE_VCORE1 + 0x010)
|
||
|
|
#define W5_BACKBONE_BUS_STATUS_VCORE1 (W5_BACKBONE_BASE_VCORE1 + 0x014)
|
||
|
|
|
||
|
|
#define W5_COMBINED_BACKBONE_BASE 0xFE00
|
||
|
|
#define W5_COMBINED_BACKBONE_BUS_CTRL (W5_COMBINED_BACKBONE_BASE + 0x010)
|
||
|
|
#define W5_COMBINED_BACKBONE_BUS_STATUS (W5_COMBINED_BACKBONE_BASE + 0x014)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* */
|
||
|
|
/* For ENCODER */
|
||
|
|
/* */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_RET_STAGE3_INSTANCE_INFO (W5_REG_BASE + 0x1F8)
|
||
|
|
/************************************************************************/
|
||
|
|
/* ENCODER - CREATE_INSTANCE */
|
||
|
|
/************************************************************************/
|
||
|
|
// 0x114 ~ 0x124 : defined above (CREATE_INSTANCE COMMON)
|
||
|
|
#define W5_CMD_ENC_VCORE_INFO (W5_REG_BASE + 0x0194)
|
||
|
|
#define W5_CMD_ENC_SRC_OPTIONS (W5_REG_BASE + 0x0128)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* ENCODER - SET_FB */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_FBC_STRIDE (W5_REG_BASE + 0x128)
|
||
|
|
#define W5_ADDR_SUB_SAMPLED_FB_BASE (W5_REG_BASE + 0x12C)
|
||
|
|
#define W5_SUB_SAMPLED_ONE_FB_SIZE (W5_REG_BASE + 0x130)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* ENCODER - ENC_SET_PARAM (COMMON & CHANGE_PARAM) */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_CMD_ENC_SEQ_SET_PARAM_OPTION (W5_REG_BASE + 0x104)
|
||
|
|
#define W5_CMD_ENC_SEQ_SET_PARAM_ENABLE (W5_REG_BASE + 0x118)
|
||
|
|
#define W5_CMD_ENC_SEQ_SRC_SIZE (W5_REG_BASE + 0x11C)
|
||
|
|
#define W5_CMD_ENC_SEQ_CUSTOM_MAP_ENDIAN (W5_REG_BASE + 0x120)
|
||
|
|
#define W5_CMD_ENC_SEQ_SPS_PARAM (W5_REG_BASE + 0x124)
|
||
|
|
#define W5_CMD_ENC_SEQ_PPS_PARAM (W5_REG_BASE + 0x128)
|
||
|
|
#define W5_CMD_ENC_SEQ_GOP_PARAM (W5_REG_BASE + 0x12C)
|
||
|
|
#define W5_CMD_ENC_SEQ_INTRA_PARAM (W5_REG_BASE + 0x130)
|
||
|
|
#define W5_CMD_ENC_SEQ_CONF_WIN_TOP_BOT (W5_REG_BASE + 0x134)
|
||
|
|
#define W5_CMD_ENC_SEQ_CONF_WIN_LEFT_RIGHT (W5_REG_BASE + 0x138)
|
||
|
|
#define W5_CMD_ENC_SEQ_RDO_PARAM (W5_REG_BASE + 0x13C)
|
||
|
|
#define W5_CMD_ENC_SEQ_INDEPENDENT_SLICE (W5_REG_BASE + 0x140)
|
||
|
|
#define W5_CMD_ENC_SEQ_DEPENDENT_SLICE (W5_REG_BASE + 0x144)
|
||
|
|
#define W5_CMD_ENC_SEQ_INTRA_REFRESH (W5_REG_BASE + 0x148)
|
||
|
|
#define W5_CMD_ENC_SEQ_INPUT_SRC_PARAM (W5_REG_BASE + 0x14C)
|
||
|
|
|
||
|
|
#define W5_CMD_ENC_SEQ_RC_FRAME_RATE (W5_REG_BASE + 0x150)
|
||
|
|
#define W5_CMD_ENC_SEQ_RC_TARGET_RATE (W5_REG_BASE + 0x154)
|
||
|
|
#define W5_CMD_ENC_SEQ_RC_PARAM (W5_REG_BASE + 0x158)
|
||
|
|
#define W5_CMD_ENC_SEQ_RC_MIN_MAX_QP (W5_REG_BASE + 0x15C)
|
||
|
|
#define W5_CMD_ENC_SEQ_RC_BIT_RATIO_LAYER_0_3 (W5_REG_BASE + 0x160)
|
||
|
|
#define W5_CMD_ENC_SEQ_RC_BIT_RATIO_LAYER_4_7 (W5_REG_BASE + 0x164)
|
||
|
|
#define W5_CMD_ENC_SEQ_RC_INTER_MIN_MAX_QP (W5_REG_BASE + 0x168)
|
||
|
|
#define W5_CMD_ENC_SEQ_RC_WEIGHT_PARAM (W5_REG_BASE + 0x16C)
|
||
|
|
|
||
|
|
#define W5_CMD_ENC_SEQ_ROT_PARAM (W5_REG_BASE + 0x170)
|
||
|
|
#define W5_CMD_ENC_SEQ_NUM_UNITS_IN_TICK (W5_REG_BASE + 0x174)
|
||
|
|
#define W5_CMD_ENC_SEQ_TIME_SCALE (W5_REG_BASE + 0x178)
|
||
|
|
#define W5_CMD_ENC_SEQ_NUM_TICKS_POC_DIFF_ONE (W5_REG_BASE + 0x17C)
|
||
|
|
|
||
|
|
#define W5_CMD_ENC_SEQ_CUSTOM_MD_PU04 (W5_REG_BASE + 0x184)
|
||
|
|
#define W5_CMD_ENC_SEQ_CUSTOM_MD_PU08 (W5_REG_BASE + 0x188)
|
||
|
|
#define W5_CMD_ENC_SEQ_CUSTOM_MD_PU16 (W5_REG_BASE + 0x18C)
|
||
|
|
#define W5_CMD_ENC_SEQ_CUSTOM_MD_PU32 (W5_REG_BASE + 0x190)
|
||
|
|
#define W5_CMD_ENC_SEQ_CUSTOM_MD_CU08 (W5_REG_BASE + 0x194)
|
||
|
|
#define W5_CMD_ENC_SEQ_CUSTOM_MD_CU16 (W5_REG_BASE + 0x198)
|
||
|
|
#define W5_CMD_ENC_SEQ_CUSTOM_MD_CU32 (W5_REG_BASE + 0x19C)
|
||
|
|
#define W5_CMD_ENC_SEQ_NR_PARAM (W5_REG_BASE + 0x1A0)
|
||
|
|
#define W5_CMD_ENC_SEQ_NR_WEIGHT (W5_REG_BASE + 0x1A4)
|
||
|
|
#define W5_CMD_ENC_SEQ_BG_PARAM (W5_REG_BASE + 0x1A8)
|
||
|
|
#define W5_CMD_ENC_SEQ_CUSTOM_LAMBDA_ADDR (W5_REG_BASE + 0x1AC)
|
||
|
|
#define W5_CMD_ENC_SEQ_USER_SCALING_LIST_ADDR (W5_REG_BASE + 0x1B0)
|
||
|
|
#define W5_CMD_ENC_SEQ_VUI_HRD_PARAM (W5_REG_BASE + 0x180)
|
||
|
|
#define W5_CMD_ENC_SEQ_VUI_RBSP_ADDR (W5_REG_BASE + 0x1B8)
|
||
|
|
#define W5_CMD_ENC_SEQ_HRD_RBSP_ADDR (W5_REG_BASE + 0x1BC)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* ENCODER - ENC_SET_PARAM (CUSTOM_GOP) */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PARAM (W5_REG_BASE + 0x11C)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_0 (W5_REG_BASE + 0x120)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_1 (W5_REG_BASE + 0x124)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_2 (W5_REG_BASE + 0x128)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_3 (W5_REG_BASE + 0x12C)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_4 (W5_REG_BASE + 0x130)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_5 (W5_REG_BASE + 0x134)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_6 (W5_REG_BASE + 0x138)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_7 (W5_REG_BASE + 0x13C)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_8 (W5_REG_BASE + 0x140)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_9 (W5_REG_BASE + 0x144)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_10 (W5_REG_BASE + 0x148)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_11 (W5_REG_BASE + 0x14C)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_12 (W5_REG_BASE + 0x150)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_13 (W5_REG_BASE + 0x154)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_14 (W5_REG_BASE + 0x158)
|
||
|
|
#define W5_CMD_ENC_CUSTOM_GOP_PIC_PARAM_15 (W5_REG_BASE + 0x15C)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* ENCODER - ENC_PIC */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_CMD_ENC_BS_START_ADDR (W5_REG_BASE + 0x118)
|
||
|
|
#define W5_CMD_ENC_BS_SIZE (W5_REG_BASE + 0x11C)
|
||
|
|
#define W5_CMD_ENC_PIC_USE_SEC_AXI (W5_REG_BASE + 0x124)
|
||
|
|
#define W5_CMD_ENC_PIC_REPORT_PARAM (W5_REG_BASE + 0x128)
|
||
|
|
#define W5_CMD_ENC_PIC_REPORT_ENDIAN (W5_REG_BASE + 0x12C)
|
||
|
|
|
||
|
|
#define W5_CMD_ENC_PIC_CUSTOM_MAP_OPTION_PARAM (W5_REG_BASE + 0x138)
|
||
|
|
#define W5_CMD_ENC_PIC_CUSTOM_MAP_OPTION_ADDR (W5_REG_BASE + 0x13C)
|
||
|
|
#define W5_CMD_ENC_PIC_SRC_PIC_IDX (W5_REG_BASE + 0x144)
|
||
|
|
#define W5_CMD_ENC_PIC_SRC_ADDR_Y (W5_REG_BASE + 0x148)
|
||
|
|
#define W5_CMD_ENC_PIC_SRC_ADDR_U (W5_REG_BASE + 0x14C)
|
||
|
|
#define W5_CMD_ENC_PIC_SRC_ADDR_V (W5_REG_BASE + 0x150)
|
||
|
|
#define W5_CMD_ENC_PIC_SRC_STRIDE (W5_REG_BASE + 0x154)
|
||
|
|
#define W5_CMD_ENC_PIC_SRC_FORMAT (W5_REG_BASE + 0x158)
|
||
|
|
#define W5_CMD_ENC_PIC_SRC_AXI_SEL (W5_REG_BASE + 0x160)
|
||
|
|
#define W5_CMD_ENC_PIC_CODE_OPTION (W5_REG_BASE + 0x164)
|
||
|
|
#define W5_CMD_ENC_PIC_PIC_PARAM (W5_REG_BASE + 0x168)
|
||
|
|
#define W5_CMD_ENC_PIC_LONGTERM_PIC (W5_REG_BASE + 0x16C)
|
||
|
|
#define W5_CMD_ENC_PIC_WP_PIXEL_SIGMA_Y (W5_REG_BASE + 0x170)
|
||
|
|
#define W5_CMD_ENC_PIC_WP_PIXEL_SIGMA_C (W5_REG_BASE + 0x174)
|
||
|
|
#define W5_CMD_ENC_PIC_WP_PIXEL_MEAN_Y (W5_REG_BASE + 0x178)
|
||
|
|
#define W5_CMD_ENC_PIC_WP_PIXEL_MEAN_C (W5_REG_BASE + 0x17C)
|
||
|
|
#define W5_CMD_ENC_PIC_LF_PARAM_0 (W5_REG_BASE + 0x180)
|
||
|
|
#define W5_CMD_ENC_PIC_LF_PARAM_1 (W5_REG_BASE + 0x184)
|
||
|
|
#define W5_CMD_ENC_PIC_CF50_Y_OFFSET_TABLE_ADDR (W5_REG_BASE + 0x190)
|
||
|
|
#define W5_CMD_ENC_PIC_CF50_CB_OFFSET_TABLE_ADDR (W5_REG_BASE + 0x194)
|
||
|
|
#define W5_CMD_ENC_PIC_CF50_CR_OFFSET_TABLE_ADDR (W5_REG_BASE + 0x198)
|
||
|
|
#define W5_CMD_ENC_PIC_PREFIX_SEI_NAL_ADDR (W5_REG_BASE + 0x180)
|
||
|
|
#define W5_CMD_ENC_PIC_PREFIX_SEI_INFO (W5_REG_BASE + 0x184)
|
||
|
|
#define W5_CMD_ENC_PIC_SUFFIX_SEI_NAL_ADDR (W5_REG_BASE + 0x188)
|
||
|
|
#define W5_CMD_ENC_PIC_SUFFIX_SEI_INFO (W5_REG_BASE + 0x18c)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* ENCODER - QUERY (GET_RESULT) */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_RET_ENC_NUM_REQUIRED_FB (W5_REG_BASE + 0x11C)
|
||
|
|
#define W5_RET_ENC_MIN_SRC_BUF_NUM (W5_REG_BASE + 0x120)
|
||
|
|
#define W5_RET_ENC_PIC_TYPE (W5_REG_BASE + 0x124)
|
||
|
|
#define W5_RET_ENC_PIC_POC (W5_REG_BASE + 0x128)
|
||
|
|
#define W5_RET_ENC_PIC_IDX (W5_REG_BASE + 0x12C)
|
||
|
|
#define W5_RET_ENC_PIC_SLICE_NUM (W5_REG_BASE + 0x130)
|
||
|
|
#define W5_RET_ENC_PIC_SKIP (W5_REG_BASE + 0x134)
|
||
|
|
#define W5_RET_ENC_PIC_NUM_INTRA (W5_REG_BASE + 0x138)
|
||
|
|
#define W5_RET_ENC_PIC_NUM_MERGE (W5_REG_BASE + 0x13C)
|
||
|
|
|
||
|
|
#define W5_RET_ENC_PIC_NUM_SKIP (W5_REG_BASE + 0x144)
|
||
|
|
#define W5_RET_ENC_PIC_AVG_CTU_QP (W5_REG_BASE + 0x148)
|
||
|
|
#define W5_RET_ENC_PIC_BYTE (W5_REG_BASE + 0x14C)
|
||
|
|
#define W5_RET_ENC_GOP_PIC_IDX (W5_REG_BASE + 0x150)
|
||
|
|
#define W5_RET_ENC_USED_SRC_IDX (W5_REG_BASE + 0x154)
|
||
|
|
#define W5_RET_ENC_PIC_NUM (W5_REG_BASE + 0x158)
|
||
|
|
#define W5_RET_ENC_VCL_NUT (W5_REG_BASE + 0x15C)
|
||
|
|
|
||
|
|
#define W5_RET_ENC_PIC_DIST_LOW (W5_REG_BASE + 0x164)
|
||
|
|
#define W5_RET_ENC_PIC_DIST_HIGH (W5_REG_BASE + 0x168)
|
||
|
|
|
||
|
|
#define W5_RET_ENC_PIC_MAX_LATENCY_PICTURES (W5_REG_BASE + 0x16C)
|
||
|
|
#define W5_RET_ENC_SVC_LAYER (W5_REG_BASE + 0x170)
|
||
|
|
|
||
|
|
|
||
|
|
#define W5_RET_ENC_HOST_CMD_TICK (W5_REG_BASE + 0x1B8)
|
||
|
|
#define W5_RET_ENC_PREPARE_START_TICK (W5_REG_BASE + 0x1BC)
|
||
|
|
#define W5_RET_ENC_PREPARE_END_TICK (W5_REG_BASE + 0x1C0)
|
||
|
|
#define W5_RET_ENC_PROCESSING_START_TICK (W5_REG_BASE + 0x1C4)
|
||
|
|
#define W5_RET_ENC_PROCESSING_END_TICK (W5_REG_BASE + 0x1C8)
|
||
|
|
#define W5_RET_ENC_ENCODING_START_TICK (W5_REG_BASE + 0x1CC)
|
||
|
|
#define W5_RET_ENC_ENCODING_END_TICK (W5_REG_BASE + 0x1D0)
|
||
|
|
|
||
|
|
|
||
|
|
#define W5_RET_ENC_WARN_INFO (W5_REG_BASE + 0x1D4)
|
||
|
|
#define W5_RET_ENC_ERR_INFO (W5_REG_BASE + 0x1D8)
|
||
|
|
#define W5_RET_ENC_ENCODING_SUCCESS (W5_REG_BASE + 0x1DC)
|
||
|
|
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* ENCODER - QUERY (GET_BW_REPORT) */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_RET_ENC_RD_PTR (W5_REG_BASE + 0x114)
|
||
|
|
#define W5_RET_ENC_WR_PTR (W5_REG_BASE + 0x118)
|
||
|
|
#define W5_CMD_ENC_REASON_SEL (W5_REG_BASE + 0x11C)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* ENCODER - QUERY (GET_BW_REPORT) */
|
||
|
|
/************************************************************************/
|
||
|
|
#define RET_QUERY_BW_PRP_AXI_READ (W5_REG_BASE + 0x118)
|
||
|
|
#define RET_QUERY_BW_PRP_AXI_WRITE (W5_REG_BASE + 0x11C)
|
||
|
|
#define RET_QUERY_BW_FBD_Y_AXI_READ (W5_REG_BASE + 0x120)
|
||
|
|
#define RET_QUERY_BW_FBC_Y_AXI_WRITE (W5_REG_BASE + 0x124)
|
||
|
|
#define RET_QUERY_BW_FBD_C_AXI_READ (W5_REG_BASE + 0x128)
|
||
|
|
#define RET_QUERY_BW_FBC_C_AXI_WRITE (W5_REG_BASE + 0x12C)
|
||
|
|
#define RET_QUERY_BW_PRI_AXI_READ (W5_REG_BASE + 0x130)
|
||
|
|
#define RET_QUERY_BW_PRI_AXI_WRITE (W5_REG_BASE + 0x134)
|
||
|
|
#define RET_QUERY_BW_SEC_AXI_READ (W5_REG_BASE + 0x138)
|
||
|
|
#define RET_QUERY_BW_SEC_AXI_WRITE (W5_REG_BASE + 0x13C)
|
||
|
|
#define RET_QUERY_BW_PROC_AXI_READ (W5_REG_BASE + 0x140)
|
||
|
|
#define RET_QUERY_BW_PROC_AXI_WRITE (W5_REG_BASE + 0x144)
|
||
|
|
#define RET_QUERY_BW_BWB_AXI_WRITE (W5_REG_BASE + 0x148)
|
||
|
|
#define W5_CMD_BW_OPTION (W5_REG_BASE + 0x14C)
|
||
|
|
|
||
|
|
/************************************************************************/
|
||
|
|
/* ENCODER - QUERY (GET_SRC_FLAG) */
|
||
|
|
/************************************************************************/
|
||
|
|
#define W5_RET_ENC_SRC_BUF_FLAG (W5_REG_BASE + 0x18C)
|
||
|
|
#define W5_RET_RELEASED_SRC_INSTANCE (W5_REG_BASE + 0x1EC)
|
||
|
|
|
||
|
|
|
||
|
|
#define W5_ENC_PIC_SUB_FRAME_SYNC_IF (W5_REG_BASE + 0x0300)
|
||
|
|
|
||
|
|
#endif /* __WAVE5_REGISTER_DEFINE_H__ */
|
||
|
|
|
||
|
|
|
||
|
|
#ifndef REGDEFINE_H_INCLUDED
|
||
|
|
#define REGDEFINE_H_INCLUDED
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// REGISTER BASE
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define BIT_BASE 0x0000
|
||
|
|
#define GDMA_BASE 0x1000
|
||
|
|
#define MBC_BASE 0x0400
|
||
|
|
#define ME_BASE 0x0600
|
||
|
|
#define MC_BASE 0x0C00
|
||
|
|
#define DMAC_BASE 0x2000
|
||
|
|
|
||
|
|
#define BW_BASE 0x03000000
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// HARDWARE REGISTER
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// SW Reset command
|
||
|
|
#define VPU_SW_RESET_BPU_CORE 0x008
|
||
|
|
#define VPU_SW_RESET_BPU_BUS 0x010
|
||
|
|
#define VPU_SW_RESET_VCE_CORE 0x020
|
||
|
|
#define VPU_SW_RESET_VCE_BUS 0x040
|
||
|
|
#define VPU_SW_RESET_GDI_CORE 0x080
|
||
|
|
#define VPU_SW_RESET_GDI_BUS 0x100
|
||
|
|
|
||
|
|
#define BIT_CODE_RUN (BIT_BASE + 0x000)
|
||
|
|
#define BIT_CODE_DOWN (BIT_BASE + 0x004)
|
||
|
|
#define BIT_INT_REQ (BIT_BASE + 0x008)
|
||
|
|
#define BIT_INT_CLEAR (BIT_BASE + 0x00C)
|
||
|
|
#define BIT_INT_STS (BIT_BASE + 0x010)
|
||
|
|
#define BIT_CODE_RESET (BIT_BASE + 0x014)
|
||
|
|
#define BIT_CUR_PC (BIT_BASE + 0x018)
|
||
|
|
#define BIT_SW_RESET (BIT_BASE + 0x024)
|
||
|
|
#define BIT_SW_RESET_STATUS (BIT_BASE + 0x034)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// GLOBAL REGISTER
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define BIT_CODE_BUF_ADDR (BIT_BASE + 0x100)
|
||
|
|
#define BIT_WORK_BUF_ADDR (BIT_BASE + 0x104)
|
||
|
|
#define BIT_PARA_BUF_ADDR (BIT_BASE + 0x108)
|
||
|
|
#define BIT_BIT_STREAM_CTRL (BIT_BASE + 0x10C)
|
||
|
|
#define BIT_FRAME_MEM_CTRL (BIT_BASE + 0x110)
|
||
|
|
#define BIT_BIT_STREAM_PARAM (BIT_BASE + 0x114)
|
||
|
|
#define BIT_TEMP_BUF_ADDR (BIT_BASE + 0x118)
|
||
|
|
|
||
|
|
#define BIT_RD_PTR (BIT_BASE + 0x120)
|
||
|
|
#define BIT_WR_PTR (BIT_BASE + 0x124)
|
||
|
|
|
||
|
|
#define BIT_ROLLBACK_STATUS (BIT_BASE + 0x128) // internal used in f/w.
|
||
|
|
|
||
|
|
#define BIT_AXI_SRAM_USE (BIT_BASE + 0x140)
|
||
|
|
#define BIT_BYTE_POS_FRAME_START (BIT_BASE + 0x144)
|
||
|
|
#define BIT_BYTE_POS_FRAME_END (BIT_BASE + 0x148)
|
||
|
|
#define BIT_FRAME_CYCLE (BIT_BASE + 0x14C)
|
||
|
|
|
||
|
|
#define BIT_FRM_DIS_FLG (BIT_BASE + 0x150)
|
||
|
|
|
||
|
|
#define BIT_BUSY_FLAG (BIT_BASE + 0x160)
|
||
|
|
#define BIT_RUN_COMMAND (BIT_BASE + 0x164)
|
||
|
|
#define BIT_RUN_INDEX (BIT_BASE + 0x168)
|
||
|
|
#define BIT_RUN_COD_STD (BIT_BASE + 0x16C)
|
||
|
|
#define BIT_INT_ENABLE (BIT_BASE + 0x170)
|
||
|
|
#define BIT_INT_REASON (BIT_BASE + 0x174)
|
||
|
|
#define BIT_RUN_AUX_STD (BIT_BASE + 0x178)
|
||
|
|
|
||
|
|
// MSG REGISTER ADDRESS changed
|
||
|
|
#define BIT_MSG_0 (BIT_BASE + 0x130)
|
||
|
|
#define BIT_MSG_1 (BIT_BASE + 0x134)
|
||
|
|
#define BIT_MSG_2 (BIT_BASE + 0x138)
|
||
|
|
#define BIT_MSG_3 (BIT_BASE + 0x13C)
|
||
|
|
|
||
|
|
#define MBC_BUSY (MBC_BASE + 0x040)
|
||
|
|
#define MC_BUSY (MC_BASE + 0x004)
|
||
|
|
|
||
|
|
|
||
|
|
#define P_MBC_SUB_FRAME_SYNC_IF (MBC_BASE + 0x1f8) // CODA980
|
||
|
|
#define P_MBC_ENC_SUB_FRAME_SYNC (MBC_BASE + 0x1fc) // CODA980
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [ENC SEQ INIT] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define CMD_ENC_SEQ_BB_START (BIT_BASE + 0x180)
|
||
|
|
#define CMD_ENC_SEQ_BB_SIZE (BIT_BASE + 0x184)
|
||
|
|
#define CMD_ENC_SEQ_OPTION (BIT_BASE + 0x188) // HecEnable,ConstIntraQp, FMO, QPREP, AUD, SLICE, MB BIT
|
||
|
|
#define CMD_ENC_SEQ_COD_STD (BIT_BASE + 0x18C)
|
||
|
|
#define CMD_ENC_SEQ_SRC_SIZE (BIT_BASE + 0x190)
|
||
|
|
#define CMD_ENC_SEQ_SRC_F_RATE (BIT_BASE + 0x194)
|
||
|
|
#define CMD_ENC_SEQ_MP4_PARA (BIT_BASE + 0x198)
|
||
|
|
#define CMD_ENC_SEQ_263_PARA (BIT_BASE + 0x19C)
|
||
|
|
#define CMD_ENC_SEQ_264_PARA (BIT_BASE + 0x1A0)
|
||
|
|
#define CMD_ENC_SEQ_SLICE_MODE (BIT_BASE + 0x1A4)
|
||
|
|
#define CMD_ENC_SEQ_GOP_NUM (BIT_BASE + 0x1A8)
|
||
|
|
#define CMD_ENC_SEQ_RC_PARA (BIT_BASE + 0x1AC)
|
||
|
|
#define CMD_ENC_SEQ_RC_BUF_SIZE (BIT_BASE + 0x1B0)
|
||
|
|
#define CMD_ENC_SEQ_INTRA_REFRESH (BIT_BASE + 0x1B4)
|
||
|
|
#define CMD_ENC_SEQ_INTRA_QP (BIT_BASE + 0x1C4)
|
||
|
|
#define CMD_ENC_SEQ_RC_QP_MAX (BIT_BASE + 0x1C8)
|
||
|
|
#define CMD_ENC_SEQ_RC_GAMMA (BIT_BASE + 0x1CC)
|
||
|
|
#define CMD_ENC_SEQ_RC_INTERVAL_MODE (BIT_BASE + 0x1D0) // mbInterval[32:2], rcIntervalMode[1:0]
|
||
|
|
#define CMD_ENC_SEQ_INTRA_WEIGHT (BIT_BASE + 0x1D4)
|
||
|
|
#define CMD_ENC_SEQ_ME_OPTION (BIT_BASE + 0x1D8)
|
||
|
|
#define CMD_ENC_SEQ_RC_PARA2 (BIT_BASE + 0x1DC)
|
||
|
|
#define CMD_ENC_SEQ_QP_RANGE_SET (BIT_BASE + 0x1E0)
|
||
|
|
#define CMD_ENC_SEQ_RC_MAX_INTRA_SIZE (BIT_BASE + 0x1F0)
|
||
|
|
|
||
|
|
|
||
|
|
#define CMD_ENC_SEQ_FIRST_MBA (BIT_BASE + 0x1E4)
|
||
|
|
#define CMD_ENC_SEQ_HEIGHT_IN_MAP_UNITS (BIT_BASE + 0x1E8)
|
||
|
|
#define CMD_ENC_SEQ_OVERLAP_CLIP_SIZE (BIT_BASE + 0x1EC)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [ENC SEQ END] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define RET_ENC_SEQ_END_SUCCESS (BIT_BASE + 0x1C0)
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [ENC PIC RUN] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
|
||
|
|
#define CMD_ENC_PIC_SRC_INDEX (BIT_BASE + 0x180)
|
||
|
|
#define CMD_ENC_PIC_SRC_STRIDE (BIT_BASE + 0x184)
|
||
|
|
#define CMD_ENC_PIC_SRC_ADDR_Y (BIT_BASE + 0x1A8)
|
||
|
|
#define CMD_ENC_PIC_SRC_ADDR_CB (BIT_BASE + 0x1AC)
|
||
|
|
#define CMD_ENC_PIC_SRC_ADDR_CR (BIT_BASE + 0x1B0)
|
||
|
|
#define CMD_ENC_PIC_SRC_BOTTOM_Y (BIT_BASE + 0x1E8) //coda980 only
|
||
|
|
#define CMD_ENC_PIC_SRC_BOTTOM_CB (BIT_BASE + 0x1EC) //coda980 only
|
||
|
|
#define CMD_ENC_PIC_SRC_BOTTOM_CR (BIT_BASE + 0x1F0) //coda980 only
|
||
|
|
|
||
|
|
#define CMD_ENC_PIC_QS (BIT_BASE + 0x18C)
|
||
|
|
#define CMD_ENC_PIC_ROT_MODE (BIT_BASE + 0x190)
|
||
|
|
#define CMD_ENC_PIC_OPTION (BIT_BASE + 0x194)
|
||
|
|
#define CMD_ENC_PIC_BB_START (BIT_BASE + 0x198)
|
||
|
|
#define CMD_ENC_PIC_BB_SIZE (BIT_BASE + 0x19C)
|
||
|
|
#define CMD_ENC_PIC_PARA_BASE_ADDR (BIT_BASE + 0x1A0)
|
||
|
|
#define CMD_ENC_PIC_SUB_FRAME_SYNC (BIT_BASE + 0x1A4)
|
||
|
|
|
||
|
|
|
||
|
|
#define RET_ENC_PIC_FRAME_NUM (BIT_BASE + 0x1C0)
|
||
|
|
#define RET_ENC_PIC_TYPE (BIT_BASE + 0x1C4)
|
||
|
|
#define RET_ENC_PIC_FRAME_IDX (BIT_BASE + 0x1C8)
|
||
|
|
#define RET_ENC_PIC_SLICE_NUM (BIT_BASE + 0x1CC)
|
||
|
|
#define RET_ENC_PIC_FLAG (BIT_BASE + 0x1D0)
|
||
|
|
#define RET_ENC_PIC_SUCCESS (BIT_BASE + 0x1D8)
|
||
|
|
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [ENC ROI INIT] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define CMD_ENC_ROI_INFO (BIT_BASE + 0x180) // [7:1]: RoiPicAvgQp, [0]: RoiEn
|
||
|
|
#define CMD_ENC_ROI_QP_MAP_ADDR (BIT_BASE + 0x184) // [31:0] ROI Qp map address
|
||
|
|
|
||
|
|
|
||
|
|
#define RET_ENC_ROI_SUCCESS (BIT_BASE + 0x1D8)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [ENC SET FRAME BUF] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define CMD_SET_FRAME_SUBSAMP_A (BIT_BASE + 0x188) //coda960 only
|
||
|
|
#define CMD_SET_FRAME_SUBSAMP_B (BIT_BASE + 0x18C) //coda960 only
|
||
|
|
#define CMD_SET_FRAME_SUBSAMP_A_MVC (BIT_BASE + 0x1B0) //coda960 only
|
||
|
|
#define CMD_SET_FRAME_SUBSAMP_B_MVC (BIT_BASE + 0x1B4) //coda960 only
|
||
|
|
|
||
|
|
#define CMD_SET_FRAME_DP_BUF_BASE (BIT_BASE + 0x1B0)
|
||
|
|
#define CMD_SET_FRAME_DP_BUF_SIZE (BIT_BASE + 0x1B4)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [ENC HEADER] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define CMD_ENC_HEADER_CODE (BIT_BASE + 0x180)
|
||
|
|
#define CMD_ENC_HEADER_BB_START (BIT_BASE + 0x184)
|
||
|
|
#define CMD_ENC_HEADER_BB_SIZE (BIT_BASE + 0x188)
|
||
|
|
#define CMD_ENC_HEADER_FRAME_CROP_H (BIT_BASE + 0x18C)
|
||
|
|
#define CMD_ENC_HEADER_FRAME_CROP_V (BIT_BASE + 0x190)
|
||
|
|
#define CMD_ENC_HEADER_CABAC_MODE (BIT_BASE + 0x194) // CODA980
|
||
|
|
#define CMD_ENC_HEADER_CABAC_INIT_IDC (BIT_BASE + 0x198) // CODA980
|
||
|
|
#define CMD_ENC_HEADER_TRANSFORM_8X8 (BIT_BASE + 0x19C) // CODA980
|
||
|
|
#define CMD_ENC_HEADER_CHROMA_FORMAT (BIT_BASE + 0x1A0) // CODA980
|
||
|
|
#define CMD_ENC_HEADER_FIELD_FLAG (BIT_BASE + 0x1A4)
|
||
|
|
#define CMD_ENC_HEADER_PROFILE (BIT_BASE + 0x1A8) // CODA980
|
||
|
|
|
||
|
|
#define RET_ENC_HEADER_SUCCESS (BIT_BASE + 0x1C0)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [ENC_PARA_SET] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define CMD_ENC_PARA_SET_TYPE (BIT_BASE + 0x180)
|
||
|
|
#define RET_ENC_PARA_SET_SIZE (BIT_BASE + 0x1c0)
|
||
|
|
#define RET_ENC_PARA_SET_SUCCESS (BIT_BASE + 0x1C4)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [ENC PARA CHANGE] COMMAND :
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_ENABLE (BIT_BASE + 0x180) // FrameRateEn[3], BitRateEn[2], IntraQpEn[1], GopEn[0]
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_GOP_NUM (BIT_BASE + 0x184)
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_INTRA_QP (BIT_BASE + 0x188)
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_BITRATE (BIT_BASE + 0x18C)
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_F_RATE (BIT_BASE + 0x190)
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_INTRA_REFRESH (BIT_BASE + 0x194) // update param
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_SLICE_MODE (BIT_BASE + 0x198) // update param
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_HEC_MODE (BIT_BASE + 0x19C) // update param
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_CABAC_MODE (BIT_BASE + 0x1A0) // entropyCodingMode==2
|
||
|
|
#define CMD_ENC_PARAM_CHANGE_PPS_ID (BIT_BASE + 0x1B4) // entropyCodingMode==2
|
||
|
|
#define RET_ENC_SEQ_PARA_CHANGE_SUCCESS (BIT_BASE + 0x1C0)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [DEC SEQ INIT] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define CMD_DEC_SEQ_BB_START (BIT_BASE + 0x180)
|
||
|
|
#define CMD_DEC_SEQ_BB_SIZE (BIT_BASE + 0x184)
|
||
|
|
#define CMD_DEC_SEQ_OPTION (BIT_BASE + 0x188)
|
||
|
|
|
||
|
|
#define CMD_DEC_SEQ_MP4_ASP_CLASS (BIT_BASE + 0x19C)
|
||
|
|
#define CMD_DEC_SEQ_VC1_STREAM_FMT (BIT_BASE + 0x19C)
|
||
|
|
#define CMD_DEC_SEQ_X264_MV_EN (BIT_BASE + 0x19C)
|
||
|
|
#define CMD_DEC_SEQ_SPP_CHUNK_SIZE (BIT_BASE + 0x1A0)
|
||
|
|
|
||
|
|
// For MPEG2 only
|
||
|
|
#define CMD_DEC_SEQ_USER_DATA_OPTION (BIT_BASE + 0x194)
|
||
|
|
#define CMD_DEC_SEQ_USER_DATA_BASE_ADDR (BIT_BASE + 0x1AC)
|
||
|
|
#define CMD_DEC_SEQ_USER_DATA_BUF_SIZE (BIT_BASE + 0x1B0)
|
||
|
|
|
||
|
|
#define CMD_DEC_SEQ_INIT_ESCAPE (BIT_BASE + 0x114)
|
||
|
|
|
||
|
|
#define RET_DEC_SEQ_BIT_RATE (BIT_BASE + 0x1B4)
|
||
|
|
#define RET_DEC_SEQ_EXT_INFO (BIT_BASE + 0x1B8)
|
||
|
|
#define RET_DEC_SEQ_SUCCESS (BIT_BASE + 0x1C0)
|
||
|
|
#define RET_DEC_SEQ_SRC_SIZE (BIT_BASE + 0x1C4)
|
||
|
|
|
||
|
|
#define RET_DEC_SEQ_ASPECT (BIT_BASE + 0x1C8)
|
||
|
|
#define RET_DEC_SEQ_FRAME_NEED (BIT_BASE + 0x1CC)
|
||
|
|
#define RET_DEC_SEQ_FRAME_DELAY (BIT_BASE + 0x1D0)
|
||
|
|
#define RET_DEC_SEQ_INFO (BIT_BASE + 0x1D4)
|
||
|
|
#define RET_DEC_SEQ_VP8_SCALE_INFO (BIT_BASE + 0x1D4)
|
||
|
|
|
||
|
|
#define RET_DEC_SEQ_CROP_LEFT_RIGHT (BIT_BASE + 0x1D8)
|
||
|
|
#define RET_DEC_SEQ_CROP_TOP_BOTTOM (BIT_BASE + 0x1DC)
|
||
|
|
#define RET_DEC_SEQ_SEQ_ERR_REASON (BIT_BASE + 0x1E0)
|
||
|
|
|
||
|
|
|
||
|
|
#define RET_DEC_SEQ_FRATE_NR (BIT_BASE + 0x1E4)
|
||
|
|
#define RET_DEC_SEQ_FRATE_DR (BIT_BASE + 0x1E8)
|
||
|
|
#define RET_DEC_SEQ_HEADER_REPORT (BIT_BASE + 0x1EC)
|
||
|
|
#define RET_DEC_SEQ_VUI_INFO (BIT_BASE + 0x18C)
|
||
|
|
#define RET_DEC_SEQ_VUI_PIC_STRUCT (BIT_BASE + 0x1A8)
|
||
|
|
|
||
|
|
#define RET_DEC_SEQ_MP2_BAR_LEFT_RIGHT (BIT_BASE + 0x180)
|
||
|
|
#define RET_DEC_SEQ_MP2_BAR_TOP_BOTTOM (BIT_BASE + 0x184)
|
||
|
|
|
||
|
|
#define RET_DEC_PIC_MP2_OFFSET1 (BIT_BASE + 0x19C) // for MP2
|
||
|
|
#define RET_DEC_PIC_MP2_OFFSET2 (BIT_BASE + 0x1A0) // for MP2
|
||
|
|
#define RET_DEC_PIC_MP2_OFFSET3 (BIT_BASE + 0x1A4) // for MP2
|
||
|
|
#define RET_DEC_PIC_MP2_OFFSET_NUM (BIT_BASE + 0x1A8) // for MP2
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [DEC SEQ END] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define RET_DEC_SEQ_END_SUCCESS (BIT_BASE + 0x1C0)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [DEC PIC RUN] COMMAND
|
||
|
|
//----------------------------------------------------
|
||
|
|
#define CMD_DEC_PIC_ROT_MODE (BIT_BASE + 0x180)
|
||
|
|
#define CMD_DEC_PIC_ROT_INDEX (BIT_BASE + 0x184)
|
||
|
|
#define CMD_DEC_PIC_ROT_ADDR_Y (BIT_BASE + 0x188)
|
||
|
|
#define CMD_DEC_PIC_ROT_ADDR_CB (BIT_BASE + 0x18C)
|
||
|
|
#define CMD_DEC_PIC_ROT_ADDR_CR (BIT_BASE + 0x190)
|
||
|
|
#define CMD_DEC_PIC_ROT_STRIDE (BIT_BASE + 0x1B8)
|
||
|
|
#define CMD_DEC_PIC_ROT_BOTTOM_Y (BIT_BASE + 0x1E8) // coda980 only
|
||
|
|
#define CMD_DEC_PIC_ROT_BOTTOM_CB (BIT_BASE + 0x1EC) // coda980 only
|
||
|
|
#define CMD_DEC_PIC_ROT_BOTTOM_CR (BIT_BASE + 0x1F0) // coda980 only
|
||
|
|
|
||
|
|
#define CMD_DEC_PIC_OPTION (BIT_BASE + 0x194)
|
||
|
|
|
||
|
|
#define CMD_DEC_PIC_USER_DATA_BASE_ADDR (BIT_BASE + 0x1AC)
|
||
|
|
#define CMD_DEC_PIC_USER_DATA_BUF_SIZE (BIT_BASE + 0x1B0)
|
||
|
|
|
||
|
|
#define CMD_DEC_PIC_NUM_ROWS (BIT_BASE + 0x1B4)
|
||
|
|
#define CMD_DEC_PIC_THO_PIC_PARA (BIT_BASE + 0x198)
|
||
|
|
#define CMD_DEC_PIC_THO_QMAT_ADDR (BIT_BASE + 0x1A0)
|
||
|
|
#define CMD_DEC_PIC_THO_MB_PARA_ADDR (BIT_BASE + 0x1A4)
|
||
|
|
#define RET_DEC_PIC_VUI_PIC_STRUCT (BIT_BASE + 0x1A8)
|
||
|
|
#define RET_DEC_PIC_AVC_FPA_SEI0 (BIT_BASE + 0x19C)
|
||
|
|
#define RET_DEC_PIC_AVC_FPA_SEI1 (BIT_BASE + 0x1A0)
|
||
|
|
#define RET_DEC_PIC_AVC_FPA_SEI2 (BIT_BASE + 0x1A4)
|
||
|
|
#define RET_DEC_NUM_MB_ROWS (BIT_BASE + 0x1B4) // it will be update
|
||
|
|
#define RET_DEC_PIC_AVC_SEI_RP_INFO (BIT_BASE + 0x1B4)
|
||
|
|
#define RET_DEC_PIC_HRD_INFO (BIT_BASE + 0x1B8)
|
||
|
|
#define RET_DEC_PIC_SIZE (BIT_BASE + 0x1BC)
|
||
|
|
#define RET_DEC_PIC_FRAME_NUM (BIT_BASE + 0x1C0)
|
||
|
|
#define RET_DEC_PIC_FRAME_IDX (BIT_BASE + 0x1C4)
|
||
|
|
#define RET_DEC_PIC_DISPLAY_IDX (BIT_BASE + 0x1C4)
|
||
|
|
#define RET_DEC_PIC_ERR_MB (BIT_BASE + 0x1C8)
|
||
|
|
#define RET_DEC_PIC_TYPE (BIT_BASE + 0x1CC)
|
||
|
|
#define RET_DEC_PIC_POST (BIT_BASE + 0x1D0) // for VC1
|
||
|
|
#define RET_DEC_PIC_MVC_REPORT (BIT_BASE + 0x1D0) // for MVC
|
||
|
|
#define RET_DEC_PIC_OPTION (BIT_BASE + 0x1D4)
|
||
|
|
#define RET_DEC_PIC_SUCCESS (BIT_BASE + 0x1D8)
|
||
|
|
#define RET_DEC_PIC_CUR_IDX (BIT_BASE + 0x1DC)
|
||
|
|
#define RET_DEC_PIC_DECODED_IDX (BIT_BASE + 0x1DC)
|
||
|
|
#define RET_DEC_PIC_CROP_LEFT_RIGHT (BIT_BASE + 0x1E0) // for AVC, MPEG-2
|
||
|
|
#define RET_DEC_PIC_CROP_TOP_BOTTOM (BIT_BASE + 0x1E4) // for AVC, MPEG-2
|
||
|
|
#define RET_DEC_PIC_MODULO_TIME_BASE (BIT_BASE + 0x1E0) // for MP4
|
||
|
|
#define RET_DEC_PIC_VOP_TIME_INCREMENT (BIT_BASE + 0x1E4) // for MP4
|
||
|
|
#define RET_DEC_PIC_RV_TR (BIT_BASE + 0x1E8)
|
||
|
|
#define RET_DEC_PIC_VP8_PIC_REPORT (BIT_BASE + 0x1E8)
|
||
|
|
#define RET_DEC_PIC_ATSC_USER_DATA_INFO (BIT_BASE + 0x1E8) // H.264, MEPEG2
|
||
|
|
#define RET_DEC_PIC_VUI_INFO (BIT_BASE + 0x1EC)
|
||
|
|
#define RET_DEC_PIC_RV_TR_BFRAME (BIT_BASE + 0x1EC)
|
||
|
|
#define RET_DEC_PIC_ASPECT (BIT_BASE + 0x1F0)
|
||
|
|
#define RET_DEC_PIC_VP8_SCALE_INFO (BIT_BASE + 0x1F0)
|
||
|
|
#define RET_DEC_PIC_FRATE_NR (BIT_BASE + 0x1F4)
|
||
|
|
#define RET_DEC_PIC_FRATE_DR (BIT_BASE + 0x1F8)
|
||
|
|
#define RET_DEC_PIC_POC_TOP (BIT_BASE + 0x1AC)
|
||
|
|
#define RET_DEC_PIC_POC_BOT (BIT_BASE + 0x1B0)
|
||
|
|
#define RET_DEC_PIC_POC (BIT_BASE + 0x1B0)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [DEC SET FRAME BUF] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define CMD_SET_FRAME_BUF_NUM (BIT_BASE + 0x180)
|
||
|
|
#define CMD_SET_FRAME_BUF_STRIDE (BIT_BASE + 0x184)
|
||
|
|
|
||
|
|
#define CMD_SET_FRAME_SLICE_BB_START (BIT_BASE + 0x188)
|
||
|
|
#define CMD_SET_FRAME_SLICE_BB_SIZE (BIT_BASE + 0x18C)
|
||
|
|
#define CMD_SET_FRAME_AXI_BIT_ADDR (BIT_BASE + 0x190)
|
||
|
|
#define CMD_SET_FRAME_AXI_IPACDC_ADDR (BIT_BASE + 0x194)
|
||
|
|
#define CMD_SET_FRAME_AXI_DBKY_ADDR (BIT_BASE + 0x198)
|
||
|
|
#define CMD_SET_FRAME_AXI_DBKC_ADDR (BIT_BASE + 0x19C)
|
||
|
|
#define CMD_SET_FRAME_AXI_OVL_ADDR (BIT_BASE + 0x1A0)
|
||
|
|
#define CMD_SET_FRAME_AXI_BTP_ADDR (BIT_BASE + 0x1A4)
|
||
|
|
|
||
|
|
#define CMD_SET_FRAME_CACHE_SIZE (BIT_BASE + 0x1A8)
|
||
|
|
#define CMD_SET_FRAME_CACHE_CONFIG (BIT_BASE + 0x1AC)
|
||
|
|
#define CMD_SET_FRAME_MB_BUF_BASE (BIT_BASE + 0x1B0)
|
||
|
|
#define CMD_SET_FRAME_MAX_DEC_SIZE (BIT_BASE + 0x1B8)
|
||
|
|
#define CMD_SET_FRAME_DELAY (BIT_BASE + 0x1BC)
|
||
|
|
|
||
|
|
#define RET_SET_FRAME_SUCCESS (BIT_BASE + 0x1C0)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [DEC_PARA_SET] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define CMD_DEC_PARA_SET_TYPE (BIT_BASE + 0x180)
|
||
|
|
#define CMD_DEC_PARA_SET_SIZE (BIT_BASE + 0x184)
|
||
|
|
#define RET_DEC_PARA_SET_SUCCESS (BIT_BASE + 0x1C0)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [DEC_BUF_FLUSH] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define RET_DEC_BUF_FLUSH_SUCCESS (BIT_BASE + 0x1C0)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [SLEEP/WAKE] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define RET_SLEEP_WAKE_SUCCESS (BIT_BASE + 0x1C0)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [SET PIC INFO] COMMAND
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define GDI_PRI_RD_PRIO_L (GDMA_BASE + 0x000)
|
||
|
|
#define GDI_PRI_RD_PRIO_H (GDMA_BASE + 0x004)
|
||
|
|
#define GDI_PRI_WR_PRIO_L (GDMA_BASE + 0x008)
|
||
|
|
#define GDI_PRI_WR_PRIO_H (GDMA_BASE + 0x00c)
|
||
|
|
#define GDI_PRI_RD_LOCK_CNT (GDMA_BASE + 0x010)
|
||
|
|
#define GDI_PRI_WR_LOCK_CNT (GDMA_BASE + 0x014)
|
||
|
|
#define GDI_SEC_RD_PRIO_L (GDMA_BASE + 0x018)
|
||
|
|
#define GDI_SEC_RD_PRIO_H (GDMA_BASE + 0x01c)
|
||
|
|
#define GDI_SEC_WR_PRIO_L (GDMA_BASE + 0x020)
|
||
|
|
#define GDI_SEC_WR_PRIO_H (GDMA_BASE + 0x024)
|
||
|
|
#define GDI_SEC_RD_LOCK_CNT (GDMA_BASE + 0x028)
|
||
|
|
#define GDI_SEC_WR_LOCK_CNT (GDMA_BASE + 0x02c)
|
||
|
|
#define GDI_SEC_CLIENT_EN (GDMA_BASE + 0x030)
|
||
|
|
#define GDI_CONTROL (GDMA_BASE + 0x034)
|
||
|
|
#define GDI_PIC_INIT_HOST (GDMA_BASE + 0x038)
|
||
|
|
|
||
|
|
#define GDI_HW_VERINFO (GDMA_BASE + 0x050)
|
||
|
|
#define GDI_PINFO_REQ (GDMA_BASE + 0x060)
|
||
|
|
#define GDI_PINFO_ACK (GDMA_BASE + 0x064)
|
||
|
|
#define GDI_PINFO_ADDR (GDMA_BASE + 0x068)
|
||
|
|
#define GDI_PINFO_DATA (GDMA_BASE + 0x06c)
|
||
|
|
#define GDI_BWB_ENABLE (GDMA_BASE + 0x070)
|
||
|
|
#define GDI_BWB_SIZE (GDMA_BASE + 0x074)
|
||
|
|
#define GDI_BWB_STD_STRUCT (GDMA_BASE + 0x078)
|
||
|
|
#define GDI_BWB_STATUS (GDMA_BASE + 0x07c)
|
||
|
|
|
||
|
|
#define GDI_STATUS (GDMA_BASE + 0x080)
|
||
|
|
|
||
|
|
#define GDI_DEBUG_0 (GDMA_BASE + 0x084)
|
||
|
|
#define GDI_DEBUG_1 (GDMA_BASE + 0x088)
|
||
|
|
#define GDI_DEBUG_2 (GDMA_BASE + 0x08c)
|
||
|
|
#define GDI_DEBUG_3 (GDMA_BASE + 0x090)
|
||
|
|
#define GDI_DEBUG_PROBE_ADDR (GDMA_BASE + 0x094)
|
||
|
|
#define GDI_DEBUG_PROBE_DATA (GDMA_BASE + 0x098)
|
||
|
|
|
||
|
|
// write protect
|
||
|
|
#define GDI_WPROT_ERR_CLR (GDMA_BASE + 0x0A0)
|
||
|
|
#define GDI_WPROT_ERR_RSN (GDMA_BASE + 0x0A4)
|
||
|
|
#define GDI_WPROT_ERR_ADR (GDMA_BASE + 0x0A8)
|
||
|
|
#define GDI_WPROT_RGN_EN (GDMA_BASE + 0x0AC)
|
||
|
|
#define GDI_WPROT_RGN0_STA (GDMA_BASE + 0x0B0)
|
||
|
|
#define GDI_WPROT_RGN0_END (GDMA_BASE + 0x0B4)
|
||
|
|
#define GDI_WPROT_RGN1_STA (GDMA_BASE + 0x0B8)
|
||
|
|
#define GDI_WPROT_RGN1_END (GDMA_BASE + 0x0BC)
|
||
|
|
#define GDI_WPROT_RGN2_STA (GDMA_BASE + 0x0C0)
|
||
|
|
#define GDI_WPROT_RGN2_END (GDMA_BASE + 0x0C4)
|
||
|
|
#define GDI_WPROT_RGN3_STA (GDMA_BASE + 0x0C8)
|
||
|
|
#define GDI_WPROT_RGN3_END (GDMA_BASE + 0x0CC)
|
||
|
|
#define GDI_WPROT_RGN4_STA (GDMA_BASE + 0x0D0)
|
||
|
|
#define GDI_WPROT_RGN4_END (GDMA_BASE + 0x0D4)
|
||
|
|
#define GDI_WPROT_RGN5_STA (GDMA_BASE + 0x0D8)
|
||
|
|
#define GDI_WPROT_RGN5_END (GDMA_BASE + 0x0DC)
|
||
|
|
#define GDI_WPROT_REGIONS 6
|
||
|
|
|
||
|
|
#define GDI_BUS_CTRL (GDMA_BASE + 0x0F0)
|
||
|
|
#define GDI_BUS_STATUS (GDMA_BASE + 0x0F4)
|
||
|
|
|
||
|
|
#define GDI_SIZE_ERR_FLAG (GDMA_BASE + 0x0e0)
|
||
|
|
#define GDI_ADR_RQ_SIZE_ERR_PRI0 (GDMA_BASE + 0x100)
|
||
|
|
#define GDI_ADR_RQ_SIZE_ERR_PRI1 (GDMA_BASE + 0x104)
|
||
|
|
#define GDI_ADR_RQ_SIZE_ERR_PRI1 (GDMA_BASE + 0x104)
|
||
|
|
#define GDI_ADR_RQ_SIZE_ERR_PRI2 (GDMA_BASE + 0x108)
|
||
|
|
#define GDI_ADR_WQ_SIZE_ERR_PRI0 (GDMA_BASE + 0x10c)
|
||
|
|
#define GDI_ADR_WQ_SIZE_ERR_PRI1 (GDMA_BASE + 0x110)
|
||
|
|
#define GDI_ADR_WQ_SIZE_ERR_PRI2 (GDMA_BASE + 0x114)
|
||
|
|
|
||
|
|
#define GDI_ADR_RQ_SIZE_ERR_SEC0 (GDMA_BASE + 0x118)
|
||
|
|
#define GDI_ADR_RQ_SIZE_ERR_SEC1 (GDMA_BASE + 0x11c)
|
||
|
|
#define GDI_ADR_RQ_SIZE_ERR_SEC2 (GDMA_BASE + 0x120)
|
||
|
|
|
||
|
|
#define GDI_ADR_WQ_SIZE_ERR_SEC0 (GDMA_BASE + 0x124)
|
||
|
|
#define GDI_ADR_WQ_SIZE_ERR_SEC1 (GDMA_BASE + 0x128)
|
||
|
|
#define GDI_ADR_WQ_SIZE_ERR_SEC2 (GDMA_BASE + 0x12c)
|
||
|
|
|
||
|
|
#define GDI_INFO_CONTROL (GDMA_BASE + 0x400)
|
||
|
|
#define GDI_INFO_PIC_SIZE (GDMA_BASE + 0x404)
|
||
|
|
// GDI 2.0 register
|
||
|
|
#define GDI_INFO_BASE_Y_TOP (GDMA_BASE + 0x408)
|
||
|
|
#define GDI_INFO_BASE_CB_TOP (GDMA_BASE + 0x40C)
|
||
|
|
#define GDI_INFO_BASE_CR_TOP (GDMA_BASE + 0x410)
|
||
|
|
#define GDI_INFO_BASE_Y_BOT (GDMA_BASE + 0x414)
|
||
|
|
#define GDI_INFO_BASE_CB_BOT (GDMA_BASE + 0x418)
|
||
|
|
#define GDI_INFO_BASE_CR_BOT (GDMA_BASE + 0x41C)
|
||
|
|
#define GDI_XY2AXI_LUM_BIT00 (GDMA_BASE + 0x800)
|
||
|
|
#define GDI_XY2AXI_LUM_BIT1F (GDMA_BASE + 0x87C)
|
||
|
|
#define GDI_XY2AXI_CHR_BIT00 (GDMA_BASE + 0x880)
|
||
|
|
#define GDI_XY2AXI_CHR_BIT1F (GDMA_BASE + 0x8FC)
|
||
|
|
#define GDI_XY2AXI_CONFIG (GDMA_BASE + 0x900)
|
||
|
|
|
||
|
|
//GDI 1.0 register
|
||
|
|
#define GDI_INFO_BASE_Y (GDMA_BASE + 0x408)
|
||
|
|
#define GDI_INFO_BASE_CB (GDMA_BASE + 0x40C)
|
||
|
|
#define GDI_INFO_BASE_CR (GDMA_BASE + 0x410)
|
||
|
|
|
||
|
|
#define GDI_XY2_CAS_0 (GDMA_BASE + 0x800)
|
||
|
|
#define GDI_XY2_CAS_F (GDMA_BASE + 0x83C)
|
||
|
|
|
||
|
|
#define GDI_XY2_BA_0 (GDMA_BASE + 0x840)
|
||
|
|
#define GDI_XY2_BA_1 (GDMA_BASE + 0x844)
|
||
|
|
#define GDI_XY2_BA_2 (GDMA_BASE + 0x848)
|
||
|
|
#define GDI_XY2_BA_3 (GDMA_BASE + 0x84C)
|
||
|
|
|
||
|
|
#define GDI_XY2_RAS_0 (GDMA_BASE + 0x850)
|
||
|
|
#define GDI_XY2_RAS_F (GDMA_BASE + 0x88C)
|
||
|
|
|
||
|
|
#define GDI_XY2_RBC_CONFIG (GDMA_BASE + 0x890)
|
||
|
|
#define GDI_RBC2_AXI_0 (GDMA_BASE + 0x8A0)
|
||
|
|
#define GDI_RBC2_AXI_1F (GDMA_BASE + 0x91C)
|
||
|
|
#define GDI_TILEDBUF_BASE (GDMA_BASE + 0x920)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// Product, Reconfiguration Information
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define DBG_CONFIG_REPORT_0 (GDMA_BASE + 0x040) //product name and version
|
||
|
|
#define DBG_CONFIG_REPORT_1 (GDMA_BASE + 0x044) //interface configuration, hardware definition
|
||
|
|
#define DBG_CONFIG_REPORT_2 (GDMA_BASE + 0x048) //standard definition
|
||
|
|
#define DBG_CONFIG_REPORT_3 (GDMA_BASE + 0x04C) //standard detail definition
|
||
|
|
#define DBG_CONFIG_REPORT_4 (GDMA_BASE + 0x050) //definition in cnm_define
|
||
|
|
#define DBG_CONFIG_REPORT_5 (GDMA_BASE + 0x054)
|
||
|
|
#define DBG_CONFIG_REPORT_6 (GDMA_BASE + 0x058)
|
||
|
|
#define DBG_CONFIG_REPORT_7 (GDMA_BASE + 0x05C)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// MEMORY COPY MODULE REGISTER
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define ADDR_DMAC_PIC_RUN (DMAC_BASE+0x000)
|
||
|
|
#define ADDR_DMAC_PIC_STATUS (DMAC_BASE+0x004)
|
||
|
|
#define ADDR_DMAC_PIC_OP_MODE (DMAC_BASE+0x008)
|
||
|
|
#define ADDR_DMAC_ID (DMAC_BASE+0x00c) //the result muse be 0x4d435059
|
||
|
|
|
||
|
|
#define ADDR_DMAC_SRC_BASE_Y (DMAC_BASE+0x010)
|
||
|
|
#define ADDR_DMAC_SRC_BASE_CB (DMAC_BASE+0x014)
|
||
|
|
#define ADDR_DMAC_SRC_BASE_CR (DMAC_BASE+0x018)
|
||
|
|
#define ADDR_DMAC_SRC_STRIDE (DMAC_BASE+0x01c)
|
||
|
|
|
||
|
|
#define ADDR_DMAC_DST_BASE_Y (DMAC_BASE+0x020)
|
||
|
|
#define ADDR_DMAC_DST_BASE_CB (DMAC_BASE+0x024)
|
||
|
|
#define ADDR_DMAC_DST_BASE_CR (DMAC_BASE+0x028)
|
||
|
|
#define ADDR_DMAC_DST_STRIDE (DMAC_BASE+0x02c)
|
||
|
|
|
||
|
|
#define ADDR_DMAC_SRC_MB_POS_X (DMAC_BASE+0x030)
|
||
|
|
#define ADDR_DMAC_SRC_MB_POS_Y (DMAC_BASE+0x034)
|
||
|
|
#define ADDR_DMAC_SRC_MB_BLK_X (DMAC_BASE+0x038)
|
||
|
|
#define ADDR_DMAC_SRC_MB_BLK_Y (DMAC_BASE+0x03c)
|
||
|
|
|
||
|
|
#define ADDR_DMAC_DST_MB_POS_X (DMAC_BASE+0x040)
|
||
|
|
#define ADDR_DMAC_DST_MB_POS_Y (DMAC_BASE+0x044)
|
||
|
|
#define ADDR_DMAC_DST_MB_BLK_X (DMAC_BASE+0x048)
|
||
|
|
#define ADDR_DMAC_DST_MB_BLK_Y (DMAC_BASE+0x04c)
|
||
|
|
|
||
|
|
#define ADDR_DMAC_SET_COLOR_Y (DMAC_BASE+0x050)
|
||
|
|
#define ADDR_DMAC_SET_COLOR_CB (DMAC_BASE+0x054)
|
||
|
|
#define ADDR_DMAC_SET_COLOR_CR (DMAC_BASE+0x058)
|
||
|
|
|
||
|
|
#define ADDR_DMAC_SUB_SAMPLE_X (DMAC_BASE+0x060)
|
||
|
|
#define ADDR_DMAC_SUB_SAMPLE_Y (DMAC_BASE+0x064)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// DMAC
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define DMAC_DMAC_RUN (DMAC_BASE + 0x00)
|
||
|
|
#define DMAC_SOFT_RESET (DMAC_BASE + 0x04)
|
||
|
|
#define DMAC_DMAC_MODE (DMAC_BASE + 0x08)
|
||
|
|
#define DMAC_DESC_ADDR (DMAC_BASE + 0x0c)
|
||
|
|
#define DMAC_DESC0 (DMAC_BASE + 0x10)
|
||
|
|
#define DMAC_DESC1 (DMAC_BASE + 0x14)
|
||
|
|
#define DMAC_DESC2 (DMAC_BASE + 0x18)
|
||
|
|
#define DMAC_DESC3 (DMAC_BASE + 0x1c)
|
||
|
|
#define DMAC_DESC4 (DMAC_BASE + 0x20)
|
||
|
|
#define DMAC_DESC5 (DMAC_BASE + 0x24)
|
||
|
|
#define DMAC_DESC6 (DMAC_BASE + 0x28)
|
||
|
|
#define DMAC_DESC7 (DMAC_BASE + 0x2c)
|
||
|
|
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
// [FIRMWARE VERSION] COMMAND
|
||
|
|
// [32:16] project number =>
|
||
|
|
// [16:0] version => xxxx.xxxx.xxxxxxxx
|
||
|
|
//------------------------------------------------------------------------------
|
||
|
|
#define RET_FW_VER_NUM (BIT_BASE + 0x1c0)
|
||
|
|
#define RET_FW_CODE_REV (BIT_BASE + 0x1c4)
|
||
|
|
|
||
|
|
#endif
|