1*53ee8cc1Swenshuai.xi //<MStar Software> 2*53ee8cc1Swenshuai.xi //****************************************************************************** 3*53ee8cc1Swenshuai.xi // MStar Software 4*53ee8cc1Swenshuai.xi // Copyright (c) 2010 - 2012 MStar Semiconductor, Inc. All rights reserved. 5*53ee8cc1Swenshuai.xi // All software, firmware and related documentation herein ("MStar Software") are 6*53ee8cc1Swenshuai.xi // intellectual property of MStar Semiconductor, Inc. ("MStar") and protected by 7*53ee8cc1Swenshuai.xi // law, including, but not limited to, copyright law and international treaties. 8*53ee8cc1Swenshuai.xi // Any use, modification, reproduction, retransmission, or republication of all 9*53ee8cc1Swenshuai.xi // or part of MStar Software is expressly prohibited, unless prior written 10*53ee8cc1Swenshuai.xi // permission has been granted by MStar. 11*53ee8cc1Swenshuai.xi // 12*53ee8cc1Swenshuai.xi // By accessing, browsing and/or using MStar Software, you acknowledge that you 13*53ee8cc1Swenshuai.xi // have read, understood, and agree, to be bound by below terms ("Terms") and to 14*53ee8cc1Swenshuai.xi // comply with all applicable laws and regulations: 15*53ee8cc1Swenshuai.xi // 16*53ee8cc1Swenshuai.xi // 1. MStar shall retain any and all right, ownership and interest to MStar 17*53ee8cc1Swenshuai.xi // Software and any modification/derivatives thereof. 18*53ee8cc1Swenshuai.xi // No right, ownership, or interest to MStar Software and any 19*53ee8cc1Swenshuai.xi // modification/derivatives thereof is transferred to you under Terms. 20*53ee8cc1Swenshuai.xi // 21*53ee8cc1Swenshuai.xi // 2. You understand that MStar Software might include, incorporate or be 22*53ee8cc1Swenshuai.xi // supplied together with third party`s software and the use of MStar 23*53ee8cc1Swenshuai.xi // Software may require additional licenses from third parties. 24*53ee8cc1Swenshuai.xi // Therefore, you hereby agree it is your sole responsibility to separately 25*53ee8cc1Swenshuai.xi // obtain any and all third party right and license necessary for your use of 26*53ee8cc1Swenshuai.xi // such third party`s software. 27*53ee8cc1Swenshuai.xi // 28*53ee8cc1Swenshuai.xi // 3. MStar Software and any modification/derivatives thereof shall be deemed as 29*53ee8cc1Swenshuai.xi // MStar`s confidential information and you agree to keep MStar`s 30*53ee8cc1Swenshuai.xi // confidential information in strictest confidence and not disclose to any 31*53ee8cc1Swenshuai.xi // third party. 32*53ee8cc1Swenshuai.xi // 33*53ee8cc1Swenshuai.xi // 4. MStar Software is provided on an "AS IS" basis without warranties of any 34*53ee8cc1Swenshuai.xi // kind. Any warranties are hereby expressly disclaimed by MStar, including 35*53ee8cc1Swenshuai.xi // without limitation, any warranties of merchantability, non-infringement of 36*53ee8cc1Swenshuai.xi // intellectual property rights, fitness for a particular purpose, error free 37*53ee8cc1Swenshuai.xi // and in conformity with any international standard. You agree to waive any 38*53ee8cc1Swenshuai.xi // claim against MStar for any loss, damage, cost or expense that you may 39*53ee8cc1Swenshuai.xi // incur related to your use of MStar Software. 40*53ee8cc1Swenshuai.xi // In no event shall MStar be liable for any direct, indirect, incidental or 41*53ee8cc1Swenshuai.xi // consequential damages, including without limitation, lost of profit or 42*53ee8cc1Swenshuai.xi // revenues, lost or damage of data, and unauthorized system use. 43*53ee8cc1Swenshuai.xi // You agree that this Section 4 shall still apply without being affected 44*53ee8cc1Swenshuai.xi // even if MStar Software has been modified by MStar in accordance with your 45*53ee8cc1Swenshuai.xi // request or instruction for your use, except otherwise agreed by both 46*53ee8cc1Swenshuai.xi // parties in writing. 47*53ee8cc1Swenshuai.xi // 48*53ee8cc1Swenshuai.xi // 5. If requested, MStar may from time to time provide technical supports or 49*53ee8cc1Swenshuai.xi // services in relation with MStar Software to you for your use of 50*53ee8cc1Swenshuai.xi // MStar Software in conjunction with your or your customer`s product 51*53ee8cc1Swenshuai.xi // ("Services"). 52*53ee8cc1Swenshuai.xi // You understand and agree that, except otherwise agreed by both parties in 53*53ee8cc1Swenshuai.xi // writing, Services are provided on an "AS IS" basis and the warranty 54*53ee8cc1Swenshuai.xi // disclaimer set forth in Section 4 above shall apply. 55*53ee8cc1Swenshuai.xi // 56*53ee8cc1Swenshuai.xi // 6. Nothing contained herein shall be construed as by implication, estoppels 57*53ee8cc1Swenshuai.xi // or otherwise: 58*53ee8cc1Swenshuai.xi // (a) conferring any license or right to use MStar name, trademark, service 59*53ee8cc1Swenshuai.xi // mark, symbol or any other identification; 60*53ee8cc1Swenshuai.xi // (b) obligating MStar or any of its affiliates to furnish any person, 61*53ee8cc1Swenshuai.xi // including without limitation, you and your customers, any assistance 62*53ee8cc1Swenshuai.xi // of any kind whatsoever, or any information; or 63*53ee8cc1Swenshuai.xi // (c) conferring any license or right under any intellectual property right. 64*53ee8cc1Swenshuai.xi // 65*53ee8cc1Swenshuai.xi // 7. These terms shall be governed by and construed in accordance with the laws 66*53ee8cc1Swenshuai.xi // of Taiwan, R.O.C., excluding its conflict of law rules. 67*53ee8cc1Swenshuai.xi // Any and all dispute arising out hereof or related hereto shall be finally 68*53ee8cc1Swenshuai.xi // settled by arbitration referred to the Chinese Arbitration Association, 69*53ee8cc1Swenshuai.xi // Taipei in accordance with the ROC Arbitration Law and the Arbitration 70*53ee8cc1Swenshuai.xi // Rules of the Association by three (3) arbitrators appointed in accordance 71*53ee8cc1Swenshuai.xi // with the said Rules. 72*53ee8cc1Swenshuai.xi // The place of arbitration shall be in Taipei, Taiwan and the language shall 73*53ee8cc1Swenshuai.xi // be English. 74*53ee8cc1Swenshuai.xi // The arbitration award shall be final and binding to both parties. 75*53ee8cc1Swenshuai.xi // 76*53ee8cc1Swenshuai.xi //****************************************************************************** 77*53ee8cc1Swenshuai.xi //<MStar Software> 78*53ee8cc1Swenshuai.xi //////////////////////////////////////////////////////////////////////////////// 79*53ee8cc1Swenshuai.xi // 80*53ee8cc1Swenshuai.xi // Copyright (c) 2008-2009 MStar Semiconductor, Inc. 81*53ee8cc1Swenshuai.xi // All rights reserved. 82*53ee8cc1Swenshuai.xi // 83*53ee8cc1Swenshuai.xi // Unless otherwise stipulated in writing, any and all information contained 84*53ee8cc1Swenshuai.xi // herein regardless in any format shall remain the sole proprietary of 85*53ee8cc1Swenshuai.xi // MStar Semiconductor Inc. and be kept in strict confidence 86*53ee8cc1Swenshuai.xi // ("MStar Confidential Information") by the recipient. 87*53ee8cc1Swenshuai.xi // Any unauthorized act including without limitation unauthorized disclosure, 88*53ee8cc1Swenshuai.xi // copying, use, reproduction, sale, distribution, modification, disassembling, 89*53ee8cc1Swenshuai.xi // reverse engineering and compiling of the contents of MStar Confidential 90*53ee8cc1Swenshuai.xi // Information is unlawful and strictly prohibited. MStar hereby reserves the 91*53ee8cc1Swenshuai.xi // rights to any and all damages, losses, costs and expenses resulting therefrom. 92*53ee8cc1Swenshuai.xi // 93*53ee8cc1Swenshuai.xi //////////////////////////////////////////////////////////////////////////////// 94*53ee8cc1Swenshuai.xi 95*53ee8cc1Swenshuai.xi #ifndef _REG_GOP_H_ 96*53ee8cc1Swenshuai.xi #define _REG_GOP_H_ 97*53ee8cc1Swenshuai.xi 98*53ee8cc1Swenshuai.xi //------------------------------------------------------------------------------------------------- 99*53ee8cc1Swenshuai.xi // Hardware Capability 100*53ee8cc1Swenshuai.xi //------------------------------------------------------------------------------------------------- 101*53ee8cc1Swenshuai.xi 102*53ee8cc1Swenshuai.xi 103*53ee8cc1Swenshuai.xi //------------------------------------------------------------------------------------------------- 104*53ee8cc1Swenshuai.xi // Macro and Define 105*53ee8cc1Swenshuai.xi //------------------------------------------------------------------------------------------------- 106*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 107*53ee8cc1Swenshuai.xi // HW IP Reg Base Adr 108*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 109*53ee8cc1Swenshuai.xi #define GOP_REG_BASE 0x1F00 110*53ee8cc1Swenshuai.xi #define GE_REG_BASE 0x2800 111*53ee8cc1Swenshuai.xi #define SC1_REG_BASE 0x2F00 112*53ee8cc1Swenshuai.xi #define CKG_REG_BASE 0x0B00 113*53ee8cc1Swenshuai.xi #define MIU_REG_BASE 0x1200 114*53ee8cc1Swenshuai.xi #define MVOP_REG_BASE 0x1400 115*53ee8cc1Swenshuai.xi #define SC1_DIRREG_BASE 0x130000 116*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 117*53ee8cc1Swenshuai.xi // Scaler Reg 118*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 119*53ee8cc1Swenshuai.xi #define XC_REG(bk, reg) (SC1_REG_BASE+((MS_U32)(bk)<<16) + (reg) * 2) 120*53ee8cc1Swenshuai.xi 121*53ee8cc1Swenshuai.xi #define REG_SC_BK00_00_L XC_REG(0x00, 0x00) 122*53ee8cc1Swenshuai.xi #define REG_SC_BK00_05_L XC_REG(0x00, 0x05) 123*53ee8cc1Swenshuai.xi #define REG_SC_BK00_06_L XC_REG(0x00, 0x06) 124*53ee8cc1Swenshuai.xi #define REG_SC_BK01_02_L XC_REG(0x01, 0x02) 125*53ee8cc1Swenshuai.xi #define REG_SC_BK02_5F_L XC_REG(0x02, 0x5F) 126*53ee8cc1Swenshuai.xi #define REG_SC_BK10_23_L XC_REG(0x10, 0x23) 127*53ee8cc1Swenshuai.xi #define REG_SC_BK10_50_L XC_REG(0x10, 0x50) 128*53ee8cc1Swenshuai.xi #define REG_SC_BK10_5B_L XC_REG(0x10, 0x5B) 129*53ee8cc1Swenshuai.xi #define REG_SC_BK12_03_L XC_REG(0x12, 0x03) 130*53ee8cc1Swenshuai.xi #define REG_SC_BK20_10_L XC_REG(0x20, 0x10) 131*53ee8cc1Swenshuai.xi #define REG_SC_BK0F_2B_L XC_REG(0x0F, 0x2B) 132*53ee8cc1Swenshuai.xi #define REG_SC_BK3E_28_L XC_REG(0x3E, 0x28) 133*53ee8cc1Swenshuai.xi #define REG_SC_BK37_22_L XC_REG(0x37, 0x22) 134*53ee8cc1Swenshuai.xi #define REG_SC_BK37_24_L XC_REG(0x37, 0x24) 135*53ee8cc1Swenshuai.xi #define REG_SC_BK3D_0D_L XC_REG(0x3D, 0x0D) 136*53ee8cc1Swenshuai.xi 137*53ee8cc1Swenshuai.xi #define GOP_SC_BANKSEL REG_SC_BK00_00_L 138*53ee8cc1Swenshuai.xi #define GOP_SC_CHANNELSYNC REG_SC_BK00_05_L 139*53ee8cc1Swenshuai.xi #define GOP_SC_GOPEN REG_SC_BK00_06_L 140*53ee8cc1Swenshuai.xi #define GOP_SC_IP_SYNC REG_SC_BK01_02_L 141*53ee8cc1Swenshuai.xi #define GOP_SC_IP2GOP_SRCSEL REG_SC_BK02_5F_L 142*53ee8cc1Swenshuai.xi #define GOP_SC_VOPNBL REG_SC_BK10_23_L 143*53ee8cc1Swenshuai.xi #define GOP_SC_GOPEN_DWIN REG_SC_BK10_50_L 144*53ee8cc1Swenshuai.xi #define GOP_SC_GOPENMODE1 REG_SC_BK10_5B_L 145*53ee8cc1Swenshuai.xi #define GOP_SC_MIRRORCFG REG_SC_BK12_03_L 146*53ee8cc1Swenshuai.xi #define GOP_SC_OSD_CHECK_ALPHA REG_SC_BK0F_2B_L 147*53ee8cc1Swenshuai.xi #define GOP_SC_GOPEN_BYPASS REG_SC_BK3E_28_L 148*53ee8cc1Swenshuai.xi #define GOP_SC_OCMIXER REG_SC_BK37_22_L 149*53ee8cc1Swenshuai.xi #define GOP_SC_OCMISC REG_SC_BK37_24_L 150*53ee8cc1Swenshuai.xi #define GOP_SC_GOPSC_SRAM_CTRL REG_SC_BK3D_0D_L 151*53ee8cc1Swenshuai.xi 152*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 153*53ee8cc1Swenshuai.xi // MVOP Reg 154*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 155*53ee8cc1Swenshuai.xi #define GOP_MVOP_MIRRORCFG (MVOP_REG_BASE+0x76) 156*53ee8cc1Swenshuai.xi 157*53ee8cc1Swenshuai.xi 158*53ee8cc1Swenshuai.xi 159*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 160*53ee8cc1Swenshuai.xi // GE Reg 161*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 162*53ee8cc1Swenshuai.xi #define GOP_GE_FMT_BLT (GE_REG_BASE+(0x01*2)) 163*53ee8cc1Swenshuai.xi #define GOP_GE_EN_CMDQ BIT(0) 164*53ee8cc1Swenshuai.xi #define GOP_GE_EN_VCMDQ BIT(1) 165*53ee8cc1Swenshuai.xi 166*53ee8cc1Swenshuai.xi #define GOP_GE_VQ_FIFO_STATUS_L (GE_REG_BASE+(0x04*2)) 167*53ee8cc1Swenshuai.xi #define GOP_GE_VQ_FIFO_STATUS_H (GE_REG_BASE+(0x05*2)) 168*53ee8cc1Swenshuai.xi 169*53ee8cc1Swenshuai.xi #define GOP_GE_STATUS (GE_REG_BASE+(0x07*2)) 170*53ee8cc1Swenshuai.xi #define GOP_GE_BUSY BIT(0) 171*53ee8cc1Swenshuai.xi #define GOP_GE_CMDQ1_STATUS BMASK(7:3) 172*53ee8cc1Swenshuai.xi #define GOP_GE_CMDQ2_STATUS BMASK(15:11) 173*53ee8cc1Swenshuai.xi 174*53ee8cc1Swenshuai.xi #define GOP_GE_TAG (GE_REG_BASE+(0x2C*2)) 175*53ee8cc1Swenshuai.xi 176*53ee8cc1Swenshuai.xi #define GOP_GE_DBBASE0 (GE_REG_BASE+(0x26*2)) 177*53ee8cc1Swenshuai.xi #define GOP_GE_DBBASE1 (GE_REG_BASE+(0x27*2)) 178*53ee8cc1Swenshuai.xi #define GOP_GE_DBPIT (GE_REG_BASE+(0x33*2)) 179*53ee8cc1Swenshuai.xi #define GOP_GE_FBFMT (GE_REG_BASE+(0x34*2)) 180*53ee8cc1Swenshuai.xi #define GOP_GE_SRCW (GE_REG_BASE+(0x6e*2)) 181*53ee8cc1Swenshuai.xi #define GOP_GE_SRCH (GE_REG_BASE+(0x6f*2)) 182*53ee8cc1Swenshuai.xi 183*53ee8cc1Swenshuai.xi 184*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 185*53ee8cc1Swenshuai.xi // ChipTop Reg 186*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 187*53ee8cc1Swenshuai.xi /* GOP0 and GOP1 CLK */ 188*53ee8cc1Swenshuai.xi #define GOP_GOPCLK (CKG_REG_BASE+0x80) 189*53ee8cc1Swenshuai.xi #define CKG_GOPG0_DISABLE_CLK ~(GOP_BIT0) 190*53ee8cc1Swenshuai.xi #define CKG_GOPG0_ODCLK (0<<2) 191*53ee8cc1Swenshuai.xi #define CKG_GOPG0_IDCLK2 (1 << 2) 192*53ee8cc1Swenshuai.xi #define CKG_GOPG0_IDCLK1 (3 << 2) 193*53ee8cc1Swenshuai.xi #define CKG_GOPG0_MASK (GOP_BIT4 | GOP_BIT3 | GOP_BIT2) 194*53ee8cc1Swenshuai.xi #define CKG_GOPG1_MASK (GOP_BIT12 | GOP_BIT11 | GOP_BIT10) 195*53ee8cc1Swenshuai.xi #define CKG_GOPG1_DISABLE_CLK ~(GOP_BIT8) 196*53ee8cc1Swenshuai.xi #define CKG_GOPG1_ODCLK (0 << 10) 197*53ee8cc1Swenshuai.xi #define CKG_GOPG1_IDCLK2 (1 << 10) 198*53ee8cc1Swenshuai.xi #define CKG_GOPG1_IDCLK1 (3 << 10) 199*53ee8cc1Swenshuai.xi 200*53ee8cc1Swenshuai.xi #define CKG_GOPG0_SCALING (CKG_REG_BASE+0x88) 201*53ee8cc1Swenshuai.xi #define CKG_GOPG0_MG (CKG_REG_BASE+0xFE) 202*53ee8cc1Swenshuai.xi #define CKG_GOPG0_MG_MASK (GOP_BIT3 | GOP_BIT2) 203*53ee8cc1Swenshuai.xi #define CKG_GOPG2_MG_MASK (GOP_BIT7 | GOP_BIT6) 204*53ee8cc1Swenshuai.xi 205*53ee8cc1Swenshuai.xi /* GOP2 and GOPDWIN CLK */ 206*53ee8cc1Swenshuai.xi #define GOP_GOP2CLK (CKG_REG_BASE+0x82) 207*53ee8cc1Swenshuai.xi #define CKG_GOPG2_DISABLE_CLK ~(GOP_BIT0) 208*53ee8cc1Swenshuai.xi #define CKG_GOPG2_ODCLK (0<<2) 209*53ee8cc1Swenshuai.xi #define CKG_GOPG2_IDCLK2 (1 << 2) 210*53ee8cc1Swenshuai.xi #define CKG_GOPG2_IDCLK1 (3 << 2) 211*53ee8cc1Swenshuai.xi #define CKG_GOPG2_MASK (GOP_BIT4 | GOP_BIT3 | GOP_BIT2) 212*53ee8cc1Swenshuai.xi #define CKG_GOPD_MASK (GOP_BIT12 | GOP_BIT11 | GOP_BIT10) 213*53ee8cc1Swenshuai.xi #define CKG_GOPD_CLK_IDCLK2 (0 << 10) 214*53ee8cc1Swenshuai.xi #define CKG_GOPD_CLK_ODCLK (1 << 10) 215*53ee8cc1Swenshuai.xi #define CKG_GOPD_CLK_DC0CLK (2 << 10) 216*53ee8cc1Swenshuai.xi #define CKG_GOPD_CLK_SUBDC0CLK (3 << 10) 217*53ee8cc1Swenshuai.xi 218*53ee8cc1Swenshuai.xi 219*53ee8cc1Swenshuai.xi /* GOP3 CLK*/ 220*53ee8cc1Swenshuai.xi #define GOP_GOP3CLK (CKG_REG_BASE+0x84) 221*53ee8cc1Swenshuai.xi #define CKG_GOPG3_ODCLK (0<<2) 222*53ee8cc1Swenshuai.xi #define CKG_GOPG3_IDCLK2 (1 << 2) 223*53ee8cc1Swenshuai.xi #define CKG_GOPG3_IDCLK1 (3 << 2) 224*53ee8cc1Swenshuai.xi #define CKG_GOPG3_MASK (GOP_BIT4 | GOP_BIT3 | GOP_BIT2) 225*53ee8cc1Swenshuai.xi #define CKG_GOPD_DISABLE_CLK ~(GOP_BIT8) 226*53ee8cc1Swenshuai.xi 227*53ee8cc1Swenshuai.xi /* GOP4 CLK*/ 228*53ee8cc1Swenshuai.xi #define GOP_GOP4CLK (CKG_REG_BASE+(0x7E<<1)) 229*53ee8cc1Swenshuai.xi #define CKG_GOPG4_ODCLK (0 << 10) 230*53ee8cc1Swenshuai.xi #define CKG_GOPG4_IDCLK2 (1 << 10) 231*53ee8cc1Swenshuai.xi #define CKG_GOPG4_IDCLK1 (2 << 10) 232*53ee8cc1Swenshuai.xi #define CKG_GOPG4_OCC_FRCCLK (3 << 10) 233*53ee8cc1Swenshuai.xi #define CKG_GOPG4_MIXERCLK_VE (4 << 10) 234*53ee8cc1Swenshuai.xi #define CKG_GOPG4_MASK (GOP_BIT12 | GOP_BIT11 | GOP_BIT10) 235*53ee8cc1Swenshuai.xi 236*53ee8cc1Swenshuai.xi 237*53ee8cc1Swenshuai.xi /* SRAM CLK */ 238*53ee8cc1Swenshuai.xi #define GOP_SRAMCLK (CKG_REG_BASE+0x84) 239*53ee8cc1Swenshuai.xi #define CKG_SRAM0_DISABLE_CLK (GOP_BIT0) 240*53ee8cc1Swenshuai.xi #define CKG_SRAM1_DISABLE_CLK (GOP_BIT8) 241*53ee8cc1Swenshuai.xi #define CKG_SRAM0_MASK (GOP_BIT0|GOP_BIT1) 242*53ee8cc1Swenshuai.xi #define CKG_SRAM1_MASK (GOP_BIT8|GOP_BIT9) 243*53ee8cc1Swenshuai.xi 244*53ee8cc1Swenshuai.xi 245*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 246*53ee8cc1Swenshuai.xi // MIU Reg 247*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 248*53ee8cc1Swenshuai.xi #define GOP_MIU_GROUP1 (MIU_REG_BASE+0xF2) 249*53ee8cc1Swenshuai.xi 250*53ee8cc1Swenshuai.xi /*Define each gop miu clint bit*/ 251*53ee8cc1Swenshuai.xi #define GOP_MIU_CLIENT_DWIN 0xff 252*53ee8cc1Swenshuai.xi #define GOP_MIU_CLIENT_GOP0 0x5 253*53ee8cc1Swenshuai.xi #define GOP_MIU_CLIENT_GOP1 0x6 254*53ee8cc1Swenshuai.xi #define GOP_MIU_CLIENT_GOP2 0x7 255*53ee8cc1Swenshuai.xi #define GOP_MIU_CLIENT_GOP3 0xF 256*53ee8cc1Swenshuai.xi #define GOP_MIU_CLIENT_GOP4 0xff 257*53ee8cc1Swenshuai.xi #define GOP_MIU_CLIENT_GOP5 0xff 258*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 259*53ee8cc1Swenshuai.xi // GOP Reg 260*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 261*53ee8cc1Swenshuai.xi #define GOP_REG(bk, reg) (GOP_REG_BASE+((MS_U32)(bk)<<16) + (reg) * 2) 262*53ee8cc1Swenshuai.xi #define __GOP_REG(reg) (GOP_REG_BASE+(reg) * 2) 263*53ee8cc1Swenshuai.xi #define GOP_REG_DIRECT_BASE (0x120200) 264*53ee8cc1Swenshuai.xi #define GOP_REG_VAL(x) (1<<x) 265*53ee8cc1Swenshuai.xi 266*53ee8cc1Swenshuai.xi //MUX Setting 267*53ee8cc1Swenshuai.xi #define GOP_MUX_SHIFT 0x2 268*53ee8cc1Swenshuai.xi #define GOP_REGMUX_MASK BMASK((GOP_MUX_SHIFT-1):0) 269*53ee8cc1Swenshuai.xi #define GOP_MUX0_MASK (GOP_REGMUX_MASK<<(GOP_MUX_SHIFT*0)) 270*53ee8cc1Swenshuai.xi #define GOP_MUX1_MASK (GOP_REGMUX_MASK<<(GOP_MUX_SHIFT*1)) 271*53ee8cc1Swenshuai.xi #define GOP_MUX2_MASK (GOP_REGMUX_MASK<<(GOP_MUX_SHIFT*2)) 272*53ee8cc1Swenshuai.xi #define GOP_MUX3_MASK (GOP_REGMUX_MASK<<(GOP_MUX_SHIFT*3)) 273*53ee8cc1Swenshuai.xi 274*53ee8cc1Swenshuai.xi //IP and VOP MUX Setting 275*53ee8cc1Swenshuai.xi #define GOP_IP_MAIN_MUX_SHIFT 0 276*53ee8cc1Swenshuai.xi #define GOP_IP_MAIN_MUX_MASK (BMASK((GOP_MUX_SHIFT-1):0))<<GOP_IP_MAIN_MUX_SHIFT 277*53ee8cc1Swenshuai.xi #define GOP_IP_SUB_MUX_SHIFT 3 278*53ee8cc1Swenshuai.xi #define GOP_IP_SUB_MUX_MASK (BMASK((GOP_MUX_SHIFT-1):0))<<GOP_IP_SUB_MUX_SHIFT 279*53ee8cc1Swenshuai.xi #define GOP_IP_VOP0_MUX_SHIFT 6 280*53ee8cc1Swenshuai.xi #define GOP_IP_VOP0_MUX_MASK (BMASK((GOP_MUX_SHIFT-1):0))<<GOP_IP_VOP0_MUX_SHIFT 281*53ee8cc1Swenshuai.xi #define GOP_IP_VOP1_MUX_SHIFT 9 282*53ee8cc1Swenshuai.xi #define GOP_IP_VOP1_MUX_MASK (BMASK((GOP_MUX_SHIFT-1):0))<<GOP_IP_VOP1_MUX_SHIFT 283*53ee8cc1Swenshuai.xi 284*53ee8cc1Swenshuai.xi // for gwin color format mask 285*53ee8cc1Swenshuai.xi #define GOP_REG_COLORTYPE_MASK BMASK(3:0) 286*53ee8cc1Swenshuai.xi #define GOP_REG_COLORTYPE_SHIFT 4 287*53ee8cc1Swenshuai.xi 288*53ee8cc1Swenshuai.xi #define GOP_BANK_OFFSET 0x3 289*53ee8cc1Swenshuai.xi #define GOP_4G_OFST 0x0 290*53ee8cc1Swenshuai.xi #define GOP_2G_OFST 0x3 291*53ee8cc1Swenshuai.xi #define GOP_1G_OFST 0x8 292*53ee8cc1Swenshuai.xi #define GOP_1GX_OFST 0xB 293*53ee8cc1Swenshuai.xi #define GOP_DW_OFST 0x6 294*53ee8cc1Swenshuai.xi #define GOP_1GS0_OFST 0xe 295*53ee8cc1Swenshuai.xi #define GOP_1GS1_OFST 0x11 296*53ee8cc1Swenshuai.xi 297*53ee8cc1Swenshuai.xi #define GOP_OFFSET_WR 8 298*53ee8cc1Swenshuai.xi #define GOP_VAL_WR GOP_REG_VAL(GOP_OFFSET_WR) 299*53ee8cc1Swenshuai.xi #define GOP_OFFSET_FWR 9 300*53ee8cc1Swenshuai.xi #define GOP_VAL_FWR GOP_REG_VAL(GOP_OFFSET_FWR) 301*53ee8cc1Swenshuai.xi #define GOP_OFFSET_FCLR 11 302*53ee8cc1Swenshuai.xi #define GOP_VAL_FCL GOP_REG_VAL(GOP_OFFSET_FCLR) 303*53ee8cc1Swenshuai.xi #define GOP4G_OFFSET_WR_ACK 12 304*53ee8cc1Swenshuai.xi #define GOP4G_VAL_WR_ACK GOP_REG_VAL(GOP4G_OFFSET_WR_ACK) 305*53ee8cc1Swenshuai.xi #define GOP2G_OFFSET_WR_ACK 13 306*53ee8cc1Swenshuai.xi #define GOP2G_VAL_WR_ACK GOP_REG_VAL(GOP2G_OFFSET_WR_ACK) 307*53ee8cc1Swenshuai.xi #define GOPD_OFFSET_WR_ACK 14 308*53ee8cc1Swenshuai.xi #define GOPD_VAL_WR_ACK GOP_REG_VAL(GOPD_OFFSET_WR_ACK) 309*53ee8cc1Swenshuai.xi #define GOP1G_OFFSET_WR_ACK 15 310*53ee8cc1Swenshuai.xi #define GOP1G_VAL_WR_ACK GOP_REG_VAL(GOPD_OFFSET_WR_ACK) 311*53ee8cc1Swenshuai.xi #define GOP_VAL_ACK(x) GOP_REG_VAL(GOP4G_OFFSET_WR_ACK+x) 312*53ee8cc1Swenshuai.xi 313*53ee8cc1Swenshuai.xi #define GOP_4G_CTRL0 GOP_REG(GOP_4G_OFST, 0x00) 314*53ee8cc1Swenshuai.xi #define GOP_4G_CTRL1 GOP_REG(GOP_4G_OFST, 0x01) 315*53ee8cc1Swenshuai.xi #define GOP_4G_RATE GOP_REG(GOP_4G_OFST, 0x02) 316*53ee8cc1Swenshuai.xi #define GOP_4G_PALDATA_L GOP_REG(GOP_4G_OFST, 0x03) 317*53ee8cc1Swenshuai.xi #define GOP_4G_PALDATA_H GOP_REG(GOP_4G_OFST, 0x04) 318*53ee8cc1Swenshuai.xi #define GOP_4G_PALCTRL GOP_REG(GOP_4G_OFST, 0x05) 319*53ee8cc1Swenshuai.xi #define GOP_4G_REGDMA_END GOP_REG(GOP_4G_OFST, 0x06) 320*53ee8cc1Swenshuai.xi #define GOP_4G_REGDMA_STR GOP_REG(GOP_4G_OFST, 0x07) 321*53ee8cc1Swenshuai.xi #define GOP_4G_INT GOP_REG(GOP_4G_OFST, 0x08) 322*53ee8cc1Swenshuai.xi #define GOP_4G_HWSTATE GOP_REG(GOP_4G_OFST, 0x09) 323*53ee8cc1Swenshuai.xi #define GOP_4G_SVM_HSTR GOP_REG(GOP_4G_OFST, 0x0a) 324*53ee8cc1Swenshuai.xi #define GOP_4G_SVM_HEND GOP_REG(GOP_4G_OFST, 0x0b) 325*53ee8cc1Swenshuai.xi #define GOP_4G_SVM_VSTR GOP_REG(GOP_4G_OFST, 0x0c) 326*53ee8cc1Swenshuai.xi #define GOP_4G_SVM_VEND GOP_REG(GOP_4G_OFST, 0x0d) 327*53ee8cc1Swenshuai.xi #define GOP_4G_RDMA_HT GOP_REG(GOP_4G_OFST, 0x0e) 328*53ee8cc1Swenshuai.xi #define GOP_4G_HS_PIPE GOP_REG(GOP_4G_OFST, 0x0f) 329*53ee8cc1Swenshuai.xi #define GOP_4G_SLOW GOP_REG(GOP_4G_OFST, 0x10) 330*53ee8cc1Swenshuai.xi #define GOP_4G_BRI GOP_REG(GOP_4G_OFST, 0x11) 331*53ee8cc1Swenshuai.xi #define GOP_4G_CON GOP_REG(GOP_4G_OFST, 0x12) 332*53ee8cc1Swenshuai.xi #define GOP_4G_BW GOP_REG(GOP_4G_OFST, 0x19) 333*53ee8cc1Swenshuai.xi #define GOP_4G_NEW_BW GOP_REG(GOP_4G_OFST, 0x1C) 334*53ee8cc1Swenshuai.xi #define GOP_4G_SRAM_BORROW GOP_REG(GOP_4G_OFST, 0x1D) 335*53ee8cc1Swenshuai.xi #define GOP_4G_3D_MIDDLE GOP_REG(GOP_4G_OFST, 0x1E) 336*53ee8cc1Swenshuai.xi #define GOP_4G_PRI0 GOP_REG(GOP_4G_OFST, 0x20) 337*53ee8cc1Swenshuai.xi #define GOP_4G_DUMMY_22 GOP_REG(GOP_4G_OFST, 0x22) 338*53ee8cc1Swenshuai.xi #define GOP_4G_BOT_HS GOP_REG(GOP_4G_OFST, 0x23) 339*53ee8cc1Swenshuai.xi #define GOP_4G_TRSCLR_L GOP_REG(GOP_4G_OFST, 0x24) 340*53ee8cc1Swenshuai.xi #define GOP_4G_TRSCLR_H GOP_REG(GOP_4G_OFST, 0x25) 341*53ee8cc1Swenshuai.xi #define GOP_4G_YUV_SWAP GOP_REG(GOP_4G_OFST, 0x28) 342*53ee8cc1Swenshuai.xi #define GOP_4G_STRCH_HSZ GOP_REG(GOP_4G_OFST, 0x30) 343*53ee8cc1Swenshuai.xi #define GOP_4G_STRCH_VSZ GOP_REG(GOP_4G_OFST, 0x31) 344*53ee8cc1Swenshuai.xi #define GOP_4G_STRCH_HSTR GOP_REG(GOP_4G_OFST, 0x32) 345*53ee8cc1Swenshuai.xi #define GOP_4G_STRCH_VSTR GOP_REG(GOP_4G_OFST, 0x34) 346*53ee8cc1Swenshuai.xi #define GOP_4G_HSTRCH GOP_REG(GOP_4G_OFST, 0x35) 347*53ee8cc1Swenshuai.xi #define GOP_4G_VSTRCH GOP_REG(GOP_4G_OFST, 0x36) 348*53ee8cc1Swenshuai.xi #define GOP_4G_HSTRCH_INI GOP_REG(GOP_4G_OFST, 0x38) 349*53ee8cc1Swenshuai.xi #define GOP_4G_VSTRCH_INI GOP_REG(GOP_4G_OFST, 0x39) 350*53ee8cc1Swenshuai.xi #define GOP_4G_HVSTRCHMD GOP_REG(GOP_4G_OFST, 0x3a) 351*53ee8cc1Swenshuai.xi #define GOP_4G_OLDADDR GOP_REG(GOP_4G_OFST, 0x3b) 352*53ee8cc1Swenshuai.xi #define GOP_4G_MULTI_ALPHA GOP_REG(GOP_4G_OFST, 0x3c) 353*53ee8cc1Swenshuai.xi #define GOP_4G_BANK_FWR GOP_REG(GOP_4G_OFST, 0x50) 354*53ee8cc1Swenshuai.xi #define GOP_4G_BANK_HVAILDSIZE GOP_REG(GOP_4G_OFST, 0x52) 355*53ee8cc1Swenshuai.xi #define GOP_4G_BANK_VVAILDSIZE GOP_REG(GOP_4G_OFST, 0x53) 356*53ee8cc1Swenshuai.xi #define GOP_4G_SCALING_H_OUTPUTSIZE GOP_REG(GOP_4G_OFST, 0x56) 357*53ee8cc1Swenshuai.xi #define GOP_4G_SCALING_HRATIO_L GOP_REG(GOP_4G_OFST, 0x59) //GOP scaling down ratio dst / out * 2^20 358*53ee8cc1Swenshuai.xi #define GOP_4G_SCALING_HRATIO_H GOP_REG(GOP_4G_OFST, 0x5A) 359*53ee8cc1Swenshuai.xi #define GOP_4G_SCALING_CFG GOP_REG(GOP_4G_OFST, 0x5B) 360*53ee8cc1Swenshuai.xi #define GOP_4G_SCALING_VRATIO_L GOP_REG(GOP_4G_OFST, 0x5C) //GOP scaling down ratio dst / out * 2^20 361*53ee8cc1Swenshuai.xi #define GOP_4G_SCALING_VRATIO_H GOP_REG(GOP_4G_OFST, 0x5D) 362*53ee8cc1Swenshuai.xi 363*53ee8cc1Swenshuai.xi 364*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK0_VOFFL GOP_REG(GOP_4G_OFST, 0x60) 365*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK0_VOFFH GOP_REG(GOP_4G_OFST, 0x61) 366*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK1_VOFFL GOP_REG(GOP_4G_OFST, 0x62) 367*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK1_VOFFH GOP_REG(GOP_4G_OFST, 0x63) 368*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK2_VOFFL GOP_REG(GOP_4G_OFST, 0x64) 369*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK2_VOFFH GOP_REG(GOP_4G_OFST, 0x65) 370*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK3_VOFFL GOP_REG(GOP_4G_OFST, 0x66) 371*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK3_VOFFH GOP_REG(GOP_4G_OFST, 0x67) 372*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK0_HOFF GOP_REG(GOP_4G_OFST, 0x70) 373*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK1_HOFF GOP_REG(GOP_4G_OFST, 0x71) 374*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK2_HOFF GOP_REG(GOP_4G_OFST, 0x72) 375*53ee8cc1Swenshuai.xi #define GOP_4G_RBLK3_HOFF GOP_REG(GOP_4G_OFST, 0x73) 376*53ee8cc1Swenshuai.xi #define GOP_4G_REGDMA_EN GOP_REG(GOP_4G_OFST, 0x78) 377*53ee8cc1Swenshuai.xi #define GOP_MUX_IPVOP __GOP_REG(0x77) 378*53ee8cc1Swenshuai.xi #define GOP_MUX_BYPASS __GOP_REG(0x7B) 379*53ee8cc1Swenshuai.xi #define GOP_MUX __GOP_REG(0x7E) 380*53ee8cc1Swenshuai.xi #define GOP_BAK_SEL __GOP_REG(0x7F) 381*53ee8cc1Swenshuai.xi 382*53ee8cc1Swenshuai.xi #define GOP_4G_GWIN0_CTRL(id) GOP_REG(GOP_4G_OFST+1, 0x00 + (0x20*((id)%MAX_GOP0_GWIN))) 383*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_RBLK_L(id) GOP_REG(GOP_4G_OFST+1, 0x01 + (0x20*((id)%MAX_GOP0_GWIN))) 384*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_RBLK_H(id) GOP_REG(GOP_4G_OFST+1, 0x02 + (0x20*((id)%MAX_GOP0_GWIN))) 385*53ee8cc1Swenshuai.xi #define GOP_4G_DEL_PIXEL(id) GOP_REG(GOP_4G_OFST+1, 0x03 + (0x20*((id)%MAX_GOP1_GWIN))) 386*53ee8cc1Swenshuai.xi #define GOP_4G_HSTR(id) GOP_REG(GOP_4G_OFST+1, 0x04 + (0x20*((id)%MAX_GOP0_GWIN))) 387*53ee8cc1Swenshuai.xi #define GOP_4G_HEND(id) GOP_REG(GOP_4G_OFST+1, 0x05 + (0x20*((id)%MAX_GOP0_GWIN))) 388*53ee8cc1Swenshuai.xi #define GOP_4G_VSTR(id) GOP_REG(GOP_4G_OFST+1, 0x06 + (0x20*((id)%MAX_GOP0_GWIN))) 389*53ee8cc1Swenshuai.xi #define GOP_4G_GWIN_MIDDLE(id) GOP_REG(GOP_4G_OFST+1, 0x07 + (0x20*((id)%MAX_GOP0_GWIN))) 390*53ee8cc1Swenshuai.xi #define GOP_4G_VEND(id) GOP_REG(GOP_4G_OFST+1, 0x08 + (0x20*((id)%MAX_GOP0_GWIN))) 391*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_RBLK_HSIZE(id) GOP_REG(GOP_4G_OFST+1, 0x09 + (0x20*((id)%MAX_GOP0_GWIN))) 392*53ee8cc1Swenshuai.xi #define GOP_4G_GWIN_ALPHA01(id) GOP_REG(GOP_4G_OFST+1, 0x0A + (0x20*((id)%MAX_GOP0_GWIN))) 393*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_VSTR_L(id) GOP_REG(GOP_4G_OFST+1, 0x0C + (0x20*((id)%MAX_GOP0_GWIN))) 394*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_VSTR_H(id) GOP_REG(GOP_4G_OFST+1, 0x0D + (0x20*((id)%MAX_GOP0_GWIN))) 395*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_HSTR(id) GOP_REG(GOP_4G_OFST+1, 0x0E + (0x20*((id)%MAX_GOP0_GWIN))) 396*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_RBLK_SIZE_L(id) GOP_REG(GOP_4G_OFST+1, 0x10 + (0x20*((id)%MAX_GOP0_GWIN))) 397*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_RBLK_SIZE_H(id) GOP_REG(GOP_4G_OFST+1, 0x11 + (0x20*((id)%MAX_GOP0_GWIN))) 398*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_RLEN_L(id) GOP_REG(GOP_4G_OFST+1, 0x12 + (0x20*((id)%MAX_GOP0_GWIN))) 399*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_RLEN_H(id) GOP_REG(GOP_4G_OFST+1, 0x13 + (0x20*((id)%MAX_GOP0_GWIN))) 400*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_HVSTOP_L(id) GOP_REG(GOP_4G_OFST+1, 0x14 + (0x20*((id)%MAX_GOP0_GWIN))) 401*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_HVSTOP_H(id) GOP_REG(GOP_4G_OFST+1, 0x15 + (0x20*((id)%MAX_GOP0_GWIN))) 402*53ee8cc1Swenshuai.xi #define GOP_4G_DRAM_FADE(id) GOP_REG(GOP_4G_OFST+1, 0x16 + (0x20*((id)%MAX_GOP0_GWIN))) 403*53ee8cc1Swenshuai.xi #define GOP_4G_BG_CLR(id) GOP_REG(GOP_4G_OFST+1, 0x18 + (0x20*((id)%MAX_GOP0_GWIN))) 404*53ee8cc1Swenshuai.xi #define GOP_4G_BG_HSTR(id) GOP_REG(GOP_4G_OFST+1, 0x19 + (0x20*((id)%MAX_GOP0_GWIN))) 405*53ee8cc1Swenshuai.xi #define GOP_4G_BG_HEND(id) GOP_REG(GOP_4G_OFST+1, 0x1a + (0x20*((id)%MAX_GOP0_GWIN))) 406*53ee8cc1Swenshuai.xi #define GOP_4G_BG_VSTR(id) GOP_REG(GOP_4G_OFST+1, 0x1C + (0x20*((id)%MAX_GOP0_GWIN))) 407*53ee8cc1Swenshuai.xi #define GOP_4G_BG_VEND(id) GOP_REG(GOP_4G_OFST+1, 0x1D + (0x20*((id)%MAX_GOP0_GWIN))) 408*53ee8cc1Swenshuai.xi #define GOP_4G_3DOSD_SUB_RBLK_L(id) GOP_REG(GOP_4G_OFST+1, 0x1E + (0x20*((id)%MAX_GOP0_GWIN))) 409*53ee8cc1Swenshuai.xi #define GOP_4G_3DOSD_SUB_RBLK_H(id) GOP_REG(GOP_4G_OFST+1, 0x1F + (0x20*((id)%MAX_GOP0_GWIN))) 410*53ee8cc1Swenshuai.xi 411*53ee8cc1Swenshuai.xi 412*53ee8cc1Swenshuai.xi #define GOP_2G_CTRL0 GOP_REG(GOP_2G_OFST, 0x00) 413*53ee8cc1Swenshuai.xi #define GOP_2G_CTRL1 GOP_REG(GOP_2G_OFST, 0x01) 414*53ee8cc1Swenshuai.xi #define GOP_2G_RATE GOP_REG(GOP_2G_OFST, 0x02) 415*53ee8cc1Swenshuai.xi #define GOP_2G_PALDATA_L GOP_REG(GOP_2G_OFST, 0x03) 416*53ee8cc1Swenshuai.xi #define GOP_2G_PALDATA_H GOP_REG(GOP_2G_OFST, 0x04) 417*53ee8cc1Swenshuai.xi #define GOP_2G_PALCTRL GOP_REG(GOP_2G_OFST, 0x05) 418*53ee8cc1Swenshuai.xi #define GOP_2G_REGDMA_END GOP_REG(GOP_2G_OFST, 0x06) 419*53ee8cc1Swenshuai.xi #define GOP_2G_REGDMA_STR GOP_REG(GOP_2G_OFST, 0x07) 420*53ee8cc1Swenshuai.xi #define GOP_2G_INT GOP_REG(GOP_2G_OFST, 0x08) 421*53ee8cc1Swenshuai.xi #define GOP_2G_HWSTATE GOP_REG(GOP_2G_OFST, 0x09) 422*53ee8cc1Swenshuai.xi #define GOP_2G_RDMA_HT GOP_REG(GOP_2G_OFST, 0x0e) 423*53ee8cc1Swenshuai.xi #define GOP_2G_HS_PIPE GOP_REG(GOP_2G_OFST, 0x0f) 424*53ee8cc1Swenshuai.xi #define GOP_2G_SLOW GOP_REG(GOP_2G_OFST, 0x10) 425*53ee8cc1Swenshuai.xi #define GOP_2G_BRI GOP_REG(GOP_2G_OFST, 0x11) 426*53ee8cc1Swenshuai.xi #define GOP_2G_CON GOP_REG(GOP_2G_OFST, 0x12) 427*53ee8cc1Swenshuai.xi #define GOP_2G_BW GOP_REG(GOP_2G_OFST, 0x19) 428*53ee8cc1Swenshuai.xi #define GOP_2G_3D_MIDDLE GOP_REG(GOP_2G_OFST, 0x1E) 429*53ee8cc1Swenshuai.xi #define GOP_2G_PRI0 GOP_REG(GOP_2G_OFST, 0x20) 430*53ee8cc1Swenshuai.xi #define GOP_2G_TRSCLR_L GOP_REG(GOP_2G_OFST, 0x24) 431*53ee8cc1Swenshuai.xi #define GOP_2G_TRSCLR_H GOP_REG(GOP_2G_OFST, 0x25) 432*53ee8cc1Swenshuai.xi #define GOP_2G_STRCH_HSZ GOP_REG(GOP_2G_OFST, 0x30) 433*53ee8cc1Swenshuai.xi #define GOP_2G_STRCH_VSZ GOP_REG(GOP_2G_OFST, 0x31) 434*53ee8cc1Swenshuai.xi #define GOP_2G_STRCH_HSTR GOP_REG(GOP_2G_OFST, 0x32) 435*53ee8cc1Swenshuai.xi #define GOP_2G_STRCH_VSTR GOP_REG(GOP_2G_OFST, 0x34) 436*53ee8cc1Swenshuai.xi #define GOP_2G_HSTRCH GOP_REG(GOP_2G_OFST, 0x35) 437*53ee8cc1Swenshuai.xi #define GOP_2G_VSTRCH GOP_REG(GOP_2G_OFST, 0x36) 438*53ee8cc1Swenshuai.xi #define GOP_2G_HSTRCH_INI GOP_REG(GOP_2G_OFST, 0x38) 439*53ee8cc1Swenshuai.xi #define GOP_2G_VSTRCH_INI GOP_REG(GOP_2G_OFST, 0x39) 440*53ee8cc1Swenshuai.xi #define GOP_2G_HVStrch_MD GOP_REG(GOP_2G_OFST, 0x3a) 441*53ee8cc1Swenshuai.xi #define GOP_2G_OLDADDR GOP_REG(GOP_2G_OFST, 0x3b) 442*53ee8cc1Swenshuai.xi #define GOP_2G_MULTI_ALPHA GOP_REG(GOP_2G_OFST, 0x3c) 443*53ee8cc1Swenshuai.xi #define GOP_2G_REGDMA_EN GOP_REG(GOP_2G_OFST, 0x78) 444*53ee8cc1Swenshuai.xi 445*53ee8cc1Swenshuai.xi 446*53ee8cc1Swenshuai.xi #define GOP_2G_GWIN0_CTRL(id) GOP_REG(GOP_2G_OFST+1, 0x00 + (0x20*((id)%MAX_GOP1_GWIN))) 447*53ee8cc1Swenshuai.xi #define GOP_2G_GWIN_CTRL(id) GOP_REG(GOP_2G_OFST+1, 0x00 + (0x20*((id)%MAX_GOP1_GWIN))) 448*53ee8cc1Swenshuai.xi #define GOP_2G_DRAM_RBLK_L(id) GOP_REG(GOP_2G_OFST+1, 0x01 + (0x20*((id)%MAX_GOP1_GWIN))) 449*53ee8cc1Swenshuai.xi #define GOP_2G_DRAM_RBLK_H(id) GOP_REG(GOP_2G_OFST+1, 0x02 + (0x20*((id)%MAX_GOP1_GWIN))) 450*53ee8cc1Swenshuai.xi #define GOP_2G_DEL_PIXEL(id) GOP_REG(GOP_2G_OFST+1, 0x03 + (0x20*((id)%MAX_GOP1_GWIN))) 451*53ee8cc1Swenshuai.xi #define GOP_2G_HSTR(id) GOP_REG(GOP_2G_OFST+1, 0x04 + (0x20*((id)%MAX_GOP1_GWIN))) 452*53ee8cc1Swenshuai.xi #define GOP_2G_HEND(id) GOP_REG(GOP_2G_OFST+1, 0x05 + (0x20*((id)%MAX_GOP1_GWIN))) 453*53ee8cc1Swenshuai.xi #define GOP_2G_VSTR(id) GOP_REG(GOP_2G_OFST+1, 0x06 + (0x20*((id)%MAX_GOP1_GWIN))) 454*53ee8cc1Swenshuai.xi #define GOP_2G_VEND(id) GOP_REG(GOP_2G_OFST+1, 0x08 + (0x20*((id)%MAX_GOP1_GWIN))) 455*53ee8cc1Swenshuai.xi #define GOP_2G_DRAM_RBLK_HSIZE(id) GOP_REG(GOP_2G_OFST+1, 0x09 + (0x20*((id)%MAX_GOP1_GWIN))) 456*53ee8cc1Swenshuai.xi #define GOP_2G_GWIN_ALPHA01(id) GOP_REG(GOP_2G_OFST+1, 0x0A + (0x20*((id)%MAX_GOP1_GWIN))) 457*53ee8cc1Swenshuai.xi #define GOP_2G_DRAM_VSTR_L(id) GOP_REG(GOP_2G_OFST+1, 0x0C + (0x20*((id)%MAX_GOP1_GWIN))) 458*53ee8cc1Swenshuai.xi #define GOP_2G_DRAM_VSTR_H(id) GOP_REG(GOP_2G_OFST+1, 0x0D + (0x20*((id)%MAX_GOP1_GWIN))) 459*53ee8cc1Swenshuai.xi #define GOP_2G_DRAM_FADE(id) GOP_REG(GOP_2G_OFST+1, 0x16 + (0x20*((id)%MAX_GOP1_GWIN))) 460*53ee8cc1Swenshuai.xi #define GOP_2G_3DOSD_SUB_RBLK_L(id) GOP_REG(GOP_2G_OFST+1, 0x1E + (0x20*((id)%MAX_GOP1_GWIN))) 461*53ee8cc1Swenshuai.xi #define GOP_2G_3DOSD_SUB_RBLK_H(id) GOP_REG(GOP_2G_OFST+1, 0x1F + (0x20*((id)%MAX_GOP1_GWIN))) 462*53ee8cc1Swenshuai.xi 463*53ee8cc1Swenshuai.xi // DWIN reg 464*53ee8cc1Swenshuai.xi #define GOP_DW_CTL0_EN GOP_REG(GOP_DW_OFST, 0x00) 465*53ee8cc1Swenshuai.xi #define GOP_DWIN_EN (0x00) 466*53ee8cc1Swenshuai.xi #define GOP_DWIN_EN_VAL GOP_REG_VAL(GOP_DWIN_EN) 467*53ee8cc1Swenshuai.xi #define GOP_DWIN_SHOT (0x07) 468*53ee8cc1Swenshuai.xi #define GOP_DWIN_SHOT_VAL GOP_REG_VAL(GOP_DWIN_SHOT) 469*53ee8cc1Swenshuai.xi 470*53ee8cc1Swenshuai.xi #define GOP_DW_LSTR_WBE GOP_REG(GOP_DW_OFST, 0x01) 471*53ee8cc1Swenshuai.xi #define GOP_DW_INT_MASK GOP_REG(GOP_DW_OFST, 0x02) 472*53ee8cc1Swenshuai.xi #define GOP_DW_DEBUG GOP_REG(GOP_DW_OFST, 0x03) 473*53ee8cc1Swenshuai.xi #define GOP_DW_ALPHA GOP_REG(GOP_DW_OFST, 0x04) 474*53ee8cc1Swenshuai.xi #define GOP_DW_BW GOP_REG(GOP_DW_OFST, 0x05) 475*53ee8cc1Swenshuai.xi #define GOP_DW_VSTR GOP_REG(GOP_DW_OFST, 0x10) 476*53ee8cc1Swenshuai.xi #define GOP_DW_HSTR GOP_REG(GOP_DW_OFST, 0x11) 477*53ee8cc1Swenshuai.xi #define GOP_DW_VEND GOP_REG(GOP_DW_OFST, 0x12) 478*53ee8cc1Swenshuai.xi #define GOP_DW_HEND GOP_REG(GOP_DW_OFST, 0x13) 479*53ee8cc1Swenshuai.xi #define GOP_DW_HSIZE GOP_REG(GOP_DW_OFST, 0x14) 480*53ee8cc1Swenshuai.xi #define GOP_DW_JMPLEN GOP_REG(GOP_DW_OFST, 0x15) 481*53ee8cc1Swenshuai.xi #define GOP_DW_DSTR_L GOP_REG(GOP_DW_OFST, 0x16) 482*53ee8cc1Swenshuai.xi #define GOP_DW_DSTR_H GOP_REG(GOP_DW_OFST, 0x17) 483*53ee8cc1Swenshuai.xi #define GOP_DW_UB_L GOP_REG(GOP_DW_OFST, 0x18) 484*53ee8cc1Swenshuai.xi #define GOP_DW_UB_H GOP_REG(GOP_DW_OFST, 0x19) 485*53ee8cc1Swenshuai.xi 486*53ee8cc1Swenshuai.xi #define GOP_DW_PON_DSTR_L GOP_REG(GOP_DW_OFST, 0x1a) 487*53ee8cc1Swenshuai.xi #define GOP_DW_PON_DSTR_H GOP_REG(GOP_DW_OFST, 0x1b) 488*53ee8cc1Swenshuai.xi #define GOP_DW_PON_UB_L GOP_REG(GOP_DW_OFST, 0x1c) 489*53ee8cc1Swenshuai.xi #define GOP_DW_PON_UB_H GOP_REG(GOP_DW_OFST, 0x1d) 490*53ee8cc1Swenshuai.xi #define GOP_DW_FRAME_OFT_L GOP_REG(GOP_DW_OFST, 0x28) 491*53ee8cc1Swenshuai.xi #define GOP_DW_FRAME_OFT_H GOP_REG(GOP_DW_OFST, 0x29) 492*53ee8cc1Swenshuai.xi #define GOP_DW_FRAME_CTRL GOP_REG(GOP_DW_OFST, 0x30) 493*53ee8cc1Swenshuai.xi 494*53ee8cc1Swenshuai.xi #define GOP_1G_CTRL0 GOP_REG(GOP_1G_OFST, 0x00) 495*53ee8cc1Swenshuai.xi #define GOP_1G_CTRL1 GOP_REG(GOP_1G_OFST, 0x01) 496*53ee8cc1Swenshuai.xi #define GOP_1G_RATE GOP_REG(GOP_1G_OFST, 0x02) 497*53ee8cc1Swenshuai.xi #define GOP_1G_PALDATA_L GOP_REG(GOP_1G_OFST, 0x03) 498*53ee8cc1Swenshuai.xi #define GOP_1G_PALDATA_H GOP_REG(GOP_1G_OFST, 0x04) 499*53ee8cc1Swenshuai.xi #define GOP_1G_PALCTRL GOP_REG(GOP_1G_OFST, 0x05) 500*53ee8cc1Swenshuai.xi #define GOP_1G_REGDMA_END GOP_REG(GOP_1G_OFST, 0x06) 501*53ee8cc1Swenshuai.xi #define GOP_1G_REGDMA_STR GOP_REG(GOP_1G_OFST, 0x07) 502*53ee8cc1Swenshuai.xi #define GOP_1G_INT GOP_REG(GOP_1G_OFST, 0x08) 503*53ee8cc1Swenshuai.xi #define GOP_1G_HWSTATE GOP_REG(GOP_1G_OFST, 0x09) 504*53ee8cc1Swenshuai.xi #define GOP_1G_RDMA_HT GOP_REG(GOP_1G_OFST, 0x0e) 505*53ee8cc1Swenshuai.xi #define GOP_1G_HS_PIPE GOP_REG(GOP_1G_OFST, 0x0f) 506*53ee8cc1Swenshuai.xi #define GOP_1G_BRI GOP_REG(GOP_1G_OFST, 0x11) 507*53ee8cc1Swenshuai.xi #define GOP_1G_CON GOP_REG(GOP_1G_OFST, 0x12) 508*53ee8cc1Swenshuai.xi #define GOP_1G_BW GOP_REG(GOP_1G_OFST, 0x19) 509*53ee8cc1Swenshuai.xi #define GOP_1G_3D_MIDDLE GOP_REG(GOP_1G_OFST, 0x1E) 510*53ee8cc1Swenshuai.xi #define GOP_1G_TRSCLR_L GOP_REG(GOP_1G_OFST, 0x24) 511*53ee8cc1Swenshuai.xi #define GOP_1G_TRSCLR_H GOP_REG(GOP_1G_OFST, 0x25) 512*53ee8cc1Swenshuai.xi #define GOP_1G_STRCH_HSZ GOP_REG(GOP_1G_OFST, 0x30) 513*53ee8cc1Swenshuai.xi #define GOP_1G_STRCH_VSZ GOP_REG(GOP_1G_OFST, 0x31) 514*53ee8cc1Swenshuai.xi #define GOP_1G_STRCH_HSTR GOP_REG(GOP_1G_OFST, 0x32) 515*53ee8cc1Swenshuai.xi #define GOP_1G_STRCH_VSTR GOP_REG(GOP_1G_OFST, 0x34) 516*53ee8cc1Swenshuai.xi #define GOP_1G_HSTRCH GOP_REG(GOP_1G_OFST, 0x35) 517*53ee8cc1Swenshuai.xi #define GOP_1G_HSTRCH_INI GOP_REG(GOP_1G_OFST, 0x38) 518*53ee8cc1Swenshuai.xi #define GOP_1G_VSTRCH_INI GOP_REG(GOP_1G_OFST, 0x39) 519*53ee8cc1Swenshuai.xi #define GOP_1G_HStrch_MD GOP_REG(GOP_1G_OFST, 0x3a) 520*53ee8cc1Swenshuai.xi #define GOP_1G_OLDADDR GOP_REG(GOP_1G_OFST, 0x3b) 521*53ee8cc1Swenshuai.xi #define GOP_1G_MULTI_ALPHA GOP_REG(GOP_1G_OFST, 0x3c) 522*53ee8cc1Swenshuai.xi 523*53ee8cc1Swenshuai.xi #define GOP_1G_GWIN0_CTRL GOP_REG(GOP_1G_OFST+1, 0x0) 524*53ee8cc1Swenshuai.xi #define GOP_1G_DRAM_RBLK_L GOP_REG(GOP_1G_OFST+1, 0x1) 525*53ee8cc1Swenshuai.xi #define GOP_1G_DRAM_RBLK_H GOP_REG(GOP_1G_OFST+1, 0x2) 526*53ee8cc1Swenshuai.xi #define GOP_1G_DEL_PIXEL GOP_REG(GOP_1G_OFST+1, 0x3) 527*53ee8cc1Swenshuai.xi #define GOP_1G_HSTR GOP_REG(GOP_1G_OFST+1, 0x4) 528*53ee8cc1Swenshuai.xi #define GOP_1G_HEND GOP_REG(GOP_1G_OFST+1, 0x5) 529*53ee8cc1Swenshuai.xi #define GOP_1G_VSTR GOP_REG(GOP_1G_OFST+1, 0x6) 530*53ee8cc1Swenshuai.xi #define GOP_1G_VEND GOP_REG(GOP_1G_OFST+1, 0x8) 531*53ee8cc1Swenshuai.xi #define GOP_1G_DRAM_RBLK_HSIZE GOP_REG(GOP_1G_OFST+1, 0x9) 532*53ee8cc1Swenshuai.xi #define GOP_1G_GWIN_ALPHA01 GOP_REG(GOP_1G_OFST+1, 0xA) 533*53ee8cc1Swenshuai.xi #define GOP_1G_DRAM_VSTR_L GOP_REG(GOP_1G_OFST+1, 0x0C) 534*53ee8cc1Swenshuai.xi #define GOP_1G_DRAM_VSTR_H GOP_REG(GOP_1G_OFST+1, 0x0D) 535*53ee8cc1Swenshuai.xi #define GOP_1G_DRAM_FADE GOP_REG(GOP_1G_OFST+1, 0x16) 536*53ee8cc1Swenshuai.xi #define GOP_1G_3DOSD_SUB_RBLK_L GOP_REG(GOP_1G_OFST+1, 0x1E) 537*53ee8cc1Swenshuai.xi #define GOP_1G_3DOSD_SUB_RBLK_H GOP_REG(GOP_1G_OFST+1, 0x1F) 538*53ee8cc1Swenshuai.xi 539*53ee8cc1Swenshuai.xi #define GOP_1GX_CTRL0 GOP_REG(GOP_1GX_OFST, 0x00) 540*53ee8cc1Swenshuai.xi #define GOP_1GX_CTRL1 GOP_REG(GOP_1GX_OFST, 0x01) 541*53ee8cc1Swenshuai.xi #define GOP_1GX_RATE GOP_REG(GOP_1GX_OFST, 0x02) 542*53ee8cc1Swenshuai.xi #define GOP_1GX_PALDATA_L GOP_REG(GOP_1GX_OFST, 0x03) 543*53ee8cc1Swenshuai.xi #define GOP_1GX_PALDATA_H GOP_REG(GOP_1GX_OFST, 0x04) 544*53ee8cc1Swenshuai.xi #define GOP_1GX_PALCTRL GOP_REG(GOP_1GX_OFST, 0x05) 545*53ee8cc1Swenshuai.xi #define GOP_1GX_REGDMA_END GOP_REG(GOP_1GX_OFST, 0x06) 546*53ee8cc1Swenshuai.xi #define GOP_1GX_REGDMA_STR GOP_REG(GOP_1GX_OFST, 0x07) 547*53ee8cc1Swenshuai.xi #define GOP_1GX_INT GOP_REG(GOP_1GX_OFST, 0x08) 548*53ee8cc1Swenshuai.xi #define GOP_1GX_HWSTATE GOP_REG(GOP_1GX_OFST, 0x09) 549*53ee8cc1Swenshuai.xi #define GOP_1GX_RDMA_HT GOP_REG(GOP_1GX_OFST, 0x0e) 550*53ee8cc1Swenshuai.xi #define GOP_1GX_HS_PIPE GOP_REG(GOP_1GX_OFST, 0x0f) 551*53ee8cc1Swenshuai.xi #define GOP_1GX_BRI GOP_REG(GOP_1GX_OFST, 0x11) 552*53ee8cc1Swenshuai.xi #define GOP_1GX_CON GOP_REG(GOP_1GX_OFST, 0x12) 553*53ee8cc1Swenshuai.xi #define GOP_1GX_BW GOP_REG(GOP_1GX_OFST, 0x19) 554*53ee8cc1Swenshuai.xi #define GOP_1GX_3D_MIDDLE GOP_REG(GOP_1GX_OFST, 0x1E) 555*53ee8cc1Swenshuai.xi #define GOP_1GX_TRSCLR_L GOP_REG(GOP_1GX_OFST, 0x24) 556*53ee8cc1Swenshuai.xi #define GOP_1GX_TRSCLR_H GOP_REG(GOP_1GX_OFST, 0x25) 557*53ee8cc1Swenshuai.xi #define GOP_1GX_STRCH_HSZ GOP_REG(GOP_1GX_OFST, 0x30) 558*53ee8cc1Swenshuai.xi #define GOP_1GX_STRCH_VSZ GOP_REG(GOP_1GX_OFST, 0x31) 559*53ee8cc1Swenshuai.xi #define GOP_1GX_STRCH_HSTR GOP_REG(GOP_1GX_OFST, 0x32) 560*53ee8cc1Swenshuai.xi #define GOP_1GX_STRCH_VSTR GOP_REG(GOP_1GX_OFST, 0x34) 561*53ee8cc1Swenshuai.xi #define GOP_1GX_HSTRCH GOP_REG(GOP_1GX_OFST, 0x35) 562*53ee8cc1Swenshuai.xi #define GOP_1GX_HSTRCH_INI GOP_REG(GOP_1GX_OFST, 0x38) 563*53ee8cc1Swenshuai.xi #define GOP_1GX_VSTRCH_INI GOP_REG(GOP_1GX_OFST, 0x39) 564*53ee8cc1Swenshuai.xi #define GOP_1GX_HStrch_MD GOP_REG(GOP_1GX_OFST, 0x3a) 565*53ee8cc1Swenshuai.xi #define GOP_1GX_OLDADDR GOP_REG(GOP_1GX_OFST, 0x3b) 566*53ee8cc1Swenshuai.xi #define GOP_1GX_MULTI_ALPHA GOP_REG(GOP_1GX_OFST, 0x3c) 567*53ee8cc1Swenshuai.xi 568*53ee8cc1Swenshuai.xi #define GOP_1GX_GWIN0_CTRL GOP_REG(GOP_1GX_OFST+1, 0x00) 569*53ee8cc1Swenshuai.xi #define GOP_1GX_DRAM_RBLK_L GOP_REG(GOP_1GX_OFST+1, 0x01) 570*53ee8cc1Swenshuai.xi #define GOP_1GX_DRAM_RBLK_H GOP_REG(GOP_1GX_OFST+1, 0x02) 571*53ee8cc1Swenshuai.xi #define GOP_1GX_DEL_PIXEL GOP_REG(GOP_1GX_OFST+1, 0x03) 572*53ee8cc1Swenshuai.xi #define GOP_1GX_HSTR GOP_REG(GOP_1GX_OFST+1, 0x04) 573*53ee8cc1Swenshuai.xi #define GOP_1GX_HEND GOP_REG(GOP_1GX_OFST+1, 0x05) 574*53ee8cc1Swenshuai.xi #define GOP_1GX_VSTR GOP_REG(GOP_1GX_OFST+1, 0x06) 575*53ee8cc1Swenshuai.xi #define GOP_1GX_VEND GOP_REG(GOP_1GX_OFST+1, 0x08) 576*53ee8cc1Swenshuai.xi #define GOP_1GX_DRAM_RBLK_HSIZE GOP_REG(GOP_1GX_OFST+1, 0x09) 577*53ee8cc1Swenshuai.xi #define GOP_1GX_GWIN_ALPHA01 GOP_REG(GOP_1GX_OFST+1, 0x0A) 578*53ee8cc1Swenshuai.xi #define GOP_1GX_DRAM_VSTR_L GOP_REG(GOP_1GX_OFST+1, 0x0C) 579*53ee8cc1Swenshuai.xi #define GOP_1GX_DRAM_VSTR_H GOP_REG(GOP_1GX_OFST+1, 0x0D) 580*53ee8cc1Swenshuai.xi #define GOP_1GX_DRAM_FADE GOP_REG(GOP_1GX_OFST+1, 0x16) 581*53ee8cc1Swenshuai.xi #define GOP_1GX_3DOSD_SUB_RBLK_L GOP_REG(GOP_1GX_OFST+1, 0x1E) 582*53ee8cc1Swenshuai.xi #define GOP_1GX_3DOSD_SUB_RBLK_H GOP_REG(GOP_1GX_OFST+1, 0x1F) 583*53ee8cc1Swenshuai.xi 584*53ee8cc1Swenshuai.xi #define GOP_1GS0_CTRL0 GOP_REG(GOP_1GS0_OFST, 0x00) 585*53ee8cc1Swenshuai.xi #define GOP_1GS0_CTRL1 GOP_REG(GOP_1GS0_OFST, 0x01) 586*53ee8cc1Swenshuai.xi #define GOP_1GS0_RATE GOP_REG(GOP_1GS0_OFST, 0x02) 587*53ee8cc1Swenshuai.xi #define GOP_1GS0_PALDATA_L GOP_REG(GOP_1GS0_OFST, 0x03) 588*53ee8cc1Swenshuai.xi #define GOP_1GS0_PALDATA_H GOP_REG(GOP_1GS0_OFST, 0x04) 589*53ee8cc1Swenshuai.xi #define GOP_1GS0_PALCTRL GOP_REG(GOP_1GS0_OFST, 0x05) 590*53ee8cc1Swenshuai.xi #define GOP_1GS0_REGDMA_END GOP_REG(GOP_1GS0_OFST, 0x06) 591*53ee8cc1Swenshuai.xi #define GOP_1GS0_REGDMA_STR GOP_REG(GOP_1GS0_OFST, 0x07) 592*53ee8cc1Swenshuai.xi #define GOP_1GS0_INT GOP_REG(GOP_1GS0_OFST, 0x08) 593*53ee8cc1Swenshuai.xi #define GOP_1GS0_HWSTATE GOP_REG(GOP_1GS0_OFST, 0x09) 594*53ee8cc1Swenshuai.xi #define GOP_1GS0_RDMA_HT GOP_REG(GOP_1GS0_OFST, 0x0e) 595*53ee8cc1Swenshuai.xi #define GOP_1GS0_HS_PIPE GOP_REG(GOP_1GS0_OFST, 0x0f) 596*53ee8cc1Swenshuai.xi #define GOP_1GS0_BRI GOP_REG(GOP_1GS0_OFST, 0x11) 597*53ee8cc1Swenshuai.xi #define GOP_1GS0_CON GOP_REG(GOP_1GS0_OFST, 0x12) 598*53ee8cc1Swenshuai.xi #define GOP_1GS0_BW GOP_REG(GOP_1GS0_OFST, 0x19) 599*53ee8cc1Swenshuai.xi #define GOP_1GS0_TRSCLR_L GOP_REG(GOP_1GS0_OFST, 0x24) 600*53ee8cc1Swenshuai.xi #define GOP_1GS0_TRSCLR_H GOP_REG(GOP_1GS0_OFST, 0x25) 601*53ee8cc1Swenshuai.xi #define GOP_1GS0_STRCH_HSZ GOP_REG(GOP_1GS0_OFST, 0x30) 602*53ee8cc1Swenshuai.xi #define GOP_1GS0_STRCH_VSZ GOP_REG(GOP_1GS0_OFST, 0x31) 603*53ee8cc1Swenshuai.xi #define GOP_1GS0_STRCH_HSTR GOP_REG(GOP_1GS0_OFST, 0x32) 604*53ee8cc1Swenshuai.xi #define GOP_1GS0_STRCH_VSTR GOP_REG(GOP_1GS0_OFST, 0x34) 605*53ee8cc1Swenshuai.xi #define GOP_1GS0_HSTRCH GOP_REG(GOP_1GS0_OFST, 0x35) 606*53ee8cc1Swenshuai.xi #define GOP_1GS0_HSTRCH_INI GOP_REG(GOP_1GS0_OFST, 0x38) 607*53ee8cc1Swenshuai.xi #define GOP_1GS0_VSTRCH_INI GOP_REG(GOP_1GS0_OFST, 0x39) 608*53ee8cc1Swenshuai.xi #define GOP_1GS0_HVStrch_MD GOP_REG(GOP_1GS0_OFST, 0x3a) 609*53ee8cc1Swenshuai.xi #define GOP_1GS0_OLDADDR GOP_REG(GOP_1GS0_OFST, 0x3b) 610*53ee8cc1Swenshuai.xi #define GOP_1GS0_MULTI_ALPHA GOP_REG(GOP_1GS0_OFST, 0x3c) 611*53ee8cc1Swenshuai.xi 612*53ee8cc1Swenshuai.xi #define GOP_1GS0_GWIN0_CTRL GOP_REG(GOP_1GS0_OFST+1, 0x00) 613*53ee8cc1Swenshuai.xi #define GOP_1GS0_DRAM_RBLK_L GOP_REG(GOP_1GS0_OFST+1, 0x01) 614*53ee8cc1Swenshuai.xi #define GOP_1GS0_DRAM_RBLK_H GOP_REG(GOP_1GS0_OFST+1, 0x02) 615*53ee8cc1Swenshuai.xi #define GOP_1GS0_DEL_PIXEL GOP_REG(GOP_1GS0_OFST+1, 0x03) 616*53ee8cc1Swenshuai.xi #define GOP_1GS0_HSTR GOP_REG(GOP_1GS0_OFST+1, 0x04) 617*53ee8cc1Swenshuai.xi #define GOP_1GS0_HEND GOP_REG(GOP_1GS0_OFST+1, 0x05) 618*53ee8cc1Swenshuai.xi #define GOP_1GS0_VSTR GOP_REG(GOP_1GS0_OFST+1, 0x06) 619*53ee8cc1Swenshuai.xi #define GOP_1GS0_VEND GOP_REG(GOP_1GS0_OFST+1, 0x08) 620*53ee8cc1Swenshuai.xi #define GOP_1GS0_DRAM_RBLK_HSIZE GOP_REG(GOP_1GS0_OFST+1, 0x09) 621*53ee8cc1Swenshuai.xi #define GOP_1GS0_GWIN_ALPHA01 GOP_REG(GOP_1GS0_OFST+1, 0x0A) 622*53ee8cc1Swenshuai.xi #define GOP_1GS0_DRAM_VSTR_L GOP_REG(GOP_1GS0_OFST+1, 0x0C) 623*53ee8cc1Swenshuai.xi #define GOP_1GS0_DRAM_VSTR_H GOP_REG(GOP_1GS0_OFST+1, 0x0D) 624*53ee8cc1Swenshuai.xi #define GOP_1GS0_DRAM_FADE GOP_REG(GOP_1GS0_OFST+1, 0x16) 625*53ee8cc1Swenshuai.xi #define GOP_1GS0_3DOSD_SUB_RBLK_L GOP_REG(GOP_1GS0_OFST+1, 0x1E) 626*53ee8cc1Swenshuai.xi #define GOP_1GS0_3DOSD_SUB_RBLK_H GOP_REG(GOP_1GS0_OFST+1, 0x1F) 627*53ee8cc1Swenshuai.xi 628*53ee8cc1Swenshuai.xi #define GOP_1GS1_CTRL0 GOP_REG(GOP_1GS1_OFST, 0x00) 629*53ee8cc1Swenshuai.xi #define GOP_1GS1_CTRL1 GOP_REG(GOP_1GS1_OFST, 0x01) 630*53ee8cc1Swenshuai.xi #define GOP_1GS1_RATE GOP_REG(GOP_1GS1_OFST, 0x02) 631*53ee8cc1Swenshuai.xi #define GOP_1GS1_PALDATA_L GOP_REG(GOP_1GS1_OFST, 0x03) 632*53ee8cc1Swenshuai.xi #define GOP_1GS1_PALDATA_H GOP_REG(GOP_1GS1_OFST, 0x04) 633*53ee8cc1Swenshuai.xi #define GOP_1GS1_PALCTRL GOP_REG(GOP_1GS1_OFST, 0x05) 634*53ee8cc1Swenshuai.xi #define GOP_1GS1_REGDMA_END GOP_REG(GOP_1GS1_OFST, 0x06) 635*53ee8cc1Swenshuai.xi #define GOP_1GS1_REGDMA_STR GOP_REG(GOP_1GS1_OFST, 0x07) 636*53ee8cc1Swenshuai.xi #define GOP_1GS1_INT GOP_REG(GOP_1GS1_OFST, 0x08) 637*53ee8cc1Swenshuai.xi #define GOP_1GS1_HWSTATE GOP_REG(GOP_1GS1_OFST, 0x09) 638*53ee8cc1Swenshuai.xi #define GOP_1GS1_RDMA_HT GOP_REG(GOP_1GS1_OFST, 0x0e) 639*53ee8cc1Swenshuai.xi #define GOP_1GS1_HS_PIPE GOP_REG(GOP_1GS1_OFST, 0x0f) 640*53ee8cc1Swenshuai.xi #define GOP_1GS1_BRI GOP_REG(GOP_1GS1_OFST, 0x11) 641*53ee8cc1Swenshuai.xi #define GOP_1GS1_CON GOP_REG(GOP_1GS1_OFST, 0x12) 642*53ee8cc1Swenshuai.xi #define GOP_1GS1_BW GOP_REG(GOP_1GS1_OFST, 0x19) 643*53ee8cc1Swenshuai.xi #define GOP_1GS1_TRSCLR_L GOP_REG(GOP_1GS1_OFST, 0x24) 644*53ee8cc1Swenshuai.xi #define GOP_1GS1_TRSCLR_H GOP_REG(GOP_1GS1_OFST, 0x25) 645*53ee8cc1Swenshuai.xi #define GOP_1GS1_STRCH_HSZ GOP_REG(GOP_1GS1_OFST, 0x30) 646*53ee8cc1Swenshuai.xi #define GOP_1GS1_STRCH_VSZ GOP_REG(GOP_1GS1_OFST, 0x31) 647*53ee8cc1Swenshuai.xi #define GOP_1GS1_STRCH_HSTR GOP_REG(GOP_1GS1_OFST, 0x32) 648*53ee8cc1Swenshuai.xi #define GOP_1GS1_STRCH_VSTR GOP_REG(GOP_1GS1_OFST, 0x34) 649*53ee8cc1Swenshuai.xi #define GOP_1GS1_HSTRCH GOP_REG(GOP_1GS1_OFST, 0x35) 650*53ee8cc1Swenshuai.xi #define GOP_1GS1_HSTRCH_INI GOP_REG(GOP_1GS1_OFST, 0x38) 651*53ee8cc1Swenshuai.xi #define GOP_1GS1_VSTRCH_INI GOP_REG(GOP_1GS1_OFST, 0x39) 652*53ee8cc1Swenshuai.xi #define GOP_1GS1_HVStrch_MD GOP_REG(GOP_1GS1_OFST, 0x3a) 653*53ee8cc1Swenshuai.xi #define GOP_1GS1_OLDADDR GOP_REG(GOP_1GS1_OFST, 0x3b) 654*53ee8cc1Swenshuai.xi #define GOP_1GS1_MULTI_ALPHA GOP_REG(GOP_1GS1_OFST, 0x3c) 655*53ee8cc1Swenshuai.xi 656*53ee8cc1Swenshuai.xi #define GOP_1GS1_GWIN0_CTRL GOP_REG(GOP_1GS1_OFST+1, 0x00) 657*53ee8cc1Swenshuai.xi #define GOP_1GS1_DRAM_RBLK_L GOP_REG(GOP_1GS1_OFST+1, 0x01) 658*53ee8cc1Swenshuai.xi #define GOP_1GS1_DRAM_RBLK_H GOP_REG(GOP_1GS1_OFST+1, 0x02) 659*53ee8cc1Swenshuai.xi #define GOP_1GS1_DEL_PIXEL GOP_REG(GOP_1GS1_OFST+1, 0x03) 660*53ee8cc1Swenshuai.xi #define GOP_1GS1_HSTR GOP_REG(GOP_1GS1_OFST+1, 0x04) 661*53ee8cc1Swenshuai.xi #define GOP_1GS1_HEND GOP_REG(GOP_1GS1_OFST+1, 0x05) 662*53ee8cc1Swenshuai.xi #define GOP_1GS1_VSTR GOP_REG(GOP_1GS1_OFST+1, 0x06) 663*53ee8cc1Swenshuai.xi #define GOP_1GS1_VEND GOP_REG(GOP_1GS1_OFST+1, 0x08) 664*53ee8cc1Swenshuai.xi #define GOP_1GS1_DRAM_RBLK_HSIZE GOP_REG(GOP_1GS1_OFST+1, 0x09) 665*53ee8cc1Swenshuai.xi #define GOP_1GS1_GWIN_ALPHA01 GOP_REG(GOP_1GS1_OFST+1, 0x0A) 666*53ee8cc1Swenshuai.xi #define GOP_1GS1_DRAM_VSTR_L GOP_REG(GOP_1GS1_OFST+1, 0x0C) 667*53ee8cc1Swenshuai.xi #define GOP_1GS1_DRAM_VSTR_H GOP_REG(GOP_1GS1_OFST+1, 0x0D) 668*53ee8cc1Swenshuai.xi #define GOP_1GS1_DRAM_FADE GOP_REG(GOP_1GS1_OFST+1, 0x16) 669*53ee8cc1Swenshuai.xi #define GOP_1GS1_3DOSD_SUB_RBLK_L GOP_REG(GOP_1GS1_OFST+1, 0x1E) 670*53ee8cc1Swenshuai.xi #define GOP_1GS1_3DOSD_SUB_RBLK_H GOP_REG(GOP_1GS1_OFST+1, 0x1F) 671*53ee8cc1Swenshuai.xi //------------------------------------------------------------------------------------------------- 672*53ee8cc1Swenshuai.xi // Type and Structure 673*53ee8cc1Swenshuai.xi //------------------------------------------------------------------------------------------------- 674*53ee8cc1Swenshuai.xi 675*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 676*53ee8cc1Swenshuai.xi // GOP Test Pattern Reg 677*53ee8cc1Swenshuai.xi //---------------------------------------------------------------------------- 678*53ee8cc1Swenshuai.xi #define REG_TSTCLR_EN GOP_REG(GOP_4G_OFST, 0x00) 679*53ee8cc1Swenshuai.xi #define REG_TSTCLR_ALPHA_EN GOP_REG(GOP_4G_OFST+2, 0x00) 680*53ee8cc1Swenshuai.xi #define REG_TLB_TAG_ADDR_L GOP_REG(GOP_4G_OFST+2, 0x2C) 681*53ee8cc1Swenshuai.xi #define REG_TLB_TAG_ADDR_H GOP_REG(GOP_4G_OFST+2, 0x2D) 682*53ee8cc1Swenshuai.xi #define REG_TLB_TAG_ADDR_RVIEW_L GOP_REG(GOP_4G_OFST+2, 0x2E) 683*53ee8cc1Swenshuai.xi #define REG_TLB_TAG_ADDR_RVIEW_H GOP_REG(GOP_4G_OFST+2, 0x2F) 684*53ee8cc1Swenshuai.xi #define REG_TSTCLR_ALPHA GOP_REG(GOP_4G_OFST+2, 0x40) 685*53ee8cc1Swenshuai.xi #define REG_R_STC GOP_REG(GOP_4G_OFST+2, 0x41) 686*53ee8cc1Swenshuai.xi #define REG_G_STC GOP_REG(GOP_4G_OFST+2, 0x48) 687*53ee8cc1Swenshuai.xi #define REG_B_STC GOP_REG(GOP_4G_OFST+2, 0x49) 688*53ee8cc1Swenshuai.xi #define REG_TSTCLR_HDUP GOP_REG(GOP_4G_OFST+2, 0x01) 689*53ee8cc1Swenshuai.xi #define REG_TSTCLR_VDUP GOP_REG(GOP_4G_OFST+2, 0x01) 690*53ee8cc1Swenshuai.xi #define REG_HR_INC GOP_REG(GOP_4G_OFST+2, 0x42) 691*53ee8cc1Swenshuai.xi #define REG_HR_INC_SIGNZ GOP_REG(GOP_4G_OFST+2, 0x42) 692*53ee8cc1Swenshuai.xi #define REG_HG_INC GOP_REG(GOP_4G_OFST+2, 0x43) 693*53ee8cc1Swenshuai.xi #define REG_HG_INC_SIGNZ GOP_REG(GOP_4G_OFST+2, 0x43) 694*53ee8cc1Swenshuai.xi #define REG_HB_INC GOP_REG(GOP_4G_OFST+2, 0x44) 695*53ee8cc1Swenshuai.xi #define REG_HB_INC_SIGNZ GOP_REG(GOP_4G_OFST+2, 0x44) 696*53ee8cc1Swenshuai.xi #define REG_HR_STEP GOP_REG(GOP_4G_OFST+2, 0x4A) 697*53ee8cc1Swenshuai.xi #define REG_HG_STEP GOP_REG(GOP_4G_OFST+2, 0x4B) 698*53ee8cc1Swenshuai.xi #define REG_HB_STEP GOP_REG(GOP_4G_OFST+2, 0x4C) 699*53ee8cc1Swenshuai.xi #define REG_VR_INC GOP_REG(GOP_4G_OFST+2, 0x45) 700*53ee8cc1Swenshuai.xi #define REG_VR_INC_SIGNZ GOP_REG(GOP_4G_OFST+2, 0x45) 701*53ee8cc1Swenshuai.xi #define REG_VG_INC GOP_REG(GOP_4G_OFST+2, 0x46) 702*53ee8cc1Swenshuai.xi #define REG_VG_INC_SIGNZ GOP_REG(GOP_4G_OFST+2, 0x46) 703*53ee8cc1Swenshuai.xi #define REG_VB_INC GOP_REG(GOP_4G_OFST+2, 0x47) 704*53ee8cc1Swenshuai.xi #define REG_VB_INC_SIGNZ GOP_REG(GOP_4G_OFST+2, 0x47) 705*53ee8cc1Swenshuai.xi #define REG_VR_STEP GOP_REG(GOP_4G_OFST+2, 0x4D) 706*53ee8cc1Swenshuai.xi #define REG_VG_STEP GOP_REG(GOP_4G_OFST+2, 0x4E) 707*53ee8cc1Swenshuai.xi #define REG_VB_STEP GOP_REG(GOP_4G_OFST+2, 0x4F) 708*53ee8cc1Swenshuai.xi #define REG_TLB_BASE_ADDR_L GOP_REG(GOP_4G_OFST+2, 0x58) 709*53ee8cc1Swenshuai.xi #define REG_TLB_BASE_ADDR_H GOP_REG(GOP_4G_OFST+2, 0x59) 710*53ee8cc1Swenshuai.xi #define REG_TLB_BASE_ADDR_RVIEW_L GOP_REG(GOP_4G_OFST+2, 0x5A) 711*53ee8cc1Swenshuai.xi #define REG_TLB_BASE_ADDR_RVIEW_H GOP_REG(GOP_4G_OFST+2, 0x5B) 712*53ee8cc1Swenshuai.xi 713*53ee8cc1Swenshuai.xi #define MASK_TSTCLR_EN GOP_BIT6 714*53ee8cc1Swenshuai.xi #define MASK_TSTCLR_ALPHA_EN 0 715*53ee8cc1Swenshuai.xi #define MASK_TSTCLR_ALPHA 0 716*53ee8cc1Swenshuai.xi #define MASK_RGB_STC_VALID BMASK(1:0) 717*53ee8cc1Swenshuai.xi #define MASK_R_STC BMASK(9:8) 718*53ee8cc1Swenshuai.xi #define MASK_G_STC BMASK(11:10) 719*53ee8cc1Swenshuai.xi #define MASK_B_STC BMASK(1:0) 720*53ee8cc1Swenshuai.xi #define MASK_INI_TSTCLR_EN GOP_BIT15 721*53ee8cc1Swenshuai.xi #define MASK_TSTCLR_HDUP BMASK(9:8) 722*53ee8cc1Swenshuai.xi #define MASK_TSTCLR_VDUP BMASK(3:2) 723*53ee8cc1Swenshuai.xi #define MASK_HR_INC BMASK(14:8) 724*53ee8cc1Swenshuai.xi #define MASK_HR_INC_SIGNZ GOP_BIT15 725*53ee8cc1Swenshuai.xi #define MASK_HG_INC BMASK(6:0) 726*53ee8cc1Swenshuai.xi #define MASK_HG_INC_SIGNZ GOP_BIT7 727*53ee8cc1Swenshuai.xi #define MASK_HB_INC BMASK(6:0) 728*53ee8cc1Swenshuai.xi #define MASK_HB_INC_SIGNZ GOP_BIT7 729*53ee8cc1Swenshuai.xi #define MASK_HR_STEP BMASK(7:0) 730*53ee8cc1Swenshuai.xi #define MASK_HG_STEP BMASK(15:8) 731*53ee8cc1Swenshuai.xi #define MASK_HB_STEP BMASK(7:0) 732*53ee8cc1Swenshuai.xi #define MASK_VR_INC BMASK(14:8) 733*53ee8cc1Swenshuai.xi #define MASK_VR_INC_SIGNZ GOP_BIT4 734*53ee8cc1Swenshuai.xi #define MASK_VG_INC BMASK(6:0) 735*53ee8cc1Swenshuai.xi #define MASK_VG_INC_SIGNZ GOP_BIT7 736*53ee8cc1Swenshuai.xi #define MASK_VB_INC BMASK(14:8) 737*53ee8cc1Swenshuai.xi #define MASK_VB_INC_SIGNZ GOP_BIT15 738*53ee8cc1Swenshuai.xi #define MASK_VR_STEP BMASK(7:0) 739*53ee8cc1Swenshuai.xi #define MASK_VG_STEP BMASK(7:0) 740*53ee8cc1Swenshuai.xi #define MASK_VB_STEP BMASK(7:0) 741*53ee8cc1Swenshuai.xi 742*53ee8cc1Swenshuai.xi #define SHIFT_TSTCLR_EN 6 743*53ee8cc1Swenshuai.xi #define SHIFT_TSTCLR_ALPHA_EN 0 744*53ee8cc1Swenshuai.xi #define SHIFT_TSTCLR_ALPHA 0 745*53ee8cc1Swenshuai.xi #define SHIFT_R_STC 8 746*53ee8cc1Swenshuai.xi #define SHIFT_G_STC 10 747*53ee8cc1Swenshuai.xi #define SHIFT_B_STC 0 748*53ee8cc1Swenshuai.xi #define SHIFT_INI_TSTCLR_EN 15 749*53ee8cc1Swenshuai.xi #define SHIFT_TSTCLR_HDUP 8 750*53ee8cc1Swenshuai.xi #define SHIFT_TSTCLR_VDUP 2 751*53ee8cc1Swenshuai.xi #define SHIFT_HR_INC 8 752*53ee8cc1Swenshuai.xi #define SHIFT_HR_INC_SIGNZ 15 753*53ee8cc1Swenshuai.xi #define SHIFT_HG_INC 0 754*53ee8cc1Swenshuai.xi #define SHIFT_HG_INC_SIGNZ 7 755*53ee8cc1Swenshuai.xi #define SHIFT_HB_INC 0 756*53ee8cc1Swenshuai.xi #define SHIFT_HB_INC_SIGNZ 7 757*53ee8cc1Swenshuai.xi #define SHIFT_HR_STEP 0 758*53ee8cc1Swenshuai.xi #define SHIFT_HG_STEP 8 759*53ee8cc1Swenshuai.xi #define SHIFT_HB_STEP 0 760*53ee8cc1Swenshuai.xi #define SHIFT_VR_INC 8 761*53ee8cc1Swenshuai.xi #define SHIFT_VR_INC_SIGNZ 4 762*53ee8cc1Swenshuai.xi #define SHIFT_VG_INC 0 763*53ee8cc1Swenshuai.xi #define SHIFT_VG_INC_SIGNZ 7 764*53ee8cc1Swenshuai.xi #define SHIFT_VB_INC 8 765*53ee8cc1Swenshuai.xi #define SHIFT_VB_INC_SIGNZ 15 766*53ee8cc1Swenshuai.xi #define SHIFT_VR_STEP 0 767*53ee8cc1Swenshuai.xi #define SHIFT_VG_STEP 0 768*53ee8cc1Swenshuai.xi #define SHIFT_VB_STEP 0 769*53ee8cc1Swenshuai.xi #endif // _REG_GOP_H_ 770*53ee8cc1Swenshuai.xi 771