android13/kernel-5.10/drivers/media/platform/rockchip/ispp/regs.h

525 lines
22 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright (c) 2019 Fuzhou Rockchip Electronics Co., Ltd. */
#ifndef _RKISPP_REGS_H
#define _RKISPP_REGS_H
/* registers */
#define RKISPP_CTRL 0x0000
#define RKISPP_CTRL_STRT (RKISPP_CTRL + 0x0000)
#define RKISPP_CTRL_UPDATE (RKISPP_CTRL + 0x0004)
#define RKISPP_CTRL_QUICK (RKISPP_CTRL + 0x0008)
#define RKISPP_CTRL_RESET (RKISPP_CTRL + 0x000C)
#define RKISPP_CTRL_CLKGATE (RKISPP_CTRL + 0x0010)
#define RKISPP_CTRL_SIZE (RKISPP_CTRL + 0x0014)
#define RKISPP_CTRL_TNR_SIZE (RKISPP_CTRL + 0x0018)
#define RKISPP_CTRL_IP_VERSION (RKISPP_CTRL + 0x001C)
#define RKISPP_CTRL_INT_MSK (RKISPP_CTRL + 0x0020)
#define RKISPP_CTRL_INT_RAW_STA (RKISPP_CTRL + 0x0024)
#define RKISPP_CTRL_INT_STA (RKISPP_CTRL + 0x0028)
#define RKISPP_CTRL_INT_SET (RKISPP_CTRL + 0x002C)
#define RKISPP_CTRL_INT_CLR (RKISPP_CTRL + 0x0030)
#define RKISPP_QUICK_DIF (RKISPP_CTRL + 0x0034)
#define RKISPP_CTRL_SYS_STATUS (RKISPP_CTRL + 0x003C)
#define RKISPP_CTRL_QUICK_FRM_NUM (RKISPP_CTRL + 0x0040)
#define RKISPP_CTRL_SYS_CTL_STA0 (RKISPP_CTRL + 0x0054)
#define RKISPP_CTRL_SYS_CTL_STA1 (RKISPP_CTRL + 0x0058)
#define RKISPP_CTRL_SYS_CTL_STA2 (RKISPP_CTRL + 0x005C)
#define RKISPP_CTRL_SYS_FRM_CNT0 (RKISPP_CTRL + 0x0060)
#define RKISPP_CTRL_SYS_FRM_CNT1 (RKISPP_CTRL + 0x0064)
#define RKISPP_TNR 0x0200
#define RKISPP_TNR_CTRL (RKISPP_TNR + 0x0000)
#define RKISPP_TNR_CUR_VIR_STRIDE (RKISPP_TNR + 0x0004)
#define RKISPP_TNR_CUR_Y_BASE (RKISPP_TNR + 0x0008)
#define RKISPP_TNR_CUR_UV_BASE (RKISPP_TNR + 0x000C)
#define RKISPP_TNR_IIR_VIR_STRIDE (RKISPP_TNR + 0x0010)
#define RKISPP_TNR_IIR_Y_BASE (RKISPP_TNR + 0x0014)
#define RKISPP_TNR_IIR_UV_BASE (RKISPP_TNR + 0x0018)
#define RKISPP_TNR_NXT_VIR_STRIDE (RKISPP_TNR + 0x001C)
#define RKISPP_TNR_NXT_Y_BASE (RKISPP_TNR + 0x0020)
#define RKISPP_TNR_NXT_UV_BASE (RKISPP_TNR + 0x0024)
#define RKISPP_TNR_GAIN_CUR_VIR_STRIDE (RKISPP_TNR + 0x0028)
#define RKISPP_TNR_GAIN_CUR_Y_BASE (RKISPP_TNR + 0x002C)
#define RKISPP_TNR_GAIN_NXT_VIR_STRIDE (RKISPP_TNR + 0x0030)
#define RKISPP_TNR_GAIN_NXT_Y_BASE (RKISPP_TNR + 0x0034)
#define RKISPP_TNR_GAIN_KG_VIR_STRIDE (RKISPP_TNR + 0x0038)
#define RKISPP_TNR_GAIN_KG_Y_BASE (RKISPP_TNR + 0x003C)
#define RKISPP_TNR_WR_VIR_STRIDE (RKISPP_TNR + 0x0040)
#define RKISPP_TNR_WR_Y_BASE (RKISPP_TNR + 0x0044)
#define RKISPP_TNR_WR_UV_BASE (RKISPP_TNR + 0x0048)
#define RKISPP_TNR_GAIN_WR_VIR_STRIDE (RKISPP_TNR + 0x004C)
#define RKISPP_TNR_GAIN_WR_Y_BASE (RKISPP_TNR + 0x0050)
#define RKISPP_TNR_CUR_Y_BASE_SHD (RKISPP_TNR + 0x0054)
#define RKISPP_TNR_CUR_UV_BASE_SHD (RKISPP_TNR + 0x0058)
#define RKISPP_TNR_IIR_Y_BASE_SHD (RKISPP_TNR + 0x005C)
#define RKISPP_TNR_IIR_UV_BASE_SHD (RKISPP_TNR + 0x0060)
#define RKISPP_TNR_NXT_Y_BASE_SHD (RKISPP_TNR + 0x0064)
#define RKISPP_TNR_NXT_UV_BASE_SHD (RKISPP_TNR + 0x0068)
#define RKISPP_TNR_GAIN_CUR_Y_BASE_SHD (RKISPP_TNR + 0x006C)
#define RKISPP_TNR_GAIN_NXT_Y_BASE_SHD (RKISPP_TNR + 0x0070)
#define RKISPP_TNR_WR_Y_BASE_SHD (RKISPP_TNR + 0x0074)
#define RKISPP_TNR_WR_UV_BASE_SHD (RKISPP_TNR + 0x0078)
#define RKISPP_TNR_GAIN_WR_Y_BASE_SHD (RKISPP_TNR + 0x007C)
#define RKISPP_TNR_CORE_CTRL (RKISPP_TNR + 0x0080)
#define RKISPP_TNR_CORE_PK0 (RKISPP_TNR + 0x0088)
#define RKISPP_TNR_CORE_GLB_GAIN (RKISPP_TNR + 0x008C)
#define RKISPP_TNR_CORE_GLB_GAIN_DIV (RKISPP_TNR + 0x0090)
#define RKISPP_TNR_CORE_SIG_X18 (RKISPP_TNR + 0x0094)
#define RKISPP_TNR_CORE_SIG_X910 (RKISPP_TNR + 0x0098)
#define RKISPP_TNR_CORE_SIG_Y01 (RKISPP_TNR + 0x009C)
#define RKISPP_TNR_CORE_SIG_Y23 (RKISPP_TNR + 0x00A0)
#define RKISPP_TNR_CORE_SIG_Y45 (RKISPP_TNR + 0x00A4)
#define RKISPP_TNR_CORE_SIG_Y67 (RKISPP_TNR + 0x00A8)
#define RKISPP_TNR_CORE_SIG_Y89 (RKISPP_TNR + 0x00AC)
#define RKISPP_TNR_CORE_SIG_YAB (RKISPP_TNR + 0x00B0)
#define RKISPP_TNR_CORE_SIG_YCD (RKISPP_TNR + 0x00B4)
#define RKISPP_TNR_CORE_SIG_YEF (RKISPP_TNR + 0x00B8)
#define RKISPP_TNR_CORE_SIG_Y10 (RKISPP_TNR + 0x00BC)
#define RKISPP_TNR_CORE_LUMACURVE_Y01 (RKISPP_TNR + 0x00C4)
#define RKISPP_TNR_CORE_LUMACURVE_Y23 (RKISPP_TNR + 0x00C8)
#define RKISPP_TNR_CORE_LUMACURVE_Y45 (RKISPP_TNR + 0x00CC)
#define RKISPP_TNR_CORE_TH_Y (RKISPP_TNR + 0x00D0)
#define RKISPP_TNR_CORE_TH_C (RKISPP_TNR + 0x00D4)
#define RKISPP_TNR_CORE_TH_DLT (RKISPP_TNR + 0x00D8)
#define RKISPP_TNR_CORE_GFCOEF_Y0_0 (RKISPP_TNR + 0x00DC)
#define RKISPP_TNR_CORE_GFCOEF_Y0_1 (RKISPP_TNR + 0x00E0)
#define RKISPP_TNR_CORE_GFCOEF_Y1 (RKISPP_TNR + 0x00E4)
#define RKISPP_TNR_CORE_GFCOEF_Y2 (RKISPP_TNR + 0x00E8)
#define RKISPP_TNR_CORE_GFCOEF_Y3 (RKISPP_TNR + 0x00EC)
#define RKISPP_TNR_CORE_GFCOEF_YG0_0 (RKISPP_TNR + 0x00F0)
#define RKISPP_TNR_CORE_GFCOEF_YG0_1 (RKISPP_TNR + 0x00F4)
#define RKISPP_TNR_CORE_GFCOEF_YG1 (RKISPP_TNR + 0x00F8)
#define RKISPP_TNR_CORE_GFCOEF_YG2 (RKISPP_TNR + 0x00FC)
#define RKISPP_TNR_CORE_GFCOEF_YG3 (RKISPP_TNR + 0x0100)
#define RKISPP_TNR_CORE_GFCOEF_YL0_0 (RKISPP_TNR + 0x0104)
#define RKISPP_TNR_CORE_GFCOEF_YL0_1 (RKISPP_TNR + 0x0108)
#define RKISPP_TNR_CORE_GFCOEF_YL1 (RKISPP_TNR + 0x010C)
#define RKISPP_TNR_CORE_GFCOEF_YL2 (RKISPP_TNR + 0x0110)
#define RKISPP_TNR_CORE_GFCOEF_CG0_0 (RKISPP_TNR + 0x0114)
#define RKISPP_TNR_CORE_GFCOEF_CG0_1 (RKISPP_TNR + 0x0118)
#define RKISPP_TNR_CORE_GFCOEF_CG1 (RKISPP_TNR + 0x011C)
#define RKISPP_TNR_CORE_GFCOEF_CG2 (RKISPP_TNR + 0x0120)
#define RKISPP_TNR_CORE_GFCOEF_CL0_0 (RKISPP_TNR + 0x0124)
#define RKISPP_TNR_CORE_GFCOEF_CL0_1 (RKISPP_TNR + 0x0128)
#define RKISPP_TNR_CORE_GFCOEF_CL1 (RKISPP_TNR + 0x012C)
#define RKISPP_TNR_CORE_SCALE_YG01 (RKISPP_TNR + 0x0130)
#define RKISPP_TNR_CORE_SCALE_YG23 (RKISPP_TNR + 0x0134)
#define RKISPP_TNR_CORE_SCALE_YL01 (RKISPP_TNR + 0x0138)
#define RKISPP_TNR_CORE_SCALE_YL2 (RKISPP_TNR + 0x013c)
#define RKISPP_TNR_CORE_SCALE_CG0 (RKISPP_TNR + 0x0140)
#define RKISPP_TNR_CORE_SCALE_CG1 (RKISPP_TNR + 0x0144)
#define RKISPP_TNR_CORE_SCALE_CG2 (RKISPP_TNR + 0x0148)
#define RKISPP_TNR_CORE_SCALE_CL0 (RKISPP_TNR + 0x014C)
#define RKISPP_TNR_CORE_SCALE_CL1 (RKISPP_TNR + 0x0150)
#define RKISPP_TNR_CORE_SCALE_CL2 (RKISPP_TNR + 0x0154)
#define RKISPP_TNR_CORE_WEIGHT (RKISPP_TNR + 0x0158)
#define RKISPP_TNR_TILE_CNT (RKISPP_TNR + 0x01c0)
#define RKISPP_TNR_STATE (RKISPP_TNR + 0x01c4)
#define RKISPP_NR 0x0400
#define RKISPP_NR_CTRL (RKISPP_NR + 0x0000)
#define RKISPP_NR_VIR_STRIDE (RKISPP_NR + 0x0004)
#define RKISPP_NR_ADDR_BASE_Y (RKISPP_NR + 0x0008)
#define RKISPP_NR_ADDR_BASE_UV (RKISPP_NR + 0x000C)
#define RKISPP_NR_VIR_STRIDE_GAIN (RKISPP_NR + 0x001C)
#define RKISPP_NR_ADDR_BASE_GAIN (RKISPP_NR + 0x0020)
#define RKISPP_NR_ADDR_BASE_Y_SHD (RKISPP_NR + 0x0024)
#define RKISPP_NR_ADDR_BASE_UV_SHD (RKISPP_NR + 0x0028)
#define RKISPP_FBC_VIR_HEIGHT (RKISPP_NR + 0x002C)
#define RKISPP_NR_UVNR_CTRL_PARA (RKISPP_NR + 0x0080)
#define RKISPP_NR_UVNR_GAIN_1SIGMA (RKISPP_NR + 0x0084)
#define RKISPP_NR_UVNR_GAIN_OFFSET (RKISPP_NR + 0x0088)
#define RKISPP_NR_UVNR_GAIN_GBLGAIN (RKISPP_NR + 0x008C)
#define RKISPP_NR_UVNR_T1GEN_M3ALPHA (RKISPP_NR + 0x0090)
#define RKISPP_NR_UVNR_T1FLT_MODE (RKISPP_NR + 0x0094)
#define RKISPP_NR_UVNR_T1FLT_MSIGMA (RKISPP_NR + 0x0098)
#define RKISPP_NR_UVNR_T1FLT_WTP (RKISPP_NR + 0x009C)
#define RKISPP_NR_UVNR_T1FLT_WTQ0 (RKISPP_NR + 0x00A0)
#define RKISPP_NR_UVNR_T1FLT_WTQ1 (RKISPP_NR + 0x00A4)
#define RKISPP_NR_UVNR_T2GEN_M3ALPHA (RKISPP_NR + 0x00A8)
#define RKISPP_NR_UVNR_T2GEN_MSIGMA (RKISPP_NR + 0x00AC)
#define RKISPP_NR_UVNR_T2GEN_WTP (RKISPP_NR + 0x00B0)
#define RKISPP_NR_UVNR_T2GEN_WTQ (RKISPP_NR + 0x00B4)
#define RKISPP_NR_UVNR_T2FLT_MSIGMA (RKISPP_NR + 0x00B8)
#define RKISPP_NR_UVNR_T2FLT_WT (RKISPP_NR + 0x00BC)
#define RKISPP_NR_YNR_SGM_DX_1_8 (RKISPP_NR + 0x0104)
#define RKISPP_NR_YNR_SGM_DX_9_16 (RKISPP_NR + 0x0108)
#define RKISPP_NR_YNR_LSGM_Y_0_1 (RKISPP_NR + 0x010C)
#define RKISPP_NR_YNR_LSGM_Y_2_3 (RKISPP_NR + 0x0110)
#define RKISPP_NR_YNR_LSGM_Y_4_5 (RKISPP_NR + 0x0114)
#define RKISPP_NR_YNR_LSGM_Y_6_7 (RKISPP_NR + 0x0118)
#define RKISPP_NR_YNR_LSGM_Y_8_9 (RKISPP_NR + 0x011C)
#define RKISPP_NR_YNR_LSGM_Y_10_11 (RKISPP_NR + 0x0120)
#define RKISPP_NR_YNR_LSGM_Y_12_13 (RKISPP_NR + 0x0124)
#define RKISPP_NR_YNR_LSGM_Y_14_15 (RKISPP_NR + 0x0128)
#define RKISPP_NR_YNR_LSGM_Y_16 (RKISPP_NR + 0x012C)
#define RKISPP_NR_YNR_LCI (RKISPP_NR + 0x0130)
#define RKISPP_NR_YNR_LGAIN_DIRE_MIN (RKISPP_NR + 0x0134)
#define RKISPP_NR_YNR_IGAIN_DIRE_MAX (RKISPP_NR + 0x0138)
#define RKISPP_NR_YNR_LMERGE (RKISPP_NR + 0x013C)
#define RKISPP_NR_YNR_LWEIT_FLT (RKISPP_NR + 0x0140)
#define RKISPP_NR_YNR_HSGM_Y_0_1 (RKISPP_NR + 0x0144)
#define RKISPP_NR_YNR_HSGM_Y_2_3 (RKISPP_NR + 0x0148)
#define RKISPP_NR_YNR_HSGM_Y_4_5 (RKISPP_NR + 0x014C)
#define RKISPP_NR_YNR_HSGM_Y_6_7 (RKISPP_NR + 0x0150)
#define RKISPP_NR_YNR_HSGM_Y_8_9 (RKISPP_NR + 0x0154)
#define RKISPP_NR_YNR_HSGM_Y_10_11 (RKISPP_NR + 0x0158)
#define RKISPP_NR_YNR_HSGM_Y_12_13 (RKISPP_NR + 0x015C)
#define RKISPP_NR_YNR_HSGM_Y_14_15 (RKISPP_NR + 0x0160)
#define RKISPP_NR_YNR_HSGM_Y_16 (RKISPP_NR + 0x0164)
#define RKISPP_NR_YNR_HLCI (RKISPP_NR + 0x0168)
#define RKISPP_NR_YNR_LHCI (RKISPP_NR + 0x016C)
#define RKISPP_NR_YNR_HHCI (RKISPP_NR + 0x0170)
#define RKISPP_NR_YNR_HGAIN_SGM (RKISPP_NR + 0x0174)
#define RKISPP_NR_YNR_HWEIT_D0 (RKISPP_NR + 0x0178)
#define RKISPP_NR_YNR_HWEIT_D1 (RKISPP_NR + 0x017C)
#define RKISPP_NR_YNR_HWEIT_D2 (RKISPP_NR + 0x0180)
#define RKISPP_NR_YNR_HWEIT_D3 (RKISPP_NR + 0x0184)
#define RKISPP_NR_YNR_HWEIT_D4 (RKISPP_NR + 0x0188)
#define RKISPP_NR_YNR_HGRAD_Y0 (RKISPP_NR + 0x018C)
#define RKISPP_NR_YNR_HGRAD_Y1 (RKISPP_NR + 0x0190)
#define RKISPP_NR_YNR_HGRAD_Y2 (RKISPP_NR + 0x0194)
#define RKISPP_NR_YNR_HGRAD_Y3 (RKISPP_NR + 0x0198)
#define RKISPP_NR_YNR_HGRAD_Y4 (RKISPP_NR + 0x019C)
#define RKISPP_NR_YNR_HGRAD_Y5 (RKISPP_NR + 0x01A0)
#define RKISPP_NR_YNR_HWEIT_1_2 (RKISPP_NR + 0x01A4)
#define RKISPP_NR_YNR_HWEIT_3_4 (RKISPP_NR + 0x01A8)
#define RKISPP_NR_YNR_HADJUST_EXGAIN (RKISPP_NR + 0x01AC)
#define RKISPP_NR_YNR_HMAX_ADJUST (RKISPP_NR + 0x01B0)
#define RKISPP_NR_YNR_HSTRENGTH (RKISPP_NR + 0x01B4)
#define RKISPP_NR_YNR_LWEIT_CMP (RKISPP_NR + 0x01B8)
#define RKISPP_NR_YNR_LMAXGAIN_LV4 (RKISPP_NR + 0x01BC)
#define RKISPP_NR_YNR_HSTV_Y_0_1 (RKISPP_NR + 0x01C0)
#define RKISPP_NR_YNR_HSTV_Y_2_3 (RKISPP_NR + 0x01C4)
#define RKISPP_NR_YNR_HSTV_Y_4_5 (RKISPP_NR + 0x01C8)
#define RKISPP_NR_YNR_HSTV_Y_6_7 (RKISPP_NR + 0x01CC)
#define RKISPP_NR_YNR_HSTV_Y_8_9 (RKISPP_NR + 0x01D0)
#define RKISPP_NR_YNR_HSTV_Y_10_11 (RKISPP_NR + 0x01D4)
#define RKISPP_NR_YNR_HSTV_Y_12_13 (RKISPP_NR + 0x01D8)
#define RKISPP_NR_YNR_HSTV_Y_14_15 (RKISPP_NR + 0x01DC)
#define RKISPP_NR_YNR_HSTV_Y_16 (RKISPP_NR + 0x01E0)
#define RKISPP_NR_YNR_ST_SCALE_LV1_LV2 (RKISPP_NR + 0x01E4)
#define RKISPP_NR_YNR_ST_SCALE_LV3 (RKISPP_NR + 0x01E8)
#define RKISPP_NR_BLOCK_CNT (RKISPP_NR + 0x01f0)
#define RKISPP_NR_BUFFER_READY (RKISPP_NR + 0x01f4)
#define RKISPP_SHARP 0x0600
#define RKISPP_SHARP_CTRL (RKISPP_SHARP + 0x0000)
#define RKISPP_SHARP_WR_VIR_STRIDE (RKISPP_SHARP + 0x0004)
#define RKISPP_SHARP_WR_Y_BASE (RKISPP_SHARP + 0x0008)
#define RKISPP_SHARP_WR_UV_BASE (RKISPP_SHARP + 0x000C)
#define RKISPP_SHARP_SC_DOWN (RKISPP_SHARP + 0x0010)
#define RKISPP_SHARP_TMP_YUV_BASE (RKISPP_SHARP + 0x0014)
#define RKISPP_SHARP_WR_Y_BASE_SHD (RKISPP_SHARP + 0x0024)
#define RKISPP_SHARP_WR_UV_BASE_SHD (RKISPP_SHARP + 0x0028)
#define RKISPP_SHARP_TILE_IDX (RKISPP_SHARP + 0x0030)
#define RKISPP_SHARP_CORE_CTRL (RKISPP_SHARP + 0x0080)
#define RKISPP_SHARP_HBF_FACTOR (RKISPP_SHARP + 0x0084)
#define RKISPP_SHARP_EDGE_TH (RKISPP_SHARP + 0x0088)
#define RKISPP_SHARP_EDGE_ALPHA (RKISPP_SHARP + 0x008C)
#define RKISPP_SHARP_PBF_KERNEL (RKISPP_SHARP + 0x0090)
#define RKISPP_SHARP_MRF_KERNEL0 (RKISPP_SHARP + 0x0094)
#define RKISPP_SHARP_MRF_KERNEL1 (RKISPP_SHARP + 0x0098)
#define RKISPP_SHARP_MBF_KERNEL0 (RKISPP_SHARP + 0x009C)
#define RKISPP_SHARP_MBF_KERNEL1 (RKISPP_SHARP + 0x00A0)
#define RKISPP_SHARP_MBF_KERNEL2 (RKISPP_SHARP + 0x00A4)
#define RKISPP_SHARP_HRF_KERNEL0 (RKISPP_SHARP + 0x00A8)
#define RKISPP_SHARP_HRF_KERNEL1 (RKISPP_SHARP + 0x00AC)
#define RKISPP_SHARP_HBF_KERNEL (RKISPP_SHARP + 0x00B0)
#define RKISPP_SHARP_EDGE_COEF (RKISPP_SHARP + 0x00B4)
#define RKISPP_SHARP_EDGE_SMOTH (RKISPP_SHARP + 0x00B8)
#define RKISPP_SHARP_EDGE_GAUS0 (RKISPP_SHARP + 0x00BC)
#define RKISPP_SHARP_EDGE_GAUS1 (RKISPP_SHARP + 0x00C0)
#define RKISPP_SHARP_DOG_KERNEL0 (RKISPP_SHARP + 0x00C4)
#define RKISPP_SHARP_DOG_KERNEL1 (RKISPP_SHARP + 0x00C8)
#define RKISPP_SHARP_LUM_POINT0 (RKISPP_SHARP + 0x00CC)
#define RKISPP_SHARP_LUM_POINT1 (RKISPP_SHARP + 0x00D0)
#define RKISPP_SHARP_SHF_BITS (RKISPP_SHARP + 0x00D4)
#define RKISPP_SHARP_PBF_SIGMA_INV0 (RKISPP_SHARP + 0x00D8)
#define RKISPP_SHARP_PBF_SIGMA_INV1 (RKISPP_SHARP + 0x00DC)
#define RKISPP_SHARP_LUM_CLP_M0 (RKISPP_SHARP + 0x00E0)
#define RKISPP_SHARP_LUM_CLP_M1 (RKISPP_SHARP + 0x00E4)
#define RKISPP_SHARP_LUM_MIN_M0 (RKISPP_SHARP + 0x00E8)
#define RKISPP_SHARP_LUM_MIN_M1 (RKISPP_SHARP + 0x00EC)
#define RKISPP_SHARP_MBF_SIGMA_INV0 (RKISPP_SHARP + 0x00F0)
#define RKISPP_SHARP_MBF_SIGMA_INV1 (RKISPP_SHARP + 0x00F4)
#define RKISPP_SHARP_LUM_CLP_H0 (RKISPP_SHARP + 0x00F8)
#define RKISPP_SHARP_LUM_CLP_H1 (RKISPP_SHARP + 0x00FC)
#define RKISPP_SHARP_HBF_SIGMA_INV0 (RKISPP_SHARP + 0x0100)
#define RKISPP_SHARP_HBF_SIGMA_INV1 (RKISPP_SHARP + 0x0104)
#define RKISPP_SHARP_EDGE_LUM_THED0 (RKISPP_SHARP + 0x0108)
#define RKISPP_SHARP_EDGE_LUM_THED1 (RKISPP_SHARP + 0x010C)
#define RKISPP_SHARP_CLAMP_POS_DOG0 (RKISPP_SHARP + 0x0110)
#define RKISPP_SHARP_CLAMP_POS_DOG1 (RKISPP_SHARP + 0x0114)
#define RKISPP_SHARP_CLAMP_NEG_DOG0 (RKISPP_SHARP + 0x0118)
#define RKISPP_SHARP_CLAMP_NEG_DOG1 (RKISPP_SHARP + 0x011C)
#define RKISPP_SHARP_DETAIL_ALPHA_DOG0 (RKISPP_SHARP + 0x0120)
#define RKISPP_SHARP_DETAIL_ALPHA_DOG1 (RKISPP_SHARP + 0x0124)
#define RKISPP_SHARP_RF_RATIO (RKISPP_SHARP + 0x0128)
#define RKISPP_SHARP_GRAD_RATIO (RKISPP_SHARP + 0x012C)
#define RKISPP_SCL0 0x0800
#define RKISPP_SCL0_CTRL (RKISPP_SCL0 + 0x0000)
#define RKISPP_SCL0_CUR_VIR_STRIDE (RKISPP_SCL0 + 0x0004)
#define RKISPP_SCL0_CUR_Y_BASE (RKISPP_SCL0 + 0x0008)
#define RKISPP_SCL0_CUR_UV_BASE (RKISPP_SCL0 + 0x000C)
#define RKISPP_SCL0_CUR_Y_BASE_SHD (RKISPP_SCL0 + 0x0010)
#define RKISPP_SCL0_CUR_UV_BASE_SHD (RKISPP_SCL0 + 0x0014)
#define RKISPP_SCL0_FACTOR (RKISPP_SCL0 + 0x0018)
#define RKISPP_SCL1 0x0900
#define RKISPP_SCL1_CTRL (RKISPP_SCL1 + 0x0000)
#define RKISPP_SCL1_CUR_VIR_STRIDE (RKISPP_SCL1 + 0x0004)
#define RKISPP_SCL1_CUR_Y_BASE (RKISPP_SCL1 + 0x0008)
#define RKISPP_SCL1_CUR_UV_BASE (RKISPP_SCL1 + 0x000C)
#define RKISPP_SCL1_CUR_Y_BASE_SHD (RKISPP_SCL1 + 0x0010)
#define RKISPP_SCL1_CUR_UV_BASE_SHD (RKISPP_SCL1 + 0x0014)
#define RKISPP_SCL1_FACTOR (RKISPP_SCL1 + 0x0018)
#define RKISPP_SCL2 0x0A00
#define RKISPP_SCL2_CTRL (RKISPP_SCL2 + 0x0000)
#define RKISPP_SCL2_CUR_VIR_STRIDE (RKISPP_SCL2 + 0x0004)
#define RKISPP_SCL2_CUR_Y_BASE (RKISPP_SCL2 + 0x0008)
#define RKISPP_SCL2_CUR_UV_BASE (RKISPP_SCL2 + 0x000C)
#define RKISPP_SCL2_CUR_Y_BASE_SHD (RKISPP_SCL2 + 0x0010)
#define RKISPP_SCL2_CUR_UV_BASE_SHD (RKISPP_SCL2 + 0x0014)
#define RKISPP_SCL2_FACTOR (RKISPP_SCL2 + 0x0018)
#define RKISPP_ORB 0x0B00
#define RKISPP_ORB_WR_BASE (RKISPP_ORB + 0x0004)
#define RKISPP_ORB_WR_BASE_SHD (RKISPP_ORB + 0x0008)
#define RKISPP_ORB_TOTAL_NUM (RKISPP_ORB + 0x000c)
#define RKISPP_ORB_CORE_CTRL (RKISPP_ORB + 0x0080)
#define RKISPP_ORB_LIMIT_VALUE (RKISPP_ORB + 0x0084)
#define RKISPP_ORB_MAX_FEATURE (RKISPP_ORB + 0x0088)
#define RKISPP_FEC 0x0C00
#define RKISPP_FEC_CTRL (RKISPP_FEC + 0x0000)
#define RKISPP_FEC_RD_VIR_STRIDE (RKISPP_FEC + 0x0004)
#define RKISPP_FEC_RD_Y_BASE (RKISPP_FEC + 0x0008)
#define RKISPP_FEC_RD_UV_BASE (RKISPP_FEC + 0x000C)
#define RKISPP_FEC_MESH_XINT_BASE (RKISPP_FEC + 0x0010)
#define RKISPP_FEC_MESH_XFRA_BASE (RKISPP_FEC + 0x0014)
#define RKISPP_FEC_MESH_YINT_BASE (RKISPP_FEC + 0x0018)
#define RKISPP_FEC_MESH_YFRA_BASE (RKISPP_FEC + 0x001C)
#define RKISPP_FEC_WR_VIR_STRIDE (RKISPP_FEC + 0x0020)
#define RKISPP_FEC_WR_Y_BASE (RKISPP_FEC + 0x0024)
#define RKISPP_FEC_WR_UV_BASE (RKISPP_FEC + 0x0028)
#define RKISPP_FEC_RD_Y_BASE_SHD (RKISPP_FEC + 0x002C)
#define RKISPP_FEC_RD_UV_BASE_SHD (RKISPP_FEC + 0x0030)
#define RKISPP_FEC_MESH_XINT_BASE_SHD (RKISPP_FEC + 0x0034)
#define RKISPP_FEC_MESH_XFRA_BASE_SHD (RKISPP_FEC + 0x0038)
#define RKISPP_FEC_MESH_YINT_BASE_SHD (RKISPP_FEC + 0x003C)
#define RKISPP_FEC_MESH_YFRA_BASE_SHD (RKISPP_FEC + 0x0040)
#define RKISPP_FEC_WR_Y_BASE_SHD (RKISPP_FEC + 0x0044)
#define RKISPP_FEC_WR_UV_BASE_SHD (RKISPP_FEC + 0x0048)
#define RKISPP_FEC_FBCE_HEAD_OFFSET (RKISPP_FEC + 0x0050)
#define RKISPP_FEC_CORE_CTRL (RKISPP_FEC + 0x0080)
#define RKISPP_FEC_PIC_SIZE (RKISPP_FEC + 0x0088)
#define RKISPP_FEC_DST_SIZE (RKISPP_FEC + 0x0088)
#define RKISPP_FEC_MESH_SIZE (RKISPP_FEC + 0x008C)
#define RKISPP_FEC_DMA_STATUS (RKISPP_FEC + 0x0090)
#define RKISPP_FEC_CROP (RKISPP_FEC + 0x0094)
#define RKISPP_FEC_SRC_SIZE (RKISPP_FEC + 0x0098)
#define FMT_WR_MASK GENMASK(7, 4)
#define FMT_RD_MASK GENMASK(3, 0)
#define FMT_YUV420 0
#define FMT_YC_SWAP BIT(3)
#define FMT_YUYV BIT(2)
#define FMT_YUV422 BIT(1)
#define FMT_FBC BIT(0)
#define NR_NEW_ALGO BIT(16)
/* ISPP_STRT */
#define FEC_ST BIT(2)
#define NR_SHP_ST BIT(1)
#define TNR_ST BIT(0)
/* ISPP_UPDATE */
#define ALL_FORCE_UPD (FEC_FORCE_UPD | TNR_FORCE_UPD | OTHER_FORCE_UPD)
#define FEC_FORCE_UPD BIT(2)
#define TNR_FORCE_UPD BIT(1)
#define OTHER_FORCE_UPD BIT(0)
/* ISPP_CTRL_QUICK */
#define GLB_QUICK_MODE_MASK GENMASK(9, 8)
#define SW_PP_FBC_MODE_DIS BIT(30)
#define SW_PP_MMU_PLUS_DIS BIT(29)
#define SW_PP2ISP_HOLD_SEL BIT(28)
#define GLB_FEC2SCL_EN BIT(11)
#define GLB_NR_SD32_TNR BIT(10)
#define GLB_QUICK_MODE(a) (((a) & 0x3) << 8)
#define GLB_NOC_HURRY(a) (((a) & 0x3) << 4)
#define GLB_TNR_RDY_DIS BIT(3)
#define GLB_TNR2NR_RDY_MODE BIT(2)
#define GLB_DIRECT_MODE BIT(1)
#define GLB_QUICK_EN BIT(0)
/* ISPP_CTRL_RESET */
#define FBCD_ERR_PROTECT_DIS BIT(12)
#define GLB_SOFT_RST_SCL BIT(11)
#define GLB_SOFT_RST_SHP BIT(10)
#define GLB_SOFT_RST_NR BIT(9)
#define GLB_SOFT_RST_TNR BIT(8)
#define RST_PROTECT_DIS BIT(1)
#define GLB_SOFT_RST_ALL BIT(0)
/* ISPP_CLKGATE */
#define GATE_DIS_ALL 0xff
#define GATE_DIS_GLOBAL_RAM_CLK BIT(7)
#define GATE_DIS_SWS BIT(6)
#define GATE_DIS_FEC BIT(5)
#define GATE_DIS_SCL BIT(4)
#define GATE_DIS_SHP BIT(3)
#define GATE_DIS_NR BIT(2)
#define GATE_DIS_TNR BIT(1)
#define GATE_DIS_GLB BIT(0)
/* INT_MASK INT_RAW_STA INT_STA INT_SET INT_CLR */
#define INT_FRAME(stream) \
((stream)->config->frame_end_id)
#define NR_LOST_ERR BIT(26)
#define TNR_LOST_ERR BIT(25)
#define UVNR_MONITOR_ERR BIT(24)
#define FBCH_EMPTY_NR BIT(23)
#define FBCH_EMPTY_TNR BIT(22)
#define FBCD_DEC_ERR_NR BIT(21)
#define FBCD_DEC_ERR_TNR BIT(20)
#define BUS_ERR_NR BIT(17)
#define BUS_ERR_TNR BIT(16)
#define CMD_NR_SHP_ST_DONE BIT(12)
#define CMD_TNR_ST_DONE BIT(11)
#define SCL2_INT BIT(10)
#define SCL1_INT BIT(9)
#define SCL0_INT BIT(8)
#define FEC_INT BIT(7)
#define ORB_INT BIT(6)
#define SHP_INT BIT(4)
#define NR_INT BIT(3)
#define TNR_INT BIT(2)
#define FRAME_INT BIT(1)
#define QUICK_INT BIT(0)
/* ISPP_QUICK_DIF */
#define GLB_TNR2NR_DIF(a) (((a) & 0xff) << 16)
#define GLB_ISP2NR_DIF(a) (((a) & 0xff) << 8)
#define GLB_NR2FEC_DIF(a) ((a) & 0xff)
/* SYS_STATUS */
#define TNR_WORKING BIT(0)
#define NR_WORKING BIT(1)
#define SHP_WORKING BIT(2)
#define ORB_WORKING BIT(3)
#define SCL0_WORKING BIT(4)
#define SCL1_WORKING BIT(5)
#define SCL2_WORKING BIT(6)
#define FEC_WORKING BIT(7)
/* SYS_CTL_STA0 */
#define TNR_TILE_LINE_CNT_MASK GENMASK(6, 0)
#define NR_TILE_LINE_CNT_MASK GENMASK(14, 8)
#define FEC_TILE_LINE_CNT_MASK GENMASK(22, 16)
/* TNR CTRL */
#define SW_TNR_WR_FORMAT_MASK GENMASK(7, 4)
#define SW_TNR_RD_FORMAT_MASK GENMASK(3, 0)
#define SW_TNR_THROUGH_MODE BIT(10)
#define SW_TNR_1ST_FRM BIT(9)
#define SW_TNR_RD_PINGPONG2TO1 BIT(8)
#define SW_TNR_WR_YUYV_YCSWAP BIT(7)
#define SW_TNR_WR_YUYV_FORMAT BIT(6)
#define SW_TNR_WR_YUV_FORMAT BIT(5)
#define SW_TNR_WR_FBCE_MODE BIT(4)
#define SW_TNR_RD_YUYV_YCSWAP BIT(3)
#define SW_TNR_RD_YUYV_FORMAT BIT(2)
#define SW_TNR_RD_YUV_FORMAT BIT(1)
#define SW_TNR_FBCD_MODE BIT(0)
/* CORE_CTRL */
#define SW_TNR_GLB_GAIN_EN_SHD BIT(28)
#define SW_TNR_OPTC_EN_SHD BIT(27)
#define SW_TNR_OPTY_EN_SHD BIT(26)
#define SW_TNR_MODE_SHD BIT(25)
#define SW_TNR_EN_SHD BIT(24)
#define SW_TNR_GLB_GAIN_EN BIT(4)
#define SW_TNR_OPTC_EN BIT(3)
#define SW_TNR_OPTY_EN BIT(2)
#define SW_TNR_MODE BIT(1)
#define SW_TNR_EN BIT(0)
/* NR CTRL */
#define SW_NR_RD_FBCD_READ_MODE BIT(31)
#define SW_NR_NEW_ALGORITHM BIT(16)
#define SW_UVNR_1ST_FRM_SELF_MODE BIT(10)
#define SW_UVNR_1ST_FRM_SELF BIT(9)
#define SW_NR_RD_YUYV_YCSWAP BIT(3)
#define SW_NR_RD_YUYV_FORMAT BIT(2)
#define SW_NR_RD_YUV_FORMAT BIT(1)
#define SW_NR_RD_FBCD_MODE BIT(0)
/* NR_CTRL_PARA */
#define SW_UVNR_BIG_EN BIT(6)
#define SW_UVNR_NOBIG_EN BIT(5)
#define SW_UVNR_SD32_SELF_EN BIT(4)
#define SW_NR_GAIN_BYPASS BIT(3)
#define SW_UVNR_STEP2_ON BIT(2)
#define SW_UVNR_STEP1_ON BIT(1)
#define SW_NR_EN BIT(0)
/* SHP CTRL*/
#define SW_SHP_WR_FORMAT_MASK GENMASK(3, 0)
#define SW_SHP_WR_ROT_MODE(a) (((a) & 0x3) << 5)
#define SW_SHP_WR_YUV_LIMIT BIT(4)
#define SW_SHP_WR_YUYV_YCSWAP BIT(3)
#define SW_SHP_WR_YUYV_FORMAT BIT(2)
#define SW_SHP_WR_YUY_FORMAT BIT(1)
#define SW_SHP_WR_FBCE_MODE BIT(0)
/* CORE_CTRL */
#define SW_SHP_EDGE_AVG_EN BIT(4)
#define SW_SHP_YIN_FLT_EN BIT(3)
#define SW_SHP_DMA_DIS BIT(2)
#define SW_SHP_ALPHA_ADP_EN BIT(1)
#define SW_SHP_EN BIT(0)
/* SCL_CTRL */
#define SW_SCL_BYPASS_SHD BIT(31)
#define SW_SCL_ENABLE_SHD BIT(30)
#define SW_SCL_RAM_CLK_ON BIT(8)
#define SW_SCL_WR_YUV_LIMIT BIT(7)
#define SW_SCL_WR_YUYV_YCSWAP BIT(6)
#define SW_SCL_WR_YUYV_FORMAT BIT(5)
#define SW_SCL_WR_YUV_FORMAT BIT(4)
#define SW_SCL_WR_UV_DIS BIT(3)
#define SW_SCL_FIRST_MODE BIT(2)
#define SW_SCL_BYPASS BIT(1)
#define SW_SCL_ENABLE BIT(0)
/* FEC_CTRL*/
#define SW_FEC_WR_YUV_LIMIT BIT(8)
#define SW_FEC_WR_YUYV_YC_SWAP BIT(7)
#define SW_FEC_WR_YUYV_FORMAT BIT(6)
#define SW_FEC_WR_YUV_FORMAT BIT(5)
#define SW_FEC_WR_FBCE_MODE BIT(4)
#define SW_FEC_RD_YUYV_YCSWAP BIT(3)
#define SW_FEC_RD_YUYV_FORMAT BIT(2)
#define SW_FEC_RD_YUV_FORMAT BIT(1)
/* FEC_CORE_CTRL */
#define SW_FEC_EN_SHD BIT(31)
#define SW_OFFSET_ENABLE BIT(31)
#define SW_MINBUF_NON_UPDATE_SHD BIT(30)
#define SW_MINBUF_NON_UPDATE BIT(6)
#define SW_MESH_DENSITY BIT(5)
#define SW_BIC_MODE GENMASK(4, 3)
#define SW_FEC2DDR_DIS BIT(1)
#define SW_FEC_EN BIT(0)
/* ORB_CORE_CTRL */
#define SW_ORB_EN BIT(0)
#endif /* _RKISPP_REGS_H */