Subversion Repositories Kolibri OS

Rev

Blame | Last modification | View Log | Download | RSS feed

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