1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * Copyright 2011 Advanced Micro Devices, Inc. 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Permission is hereby granted, free of charge, to any person obtaining a 5*4882a593Smuzhiyun * copy of this software and associated documentation files (the "Software"), 6*4882a593Smuzhiyun * to deal in the Software without restriction, including without limitation 7*4882a593Smuzhiyun * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8*4882a593Smuzhiyun * and/or sell copies of the Software, and to permit persons to whom the 9*4882a593Smuzhiyun * Software is furnished to do so, subject to the following conditions: 10*4882a593Smuzhiyun * 11*4882a593Smuzhiyun * The above copyright notice and this permission notice (including the next 12*4882a593Smuzhiyun * paragraph) shall be included in all copies or substantial portions of the 13*4882a593Smuzhiyun * Software. 14*4882a593Smuzhiyun * 15*4882a593Smuzhiyun * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16*4882a593Smuzhiyun * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17*4882a593Smuzhiyun * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18*4882a593Smuzhiyun * THE COPYRIGHT HOLDER(S) AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR 19*4882a593Smuzhiyun * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 20*4882a593Smuzhiyun * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 21*4882a593Smuzhiyun * DEALINGS IN THE SOFTWARE. 22*4882a593Smuzhiyun * 23*4882a593Smuzhiyun * Authors: 24*4882a593Smuzhiyun * Alex Deucher <alexander.deucher@amd.com> 25*4882a593Smuzhiyun */ 26*4882a593Smuzhiyun 27*4882a593Smuzhiyun #include <linux/types.h> 28*4882a593Smuzhiyun #include <linux/bug.h> 29*4882a593Smuzhiyun #include <linux/kernel.h> 30*4882a593Smuzhiyun 31*4882a593Smuzhiyun const u32 si_default_state[] = 32*4882a593Smuzhiyun { 33*4882a593Smuzhiyun 0xc0066900, 34*4882a593Smuzhiyun 0x00000000, 35*4882a593Smuzhiyun 0x00000060, /* DB_RENDER_CONTROL */ 36*4882a593Smuzhiyun 0x00000000, /* DB_COUNT_CONTROL */ 37*4882a593Smuzhiyun 0x00000000, /* DB_DEPTH_VIEW */ 38*4882a593Smuzhiyun 0x0000002a, /* DB_RENDER_OVERRIDE */ 39*4882a593Smuzhiyun 0x00000000, /* DB_RENDER_OVERRIDE2 */ 40*4882a593Smuzhiyun 0x00000000, /* DB_HTILE_DATA_BASE */ 41*4882a593Smuzhiyun 42*4882a593Smuzhiyun 0xc0046900, 43*4882a593Smuzhiyun 0x00000008, 44*4882a593Smuzhiyun 0x00000000, /* DB_DEPTH_BOUNDS_MIN */ 45*4882a593Smuzhiyun 0x00000000, /* DB_DEPTH_BOUNDS_MAX */ 46*4882a593Smuzhiyun 0x00000000, /* DB_STENCIL_CLEAR */ 47*4882a593Smuzhiyun 0x00000000, /* DB_DEPTH_CLEAR */ 48*4882a593Smuzhiyun 49*4882a593Smuzhiyun 0xc0036900, 50*4882a593Smuzhiyun 0x0000000f, 51*4882a593Smuzhiyun 0x00000000, /* DB_DEPTH_INFO */ 52*4882a593Smuzhiyun 0x00000000, /* DB_Z_INFO */ 53*4882a593Smuzhiyun 0x00000000, /* DB_STENCIL_INFO */ 54*4882a593Smuzhiyun 55*4882a593Smuzhiyun 0xc0016900, 56*4882a593Smuzhiyun 0x00000080, 57*4882a593Smuzhiyun 0x00000000, /* PA_SC_WINDOW_OFFSET */ 58*4882a593Smuzhiyun 59*4882a593Smuzhiyun 0xc00d6900, 60*4882a593Smuzhiyun 0x00000083, 61*4882a593Smuzhiyun 0x0000ffff, /* PA_SC_CLIPRECT_RULE */ 62*4882a593Smuzhiyun 0x00000000, /* PA_SC_CLIPRECT_0_TL */ 63*4882a593Smuzhiyun 0x20002000, /* PA_SC_CLIPRECT_0_BR */ 64*4882a593Smuzhiyun 0x00000000, 65*4882a593Smuzhiyun 0x20002000, 66*4882a593Smuzhiyun 0x00000000, 67*4882a593Smuzhiyun 0x20002000, 68*4882a593Smuzhiyun 0x00000000, 69*4882a593Smuzhiyun 0x20002000, 70*4882a593Smuzhiyun 0xaaaaaaaa, /* PA_SC_EDGERULE */ 71*4882a593Smuzhiyun 0x00000000, /* PA_SU_HARDWARE_SCREEN_OFFSET */ 72*4882a593Smuzhiyun 0x0000000f, /* CB_TARGET_MASK */ 73*4882a593Smuzhiyun 0x0000000f, /* CB_SHADER_MASK */ 74*4882a593Smuzhiyun 75*4882a593Smuzhiyun 0xc0226900, 76*4882a593Smuzhiyun 0x00000094, 77*4882a593Smuzhiyun 0x80000000, /* PA_SC_VPORT_SCISSOR_0_TL */ 78*4882a593Smuzhiyun 0x20002000, /* PA_SC_VPORT_SCISSOR_0_BR */ 79*4882a593Smuzhiyun 0x80000000, 80*4882a593Smuzhiyun 0x20002000, 81*4882a593Smuzhiyun 0x80000000, 82*4882a593Smuzhiyun 0x20002000, 83*4882a593Smuzhiyun 0x80000000, 84*4882a593Smuzhiyun 0x20002000, 85*4882a593Smuzhiyun 0x80000000, 86*4882a593Smuzhiyun 0x20002000, 87*4882a593Smuzhiyun 0x80000000, 88*4882a593Smuzhiyun 0x20002000, 89*4882a593Smuzhiyun 0x80000000, 90*4882a593Smuzhiyun 0x20002000, 91*4882a593Smuzhiyun 0x80000000, 92*4882a593Smuzhiyun 0x20002000, 93*4882a593Smuzhiyun 0x80000000, 94*4882a593Smuzhiyun 0x20002000, 95*4882a593Smuzhiyun 0x80000000, 96*4882a593Smuzhiyun 0x20002000, 97*4882a593Smuzhiyun 0x80000000, 98*4882a593Smuzhiyun 0x20002000, 99*4882a593Smuzhiyun 0x80000000, 100*4882a593Smuzhiyun 0x20002000, 101*4882a593Smuzhiyun 0x80000000, 102*4882a593Smuzhiyun 0x20002000, 103*4882a593Smuzhiyun 0x80000000, 104*4882a593Smuzhiyun 0x20002000, 105*4882a593Smuzhiyun 0x80000000, 106*4882a593Smuzhiyun 0x20002000, 107*4882a593Smuzhiyun 0x80000000, 108*4882a593Smuzhiyun 0x20002000, 109*4882a593Smuzhiyun 0x00000000, /* PA_SC_VPORT_ZMIN_0 */ 110*4882a593Smuzhiyun 0x3f800000, /* PA_SC_VPORT_ZMAX_0 */ 111*4882a593Smuzhiyun 112*4882a593Smuzhiyun 0xc0026900, 113*4882a593Smuzhiyun 0x000000d9, 114*4882a593Smuzhiyun 0x00000000, /* CP_RINGID */ 115*4882a593Smuzhiyun 0x00000000, /* CP_VMID */ 116*4882a593Smuzhiyun 117*4882a593Smuzhiyun 0xc0046900, 118*4882a593Smuzhiyun 0x00000100, 119*4882a593Smuzhiyun 0xffffffff, /* VGT_MAX_VTX_INDX */ 120*4882a593Smuzhiyun 0x00000000, /* VGT_MIN_VTX_INDX */ 121*4882a593Smuzhiyun 0x00000000, /* VGT_INDX_OFFSET */ 122*4882a593Smuzhiyun 0x00000000, /* VGT_MULTI_PRIM_IB_RESET_INDX */ 123*4882a593Smuzhiyun 124*4882a593Smuzhiyun 0xc0046900, 125*4882a593Smuzhiyun 0x00000105, 126*4882a593Smuzhiyun 0x00000000, /* CB_BLEND_RED */ 127*4882a593Smuzhiyun 0x00000000, /* CB_BLEND_GREEN */ 128*4882a593Smuzhiyun 0x00000000, /* CB_BLEND_BLUE */ 129*4882a593Smuzhiyun 0x00000000, /* CB_BLEND_ALPHA */ 130*4882a593Smuzhiyun 131*4882a593Smuzhiyun 0xc0016900, 132*4882a593Smuzhiyun 0x000001e0, 133*4882a593Smuzhiyun 0x00000000, /* CB_BLEND0_CONTROL */ 134*4882a593Smuzhiyun 135*4882a593Smuzhiyun 0xc00e6900, 136*4882a593Smuzhiyun 0x00000200, 137*4882a593Smuzhiyun 0x00000000, /* DB_DEPTH_CONTROL */ 138*4882a593Smuzhiyun 0x00000000, /* DB_EQAA */ 139*4882a593Smuzhiyun 0x00cc0010, /* CB_COLOR_CONTROL */ 140*4882a593Smuzhiyun 0x00000210, /* DB_SHADER_CONTROL */ 141*4882a593Smuzhiyun 0x00010000, /* PA_CL_CLIP_CNTL */ 142*4882a593Smuzhiyun 0x00000004, /* PA_SU_SC_MODE_CNTL */ 143*4882a593Smuzhiyun 0x00000100, /* PA_CL_VTE_CNTL */ 144*4882a593Smuzhiyun 0x00000000, /* PA_CL_VS_OUT_CNTL */ 145*4882a593Smuzhiyun 0x00000000, /* PA_CL_NANINF_CNTL */ 146*4882a593Smuzhiyun 0x00000000, /* PA_SU_LINE_STIPPLE_CNTL */ 147*4882a593Smuzhiyun 0x00000000, /* PA_SU_LINE_STIPPLE_SCALE */ 148*4882a593Smuzhiyun 0x00000000, /* PA_SU_PRIM_FILTER_CNTL */ 149*4882a593Smuzhiyun 0x00000000, /* */ 150*4882a593Smuzhiyun 0x00000000, /* */ 151*4882a593Smuzhiyun 152*4882a593Smuzhiyun 0xc0116900, 153*4882a593Smuzhiyun 0x00000280, 154*4882a593Smuzhiyun 0x00000000, /* PA_SU_POINT_SIZE */ 155*4882a593Smuzhiyun 0x00000000, /* PA_SU_POINT_MINMAX */ 156*4882a593Smuzhiyun 0x00000008, /* PA_SU_LINE_CNTL */ 157*4882a593Smuzhiyun 0x00000000, /* PA_SC_LINE_STIPPLE */ 158*4882a593Smuzhiyun 0x00000000, /* VGT_OUTPUT_PATH_CNTL */ 159*4882a593Smuzhiyun 0x00000000, /* VGT_HOS_CNTL */ 160*4882a593Smuzhiyun 0x00000000, 161*4882a593Smuzhiyun 0x00000000, 162*4882a593Smuzhiyun 0x00000000, 163*4882a593Smuzhiyun 0x00000000, 164*4882a593Smuzhiyun 0x00000000, 165*4882a593Smuzhiyun 0x00000000, 166*4882a593Smuzhiyun 0x00000000, 167*4882a593Smuzhiyun 0x00000000, 168*4882a593Smuzhiyun 0x00000000, 169*4882a593Smuzhiyun 0x00000000, 170*4882a593Smuzhiyun 0x00000000, /* VGT_GS_MODE */ 171*4882a593Smuzhiyun 172*4882a593Smuzhiyun 0xc0026900, 173*4882a593Smuzhiyun 0x00000292, 174*4882a593Smuzhiyun 0x00000000, /* PA_SC_MODE_CNTL_0 */ 175*4882a593Smuzhiyun 0x00000000, /* PA_SC_MODE_CNTL_1 */ 176*4882a593Smuzhiyun 177*4882a593Smuzhiyun 0xc0016900, 178*4882a593Smuzhiyun 0x000002a1, 179*4882a593Smuzhiyun 0x00000000, /* VGT_PRIMITIVEID_EN */ 180*4882a593Smuzhiyun 181*4882a593Smuzhiyun 0xc0016900, 182*4882a593Smuzhiyun 0x000002a5, 183*4882a593Smuzhiyun 0x00000000, /* VGT_MULTI_PRIM_IB_RESET_EN */ 184*4882a593Smuzhiyun 185*4882a593Smuzhiyun 0xc0026900, 186*4882a593Smuzhiyun 0x000002a8, 187*4882a593Smuzhiyun 0x00000000, /* VGT_INSTANCE_STEP_RATE_0 */ 188*4882a593Smuzhiyun 0x00000000, 189*4882a593Smuzhiyun 190*4882a593Smuzhiyun 0xc0026900, 191*4882a593Smuzhiyun 0x000002ad, 192*4882a593Smuzhiyun 0x00000000, /* VGT_REUSE_OFF */ 193*4882a593Smuzhiyun 0x00000000, 194*4882a593Smuzhiyun 195*4882a593Smuzhiyun 0xc0016900, 196*4882a593Smuzhiyun 0x000002d5, 197*4882a593Smuzhiyun 0x00000000, /* VGT_SHADER_STAGES_EN */ 198*4882a593Smuzhiyun 199*4882a593Smuzhiyun 0xc0016900, 200*4882a593Smuzhiyun 0x000002dc, 201*4882a593Smuzhiyun 0x0000aa00, /* DB_ALPHA_TO_MASK */ 202*4882a593Smuzhiyun 203*4882a593Smuzhiyun 0xc0066900, 204*4882a593Smuzhiyun 0x000002de, 205*4882a593Smuzhiyun 0x00000000, /* PA_SU_POLY_OFFSET_DB_FMT_CNTL */ 206*4882a593Smuzhiyun 0x00000000, 207*4882a593Smuzhiyun 0x00000000, 208*4882a593Smuzhiyun 0x00000000, 209*4882a593Smuzhiyun 0x00000000, 210*4882a593Smuzhiyun 0x00000000, 211*4882a593Smuzhiyun 212*4882a593Smuzhiyun 0xc0026900, 213*4882a593Smuzhiyun 0x000002e5, 214*4882a593Smuzhiyun 0x00000000, /* VGT_STRMOUT_CONFIG */ 215*4882a593Smuzhiyun 0x00000000, 216*4882a593Smuzhiyun 217*4882a593Smuzhiyun 0xc01b6900, 218*4882a593Smuzhiyun 0x000002f5, 219*4882a593Smuzhiyun 0x76543210, /* PA_SC_CENTROID_PRIORITY_0 */ 220*4882a593Smuzhiyun 0xfedcba98, /* PA_SC_CENTROID_PRIORITY_1 */ 221*4882a593Smuzhiyun 0x00000000, /* PA_SC_LINE_CNTL */ 222*4882a593Smuzhiyun 0x00000000, /* PA_SC_AA_CONFIG */ 223*4882a593Smuzhiyun 0x00000005, /* PA_SU_VTX_CNTL */ 224*4882a593Smuzhiyun 0x3f800000, /* PA_CL_GB_VERT_CLIP_ADJ */ 225*4882a593Smuzhiyun 0x3f800000, /* PA_CL_GB_VERT_DISC_ADJ */ 226*4882a593Smuzhiyun 0x3f800000, /* PA_CL_GB_HORZ_CLIP_ADJ */ 227*4882a593Smuzhiyun 0x3f800000, /* PA_CL_GB_HORZ_DISC_ADJ */ 228*4882a593Smuzhiyun 0x00000000, /* PA_SC_AA_SAMPLE_LOCS_PIXEL_X0Y0_0 */ 229*4882a593Smuzhiyun 0x00000000, 230*4882a593Smuzhiyun 0x00000000, 231*4882a593Smuzhiyun 0x00000000, 232*4882a593Smuzhiyun 0x00000000, 233*4882a593Smuzhiyun 0x00000000, 234*4882a593Smuzhiyun 0x00000000, 235*4882a593Smuzhiyun 0x00000000, 236*4882a593Smuzhiyun 0x00000000, 237*4882a593Smuzhiyun 0x00000000, 238*4882a593Smuzhiyun 0x00000000, 239*4882a593Smuzhiyun 0x00000000, 240*4882a593Smuzhiyun 0x00000000, 241*4882a593Smuzhiyun 0x00000000, 242*4882a593Smuzhiyun 0x00000000, 243*4882a593Smuzhiyun 0x00000000, 244*4882a593Smuzhiyun 0xffffffff, /* PA_SC_AA_MASK_X0Y0_X1Y0 */ 245*4882a593Smuzhiyun 0xffffffff, 246*4882a593Smuzhiyun 247*4882a593Smuzhiyun 0xc0026900, 248*4882a593Smuzhiyun 0x00000316, 249*4882a593Smuzhiyun 0x0000000e, /* VGT_VERTEX_REUSE_BLOCK_CNTL */ 250*4882a593Smuzhiyun 0x00000010, /* */ 251*4882a593Smuzhiyun }; 252*4882a593Smuzhiyun 253*4882a593Smuzhiyun const u32 si_default_size = ARRAY_SIZE(si_default_state); 254