Subversion Repositories Kolibri OS

Rev

Blame | Last modification | View Log | RSS feed

  1. /*
  2.  * Mesa 3-D graphics library
  3.  *
  4.  * Copyright (C) 2012-2013 LunarG, Inc.
  5.  *
  6.  * Permission is hereby granted, free of charge, to any person obtaining a
  7.  * copy of this software and associated documentation files (the "Software"),
  8.  * to deal in the Software without restriction, including without limitation
  9.  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  10.  * and/or sell copies of the Software, and to permit persons to whom the
  11.  * Software is furnished to do so, subject to the following conditions:
  12.  *
  13.  * The above copyright notice and this permission notice shall be included
  14.  * in all copies or substantial portions of the Software.
  15.  *
  16.  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  17.  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  18.  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
  19.  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  20.  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  21.  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  22.  * DEALINGS IN THE SOFTWARE.
  23.  *
  24.  * Authors:
  25.  *    Chia-I Wu <olv@lunarg.com>
  26.  */
  27.  
  28. #include "genhw/genhw.h"
  29. #include "ilo_format.h"
  30.  
  31. struct ilo_vf_cap {
  32.    int vertex_element;
  33. };
  34.  
  35. struct ilo_sol_cap {
  36.    int buffer;
  37. };
  38.  
  39. struct ilo_sampler_cap {
  40.    int sampling;
  41.    int filtering;
  42.    int shadow_map;
  43.    int chroma_key;
  44. };
  45.  
  46. struct ilo_dp_cap {
  47.    int rt_write;
  48.    int rt_write_blending;
  49.    int typed_write;
  50.    int media_color_processing;
  51. };
  52.  
  53. /*
  54.  * This table is based on:
  55.  *
  56.  *  - the Sandy Bridge PRM, volume 4 part 1, page 88-97
  57.  *  - the Ivy Bridge PRM, volume 2 part 1, page 97-99
  58.  *  - the Haswell PRM, volume 7, page 467-470
  59.  */
  60. static const struct ilo_vf_cap ilo_vf_caps[] = {
  61. #define CAP(vertex_element) { ILO_GEN(vertex_element) }
  62.    [GEN6_FORMAT_R32G32B32A32_FLOAT]       = CAP(  1),
  63.    [GEN6_FORMAT_R32G32B32A32_SINT]        = CAP(  1),
  64.    [GEN6_FORMAT_R32G32B32A32_UINT]        = CAP(  1),
  65.    [GEN6_FORMAT_R32G32B32A32_UNORM]       = CAP(  1),
  66.    [GEN6_FORMAT_R32G32B32A32_SNORM]       = CAP(  1),
  67.    [GEN6_FORMAT_R64G64_FLOAT]             = CAP(  1),
  68.    [GEN6_FORMAT_R32G32B32A32_SSCALED]     = CAP(  1),
  69.    [GEN6_FORMAT_R32G32B32A32_USCALED]     = CAP(  1),
  70.    [GEN6_FORMAT_R32G32B32A32_SFIXED]      = CAP(7.5),
  71.    [GEN6_FORMAT_R32G32B32_FLOAT]          = CAP(  1),
  72.    [GEN6_FORMAT_R32G32B32_SINT]           = CAP(  1),
  73.    [GEN6_FORMAT_R32G32B32_UINT]           = CAP(  1),
  74.    [GEN6_FORMAT_R32G32B32_UNORM]          = CAP(  1),
  75.    [GEN6_FORMAT_R32G32B32_SNORM]          = CAP(  1),
  76.    [GEN6_FORMAT_R32G32B32_SSCALED]        = CAP(  1),
  77.    [GEN6_FORMAT_R32G32B32_USCALED]        = CAP(  1),
  78.    [GEN6_FORMAT_R32G32B32_SFIXED]         = CAP(7.5),
  79.    [GEN6_FORMAT_R16G16B16A16_UNORM]       = CAP(  1),
  80.    [GEN6_FORMAT_R16G16B16A16_SNORM]       = CAP(  1),
  81.    [GEN6_FORMAT_R16G16B16A16_SINT]        = CAP(  1),
  82.    [GEN6_FORMAT_R16G16B16A16_UINT]        = CAP(  1),
  83.    [GEN6_FORMAT_R16G16B16A16_FLOAT]       = CAP(  1),
  84.    [GEN6_FORMAT_R32G32_FLOAT]             = CAP(  1),
  85.    [GEN6_FORMAT_R32G32_SINT]              = CAP(  1),
  86.    [GEN6_FORMAT_R32G32_UINT]              = CAP(  1),
  87.    [GEN6_FORMAT_R32G32_UNORM]             = CAP(  1),
  88.    [GEN6_FORMAT_R32G32_SNORM]             = CAP(  1),
  89.    [GEN6_FORMAT_R64_FLOAT]                = CAP(  1),
  90.    [GEN6_FORMAT_R16G16B16A16_SSCALED]     = CAP(  1),
  91.    [GEN6_FORMAT_R16G16B16A16_USCALED]     = CAP(  1),
  92.    [GEN6_FORMAT_R32G32_SSCALED]           = CAP(  1),
  93.    [GEN6_FORMAT_R32G32_USCALED]           = CAP(  1),
  94.    [GEN6_FORMAT_R32G32_SFIXED]            = CAP(7.5),
  95.    [GEN6_FORMAT_B8G8R8A8_UNORM]           = CAP(  1),
  96.    [GEN6_FORMAT_R10G10B10A2_UNORM]        = CAP(  1),
  97.    [GEN6_FORMAT_R10G10B10A2_UINT]         = CAP(  1),
  98.    [GEN6_FORMAT_R10G10B10_SNORM_A2_UNORM] = CAP(  1),
  99.    [GEN6_FORMAT_R8G8B8A8_UNORM]           = CAP(  1),
  100.    [GEN6_FORMAT_R8G8B8A8_SNORM]           = CAP(  1),
  101.    [GEN6_FORMAT_R8G8B8A8_SINT]            = CAP(  1),
  102.    [GEN6_FORMAT_R8G8B8A8_UINT]            = CAP(  1),
  103.    [GEN6_FORMAT_R16G16_UNORM]             = CAP(  1),
  104.    [GEN6_FORMAT_R16G16_SNORM]             = CAP(  1),
  105.    [GEN6_FORMAT_R16G16_SINT]              = CAP(  1),
  106.    [GEN6_FORMAT_R16G16_UINT]              = CAP(  1),
  107.    [GEN6_FORMAT_R16G16_FLOAT]             = CAP(  1),
  108.    [GEN6_FORMAT_B10G10R10A2_UNORM]        = CAP(7.5),
  109.    [GEN6_FORMAT_R11G11B10_FLOAT]          = CAP(  1),
  110.    [GEN6_FORMAT_R32_SINT]                 = CAP(  1),
  111.    [GEN6_FORMAT_R32_UINT]                 = CAP(  1),
  112.    [GEN6_FORMAT_R32_FLOAT]                = CAP(  1),
  113.    [GEN6_FORMAT_R32_UNORM]                = CAP(  1),
  114.    [GEN6_FORMAT_R32_SNORM]                = CAP(  1),
  115.    [GEN6_FORMAT_R10G10B10X2_USCALED]      = CAP(  1),
  116.    [GEN6_FORMAT_R8G8B8A8_SSCALED]         = CAP(  1),
  117.    [GEN6_FORMAT_R8G8B8A8_USCALED]         = CAP(  1),
  118.    [GEN6_FORMAT_R16G16_SSCALED]           = CAP(  1),
  119.    [GEN6_FORMAT_R16G16_USCALED]           = CAP(  1),
  120.    [GEN6_FORMAT_R32_SSCALED]              = CAP(  1),
  121.    [GEN6_FORMAT_R32_USCALED]              = CAP(  1),
  122.    [GEN6_FORMAT_R8G8_UNORM]               = CAP(  1),
  123.    [GEN6_FORMAT_R8G8_SNORM]               = CAP(  1),
  124.    [GEN6_FORMAT_R8G8_SINT]                = CAP(  1),
  125.    [GEN6_FORMAT_R8G8_UINT]                = CAP(  1),
  126.    [GEN6_FORMAT_R16_UNORM]                = CAP(  1),
  127.    [GEN6_FORMAT_R16_SNORM]                = CAP(  1),
  128.    [GEN6_FORMAT_R16_SINT]                 = CAP(  1),
  129.    [GEN6_FORMAT_R16_UINT]                 = CAP(  1),
  130.    [GEN6_FORMAT_R16_FLOAT]                = CAP(  1),
  131.    [GEN6_FORMAT_R8G8_SSCALED]             = CAP(  1),
  132.    [GEN6_FORMAT_R8G8_USCALED]             = CAP(  1),
  133.    [GEN6_FORMAT_R16_SSCALED]              = CAP(  1),
  134.    [GEN6_FORMAT_R16_USCALED]              = CAP(  1),
  135.    [GEN6_FORMAT_R8_UNORM]                 = CAP(  1),
  136.    [GEN6_FORMAT_R8_SNORM]                 = CAP(  1),
  137.    [GEN6_FORMAT_R8_SINT]                  = CAP(  1),
  138.    [GEN6_FORMAT_R8_UINT]                  = CAP(  1),
  139.    [GEN6_FORMAT_R8_SSCALED]               = CAP(  1),
  140.    [GEN6_FORMAT_R8_USCALED]               = CAP(  1),
  141.    [GEN6_FORMAT_R8G8B8_UNORM]             = CAP(  1),
  142.    [GEN6_FORMAT_R8G8B8_SNORM]             = CAP(  1),
  143.    [GEN6_FORMAT_R8G8B8_SSCALED]           = CAP(  1),
  144.    [GEN6_FORMAT_R8G8B8_USCALED]           = CAP(  1),
  145.    [GEN6_FORMAT_R64G64B64A64_FLOAT]       = CAP(  1),
  146.    [GEN6_FORMAT_R64G64B64_FLOAT]          = CAP(  1),
  147.    [GEN6_FORMAT_R16G16B16_FLOAT]          = CAP(  6),
  148.    [GEN6_FORMAT_R16G16B16_UNORM]          = CAP(  1),
  149.    [GEN6_FORMAT_R16G16B16_SNORM]          = CAP(  1),
  150.    [GEN6_FORMAT_R16G16B16_SSCALED]        = CAP(  1),
  151.    [GEN6_FORMAT_R16G16B16_USCALED]        = CAP(  1),
  152.    [GEN6_FORMAT_R16G16B16_UINT]           = CAP(7.5),
  153.    [GEN6_FORMAT_R16G16B16_SINT]           = CAP(7.5),
  154.    [GEN6_FORMAT_R32_SFIXED]               = CAP(7.5),
  155.    [GEN6_FORMAT_R10G10B10A2_SNORM]        = CAP(7.5),
  156.    [GEN6_FORMAT_R10G10B10A2_USCALED]      = CAP(7.5),
  157.    [GEN6_FORMAT_R10G10B10A2_SSCALED]      = CAP(7.5),
  158.    [GEN6_FORMAT_R10G10B10A2_SINT]         = CAP(7.5),
  159.    [GEN6_FORMAT_B10G10R10A2_SNORM]        = CAP(7.5),
  160.    [GEN6_FORMAT_B10G10R10A2_USCALED]      = CAP(7.5),
  161.    [GEN6_FORMAT_B10G10R10A2_SSCALED]      = CAP(7.5),
  162.    [GEN6_FORMAT_B10G10R10A2_UINT]         = CAP(7.5),
  163.    [GEN6_FORMAT_B10G10R10A2_SINT]         = CAP(7.5),
  164.    [GEN6_FORMAT_R8G8B8_UINT]              = CAP(7.5),
  165.    [GEN6_FORMAT_R8G8B8_SINT]              = CAP(7.5),
  166. #undef CAP
  167. };
  168.  
  169. /*
  170.  * This table is based on:
  171.  *
  172.  *  - the Sandy Bridge PRM, volume 4 part 1, page 88-97
  173.  *  - the Ivy Bridge PRM, volume 2 part 1, page 195
  174.  *  - the Haswell PRM, volume 7, page 535
  175.  */
  176. static const struct ilo_sol_cap ilo_sol_caps[] = {
  177. #define CAP(buffer) { ILO_GEN(buffer) }
  178.    [GEN6_FORMAT_R32G32B32A32_FLOAT]       = CAP(  1),
  179.    [GEN6_FORMAT_R32G32B32A32_SINT]        = CAP(  1),
  180.    [GEN6_FORMAT_R32G32B32A32_UINT]        = CAP(  1),
  181.    [GEN6_FORMAT_R32G32B32_FLOAT]          = CAP(  1),
  182.    [GEN6_FORMAT_R32G32B32_SINT]           = CAP(  1),
  183.    [GEN6_FORMAT_R32G32B32_UINT]           = CAP(  1),
  184.    [GEN6_FORMAT_R32G32_FLOAT]             = CAP(  1),
  185.    [GEN6_FORMAT_R32G32_SINT]              = CAP(  1),
  186.    [GEN6_FORMAT_R32G32_UINT]              = CAP(  1),
  187.    [GEN6_FORMAT_R32_SINT]                 = CAP(  1),
  188.    [GEN6_FORMAT_R32_UINT]                 = CAP(  1),
  189.    [GEN6_FORMAT_R32_FLOAT]                = CAP(  1),
  190. #undef CAP
  191. };
  192.  
  193. /*
  194.  * This table is based on:
  195.  *
  196.  *  - the Sandy Bridge PRM, volume 4 part 1, page 88-97
  197.  *  - the Ivy Bridge PRM, volume 4 part 1, page 84-87
  198.  */
  199. static const struct ilo_sampler_cap ilo_sampler_caps[] = {
  200. #define CAP(sampling, filtering, shadow_map, chroma_key) \
  201.    { ILO_GEN(sampling), ILO_GEN(filtering), ILO_GEN(shadow_map), ILO_GEN(chroma_key) }
  202.    [GEN6_FORMAT_R32G32B32A32_FLOAT]       = CAP(  1,   5,   0,   0),
  203.    [GEN6_FORMAT_R32G32B32A32_SINT]        = CAP(  1,   0,   0,   0),
  204.    [GEN6_FORMAT_R32G32B32A32_UINT]        = CAP(  1,   0,   0,   0),
  205.    [GEN6_FORMAT_R32G32B32X32_FLOAT]       = CAP(  1,   5,   0,   0),
  206.    [GEN6_FORMAT_R32G32B32_FLOAT]          = CAP(  1,   5,   0,   0),
  207.    [GEN6_FORMAT_R32G32B32_SINT]           = CAP(  1,   0,   0,   0),
  208.    [GEN6_FORMAT_R32G32B32_UINT]           = CAP(  1,   0,   0,   0),
  209.    [GEN6_FORMAT_R16G16B16A16_UNORM]       = CAP(  1,   1,   0,   0),
  210.    [GEN6_FORMAT_R16G16B16A16_SNORM]       = CAP(  1,   1,   0,   0),
  211.    [GEN6_FORMAT_R16G16B16A16_SINT]        = CAP(  1,   0,   0,   0),
  212.    [GEN6_FORMAT_R16G16B16A16_UINT]        = CAP(  1,   0,   0,   0),
  213.    [GEN6_FORMAT_R16G16B16A16_FLOAT]       = CAP(  1,   1,   0,   0),
  214.    [GEN6_FORMAT_R32G32_FLOAT]             = CAP(  1,   5,   0,   0),
  215.    [GEN6_FORMAT_R32G32_SINT]              = CAP(  1,   0,   0,   0),
  216.    [GEN6_FORMAT_R32G32_UINT]              = CAP(  1,   0,   0,   0),
  217.    [GEN6_FORMAT_R32_FLOAT_X8X24_TYPELESS] = CAP(  1,   5,   1,   0),
  218.    [GEN6_FORMAT_X32_TYPELESS_G8X24_UINT]  = CAP(  1,   0,   0,   0),
  219.    [GEN6_FORMAT_L32A32_FLOAT]             = CAP(  1,   5,   0,   0),
  220.    [GEN6_FORMAT_R16G16B16X16_UNORM]       = CAP(  1,   1,   0,   0),
  221.    [GEN6_FORMAT_R16G16B16X16_FLOAT]       = CAP(  1,   1,   0,   0),
  222.    [GEN6_FORMAT_A32X32_FLOAT]             = CAP(  1,   5,   0,   0),
  223.    [GEN6_FORMAT_L32X32_FLOAT]             = CAP(  1,   5,   0,   0),
  224.    [GEN6_FORMAT_I32X32_FLOAT]             = CAP(  1,   5,   0,   0),
  225.    [GEN6_FORMAT_B8G8R8A8_UNORM]           = CAP(  1,   1,   0,   1),
  226.    [GEN6_FORMAT_B8G8R8A8_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  227.    [GEN6_FORMAT_R10G10B10A2_UNORM]        = CAP(  1,   1,   0,   0),
  228.    [GEN6_FORMAT_R10G10B10A2_UNORM_SRGB]   = CAP(  1,   1,   0,   0),
  229.    [GEN6_FORMAT_R10G10B10A2_UINT]         = CAP(  1,   0,   0,   0),
  230.    [GEN6_FORMAT_R10G10B10_SNORM_A2_UNORM] = CAP(  1,   1,   0,   0),
  231.    [GEN6_FORMAT_R8G8B8A8_UNORM]           = CAP(  1,   1,   0,   0),
  232.    [GEN6_FORMAT_R8G8B8A8_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  233.    [GEN6_FORMAT_R8G8B8A8_SNORM]           = CAP(  1,   1,   0,   0),
  234.    [GEN6_FORMAT_R8G8B8A8_SINT]            = CAP(  1,   0,   0,   0),
  235.    [GEN6_FORMAT_R8G8B8A8_UINT]            = CAP(  1,   0,   0,   0),
  236.    [GEN6_FORMAT_R16G16_UNORM]             = CAP(  1,   1,   0,   0),
  237.    [GEN6_FORMAT_R16G16_SNORM]             = CAP(  1,   1,   0,   0),
  238.    [GEN6_FORMAT_R16G16_SINT]              = CAP(  1,   0,   0,   0),
  239.    [GEN6_FORMAT_R16G16_UINT]              = CAP(  1,   0,   0,   0),
  240.    [GEN6_FORMAT_R16G16_FLOAT]             = CAP(  1,   1,   0,   0),
  241.    [GEN6_FORMAT_B10G10R10A2_UNORM]        = CAP(  1,   1,   0,   0),
  242.    [GEN6_FORMAT_B10G10R10A2_UNORM_SRGB]   = CAP(  1,   1,   0,   0),
  243.    [GEN6_FORMAT_R11G11B10_FLOAT]          = CAP(  1,   1,   0,   0),
  244.    [GEN6_FORMAT_R32_SINT]                 = CAP(  1,   0,   0,   0),
  245.    [GEN6_FORMAT_R32_UINT]                 = CAP(  1,   0,   0,   0),
  246.    [GEN6_FORMAT_R32_FLOAT]                = CAP(  1,   5,   1,   0),
  247.    [GEN6_FORMAT_R24_UNORM_X8_TYPELESS]    = CAP(  1,   5,   1,   0),
  248.    [GEN6_FORMAT_X24_TYPELESS_G8_UINT]     = CAP(  1,   0,   0,   0),
  249.    [GEN6_FORMAT_L16A16_UNORM]             = CAP(  1,   1,   0,   0),
  250.    [GEN6_FORMAT_I24X8_UNORM]              = CAP(  1,   5,   1,   0),
  251.    [GEN6_FORMAT_L24X8_UNORM]              = CAP(  1,   5,   1,   0),
  252.    [GEN6_FORMAT_A24X8_UNORM]              = CAP(  1,   5,   1,   0),
  253.    [GEN6_FORMAT_I32_FLOAT]                = CAP(  1,   5,   1,   0),
  254.    [GEN6_FORMAT_L32_FLOAT]                = CAP(  1,   5,   1,   0),
  255.    [GEN6_FORMAT_A32_FLOAT]                = CAP(  1,   5,   1,   0),
  256.    [GEN6_FORMAT_B8G8R8X8_UNORM]           = CAP(  1,   1,   0,   1),
  257.    [GEN6_FORMAT_B8G8R8X8_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  258.    [GEN6_FORMAT_R8G8B8X8_UNORM]           = CAP(  1,   1,   0,   0),
  259.    [GEN6_FORMAT_R8G8B8X8_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  260.    [GEN6_FORMAT_R9G9B9E5_SHAREDEXP]       = CAP(  1,   1,   0,   0),
  261.    [GEN6_FORMAT_B10G10R10X2_UNORM]        = CAP(  1,   1,   0,   0),
  262.    [GEN6_FORMAT_L16A16_FLOAT]             = CAP(  1,   1,   0,   0),
  263.    [GEN6_FORMAT_B5G6R5_UNORM]             = CAP(  1,   1,   0,   1),
  264.    [GEN6_FORMAT_B5G6R5_UNORM_SRGB]        = CAP(  1,   1,   0,   0),
  265.    [GEN6_FORMAT_B5G5R5A1_UNORM]           = CAP(  1,   1,   0,   1),
  266.    [GEN6_FORMAT_B5G5R5A1_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  267.    [GEN6_FORMAT_B4G4R4A4_UNORM]           = CAP(  1,   1,   0,   1),
  268.    [GEN6_FORMAT_B4G4R4A4_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  269.    [GEN6_FORMAT_R8G8_UNORM]               = CAP(  1,   1,   0,   0),
  270.    [GEN6_FORMAT_R8G8_SNORM]               = CAP(  1,   1,   0,   1),
  271.    [GEN6_FORMAT_R8G8_SINT]                = CAP(  1,   0,   0,   0),
  272.    [GEN6_FORMAT_R8G8_UINT]                = CAP(  1,   0,   0,   0),
  273.    [GEN6_FORMAT_R16_UNORM]                = CAP(  1,   1,   1,   0),
  274.    [GEN6_FORMAT_R16_SNORM]                = CAP(  1,   1,   0,   0),
  275.    [GEN6_FORMAT_R16_SINT]                 = CAP(  1,   0,   0,   0),
  276.    [GEN6_FORMAT_R16_UINT]                 = CAP(  1,   0,   0,   0),
  277.    [GEN6_FORMAT_R16_FLOAT]                = CAP(  1,   1,   0,   0),
  278.    [GEN6_FORMAT_A8P8_UNORM_PALETTE0]      = CAP(  5,   5,   0,   0),
  279.    [GEN6_FORMAT_A8P8_UNORM_PALETTE1]      = CAP(  5,   5,   0,   0),
  280.    [GEN6_FORMAT_I16_UNORM]                = CAP(  1,   1,   1,   0),
  281.    [GEN6_FORMAT_L16_UNORM]                = CAP(  1,   1,   1,   0),
  282.    [GEN6_FORMAT_A16_UNORM]                = CAP(  1,   1,   1,   0),
  283.    [GEN6_FORMAT_L8A8_UNORM]               = CAP(  1,   1,   0,   1),
  284.    [GEN6_FORMAT_I16_FLOAT]                = CAP(  1,   1,   1,   0),
  285.    [GEN6_FORMAT_L16_FLOAT]                = CAP(  1,   1,   1,   0),
  286.    [GEN6_FORMAT_A16_FLOAT]                = CAP(  1,   1,   1,   0),
  287.    [GEN6_FORMAT_L8A8_UNORM_SRGB]          = CAP(4.5, 4.5,   0,   0),
  288.    [GEN6_FORMAT_R5G5_SNORM_B6_UNORM]      = CAP(  1,   1,   0,   1),
  289.    [GEN6_FORMAT_P8A8_UNORM_PALETTE0]      = CAP(  5,   5,   0,   0),
  290.    [GEN6_FORMAT_P8A8_UNORM_PALETTE1]      = CAP(  5,   5,   0,   0),
  291.    [GEN6_FORMAT_R8_UNORM]                 = CAP(  1,   1,   0, 4.5),
  292.    [GEN6_FORMAT_R8_SNORM]                 = CAP(  1,   1,   0,   0),
  293.    [GEN6_FORMAT_R8_SINT]                  = CAP(  1,   0,   0,   0),
  294.    [GEN6_FORMAT_R8_UINT]                  = CAP(  1,   0,   0,   0),
  295.    [GEN6_FORMAT_A8_UNORM]                 = CAP(  1,   1,   0,   1),
  296.    [GEN6_FORMAT_I8_UNORM]                 = CAP(  1,   1,   0,   0),
  297.    [GEN6_FORMAT_L8_UNORM]                 = CAP(  1,   1,   0,   1),
  298.    [GEN6_FORMAT_P4A4_UNORM_PALETTE0]      = CAP(  1,   1,   0,   0),
  299.    [GEN6_FORMAT_A4P4_UNORM_PALETTE0]      = CAP(  1,   1,   0,   0),
  300.    [GEN6_FORMAT_P8_UNORM_PALETTE0]        = CAP(4.5, 4.5,   0,   0),
  301.    [GEN6_FORMAT_L8_UNORM_SRGB]            = CAP(4.5, 4.5,   0,   0),
  302.    [GEN6_FORMAT_P8_UNORM_PALETTE1]        = CAP(4.5, 4.5,   0,   0),
  303.    [GEN6_FORMAT_P4A4_UNORM_PALETTE1]      = CAP(4.5, 4.5,   0,   0),
  304.    [GEN6_FORMAT_A4P4_UNORM_PALETTE1]      = CAP(4.5, 4.5,   0,   0),
  305.    [GEN6_FORMAT_DXT1_RGB_SRGB]            = CAP(4.5, 4.5,   0,   0),
  306.    [GEN6_FORMAT_R1_UNORM]                 = CAP(  1,   1,   0,   0),
  307.    [GEN6_FORMAT_YCRCB_NORMAL]             = CAP(  1,   1,   0,   1),
  308.    [GEN6_FORMAT_YCRCB_SWAPUVY]            = CAP(  1,   1,   0,   1),
  309.    [GEN6_FORMAT_P2_UNORM_PALETTE0]        = CAP(4.5, 4.5,   0,   0),
  310.    [GEN6_FORMAT_P2_UNORM_PALETTE1]        = CAP(4.5, 4.5,   0,   0),
  311.    [GEN6_FORMAT_BC1_UNORM]                = CAP(  1,   1,   0,   1),
  312.    [GEN6_FORMAT_BC2_UNORM]                = CAP(  1,   1,   0,   1),
  313.    [GEN6_FORMAT_BC3_UNORM]                = CAP(  1,   1,   0,   1),
  314.    [GEN6_FORMAT_BC4_UNORM]                = CAP(  1,   1,   0,   0),
  315.    [GEN6_FORMAT_BC5_UNORM]                = CAP(  1,   1,   0,   0),
  316.    [GEN6_FORMAT_BC1_UNORM_SRGB]           = CAP(  1,   1,   0,   0),
  317.    [GEN6_FORMAT_BC2_UNORM_SRGB]           = CAP(  1,   1,   0,   0),
  318.    [GEN6_FORMAT_BC3_UNORM_SRGB]           = CAP(  1,   1,   0,   0),
  319.    [GEN6_FORMAT_MONO8]                    = CAP(  1,   0,   0,   0),
  320.    [GEN6_FORMAT_YCRCB_SWAPUV]             = CAP(  1,   1,   0,   0),
  321.    [GEN6_FORMAT_YCRCB_SWAPY]              = CAP(  1,   1,   0,   0),
  322.    [GEN6_FORMAT_DXT1_RGB]                 = CAP(  1,   1,   0,   0),
  323.    [GEN6_FORMAT_FXT1]                     = CAP(  1,   1,   0,   0),
  324.    [GEN6_FORMAT_BC4_SNORM]                = CAP(  1,   1,   0,   0),
  325.    [GEN6_FORMAT_BC5_SNORM]                = CAP(  1,   1,   0,   0),
  326.    [GEN6_FORMAT_R16G16B16_FLOAT]          = CAP(  5,   5,   0,   0),
  327.    [GEN6_FORMAT_BC6H_SF16]                = CAP(  7,   7,   0,   0),
  328.    [GEN6_FORMAT_BC7_UNORM]                = CAP(  7,   7,   0,   0),
  329.    [GEN6_FORMAT_BC7_UNORM_SRGB]           = CAP(  7,   7,   0,   0),
  330.    [GEN6_FORMAT_BC6H_UF16]                = CAP(  7,   7,   0,   0),
  331. #undef CAP
  332. };
  333.  
  334. /*
  335.  * This table is based on:
  336.  *
  337.  *  - the Sandy Bridge PRM, volume 4 part 1, page 88-97
  338.  *  - the Ivy Bridge PRM, volume 4 part 1, page 172, 252-253, and 277-278
  339.  *  - the Haswell PRM, volume 7, page 262-264
  340.  */
  341. static const struct ilo_dp_cap ilo_dp_caps[] = {
  342. #define CAP(rt_write, rt_write_blending, typed_write, media_color_processing) \
  343.    { ILO_GEN(rt_write), ILO_GEN(rt_write_blending), ILO_GEN(typed_write), ILO_GEN(media_color_processing) }
  344.    [GEN6_FORMAT_R32G32B32A32_FLOAT]       = CAP(  1,   1,   7,   0),
  345.    [GEN6_FORMAT_R32G32B32A32_SINT]        = CAP(  1,   0,   7,   0),
  346.    [GEN6_FORMAT_R32G32B32A32_UINT]        = CAP(  1,   0,   7,   0),
  347.    [GEN6_FORMAT_R16G16B16A16_UNORM]       = CAP(  1, 4.5,   7,   6),
  348.    [GEN6_FORMAT_R16G16B16A16_SNORM]       = CAP(  1,   6,   7,   0),
  349.    [GEN6_FORMAT_R16G16B16A16_SINT]        = CAP(  1,   0,   7,   0),
  350.    [GEN6_FORMAT_R16G16B16A16_UINT]        = CAP(  1,   0,   7,   0),
  351.    [GEN6_FORMAT_R16G16B16A16_FLOAT]       = CAP(  1,   1,   7,   0),
  352.    [GEN6_FORMAT_R32G32_FLOAT]             = CAP(  1,   1,   7,   0),
  353.    [GEN6_FORMAT_R32G32_SINT]              = CAP(  1,   0,   7,   0),
  354.    [GEN6_FORMAT_R32G32_UINT]              = CAP(  1,   0,   7,   0),
  355.    [GEN6_FORMAT_B8G8R8A8_UNORM]           = CAP(  1,   1,   7,   6),
  356.    [GEN6_FORMAT_B8G8R8A8_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  357.    [GEN6_FORMAT_R10G10B10A2_UNORM]        = CAP(  1,   1,   7,   6),
  358.    [GEN6_FORMAT_R10G10B10A2_UNORM_SRGB]   = CAP(  0,   0,   0,   6),
  359.    [GEN6_FORMAT_R10G10B10A2_UINT]         = CAP(  1,   0,   7,   0),
  360.    [GEN6_FORMAT_R8G8B8A8_UNORM]           = CAP(  1,   1,   7,   6),
  361.    [GEN6_FORMAT_R8G8B8A8_UNORM_SRGB]      = CAP(  1,   1,   0,   6),
  362.    [GEN6_FORMAT_R8G8B8A8_SNORM]           = CAP(  1,   6,   7,   0),
  363.    [GEN6_FORMAT_R8G8B8A8_SINT]            = CAP(  1,   0,   7,   0),
  364.    [GEN6_FORMAT_R8G8B8A8_UINT]            = CAP(  1,   0,   7,   0),
  365.    [GEN6_FORMAT_R16G16_UNORM]             = CAP(  1, 4.5,   7,   0),
  366.    [GEN6_FORMAT_R16G16_SNORM]             = CAP(  1,   6,   7,   0),
  367.    [GEN6_FORMAT_R16G16_SINT]              = CAP(  1,   0,   7,   0),
  368.    [GEN6_FORMAT_R16G16_UINT]              = CAP(  1,   0,   7,   0),
  369.    [GEN6_FORMAT_R16G16_FLOAT]             = CAP(  1,   1,   7,   0),
  370.    [GEN6_FORMAT_B10G10R10A2_UNORM]        = CAP(  1,   1,   7,   6),
  371.    [GEN6_FORMAT_B10G10R10A2_UNORM_SRGB]   = CAP(  1,   1,   0,   6),
  372.    [GEN6_FORMAT_R11G11B10_FLOAT]          = CAP(  1,   1,   7,   0),
  373.    [GEN6_FORMAT_R32_SINT]                 = CAP(  1,   0,   7,   0),
  374.    [GEN6_FORMAT_R32_UINT]                 = CAP(  1,   0,   7,   0),
  375.    [GEN6_FORMAT_R32_FLOAT]                = CAP(  1,   1,   7,   0),
  376.    [GEN6_FORMAT_B8G8R8X8_UNORM]           = CAP(  0,   0,   0,   6),
  377.    [GEN6_FORMAT_B5G6R5_UNORM]             = CAP(  1,   1,   7,   0),
  378.    [GEN6_FORMAT_B5G6R5_UNORM_SRGB]        = CAP(  1,   1,   0,   0),
  379.    [GEN6_FORMAT_B5G5R5A1_UNORM]           = CAP(  1,   1,   7,   0),
  380.    [GEN6_FORMAT_B5G5R5A1_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  381.    [GEN6_FORMAT_B4G4R4A4_UNORM]           = CAP(  1,   1,   7,   0),
  382.    [GEN6_FORMAT_B4G4R4A4_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  383.    [GEN6_FORMAT_R8G8_UNORM]               = CAP(  1,   1,   7,   0),
  384.    [GEN6_FORMAT_R8G8_SNORM]               = CAP(  1,   6,   7,   0),
  385.    [GEN6_FORMAT_R8G8_SINT]                = CAP(  1,   0,   7,   0),
  386.    [GEN6_FORMAT_R8G8_UINT]                = CAP(  1,   0,   7,   0),
  387.    [GEN6_FORMAT_R16_UNORM]                = CAP(  1, 4.5,   7,   7),
  388.    [GEN6_FORMAT_R16_SNORM]                = CAP(  1,   6,   7,   0),
  389.    [GEN6_FORMAT_R16_SINT]                 = CAP(  1,   0,   7,   0),
  390.    [GEN6_FORMAT_R16_UINT]                 = CAP(  1,   0,   7,   0),
  391.    [GEN6_FORMAT_R16_FLOAT]                = CAP(  1,   1,   7,   0),
  392.    [GEN6_FORMAT_B5G5R5X1_UNORM]           = CAP(  1,   1,   7,   0),
  393.    [GEN6_FORMAT_B5G5R5X1_UNORM_SRGB]      = CAP(  1,   1,   0,   0),
  394.    [GEN6_FORMAT_R8_UNORM]                 = CAP(  1,   1,   7,   0),
  395.    [GEN6_FORMAT_R8_SNORM]                 = CAP(  1,   6,   7,   0),
  396.    [GEN6_FORMAT_R8_SINT]                  = CAP(  1,   0,   7,   0),
  397.    [GEN6_FORMAT_R8_UINT]                  = CAP(  1,   0,   7,   0),
  398.    [GEN6_FORMAT_A8_UNORM]                 = CAP(  1,   1,   7,   0),
  399.    [GEN6_FORMAT_YCRCB_NORMAL]             = CAP(  1,   0,   0,   6),
  400.    [GEN6_FORMAT_YCRCB_SWAPUVY]            = CAP(  1,   0,   0,   6),
  401.    [GEN6_FORMAT_YCRCB_SWAPUV]             = CAP(  1,   0,   0,   6),
  402.    [GEN6_FORMAT_YCRCB_SWAPY]              = CAP(  1,   0,   0,   6),
  403. #undef CAP
  404. };
  405.  
  406. bool
  407. ilo_format_support_vb(const struct ilo_dev *dev,
  408.                       enum pipe_format format)
  409. {
  410.    const int idx = ilo_format_translate(dev, format, PIPE_BIND_VERTEX_BUFFER);
  411.    const struct ilo_vf_cap *cap = (idx >= 0 && idx < Elements(ilo_vf_caps)) ?
  412.       &ilo_vf_caps[idx] : NULL;
  413.  
  414.    return (cap && cap->vertex_element &&
  415.          ilo_dev_gen(dev) >= cap->vertex_element);
  416. }
  417.  
  418. bool
  419. ilo_format_support_sol(const struct ilo_dev *dev,
  420.                        enum pipe_format format)
  421. {
  422.    const int idx = ilo_format_translate(dev, format, PIPE_BIND_STREAM_OUTPUT);
  423.    const struct ilo_sol_cap *cap = (idx >= 0 && idx < Elements(ilo_sol_caps)) ?
  424.       &ilo_sol_caps[idx] : NULL;
  425.  
  426.    return (cap && cap->buffer && ilo_dev_gen(dev) >= cap->buffer);
  427. }
  428.  
  429. bool
  430. ilo_format_support_sampler(const struct ilo_dev *dev,
  431.                            enum pipe_format format)
  432. {
  433.    const int idx = ilo_format_translate(dev, format, PIPE_BIND_SAMPLER_VIEW);
  434.    const struct ilo_sampler_cap *cap = (idx >= 0 &&
  435.          idx < Elements(ilo_sampler_caps)) ? &ilo_sampler_caps[idx] : NULL;
  436.  
  437.    if (!cap || !cap->sampling)
  438.       return false;
  439.  
  440.    assert(!cap->filtering || cap->filtering >= cap->sampling);
  441.  
  442.    if (util_format_is_pure_integer(format))
  443.       return (ilo_dev_gen(dev) >= cap->sampling);
  444.    else if (cap->filtering)
  445.       return (ilo_dev_gen(dev) >= cap->filtering);
  446.    else
  447.       return false;
  448. }
  449.  
  450. bool
  451. ilo_format_support_rt(const struct ilo_dev *dev,
  452.                       enum pipe_format format)
  453. {
  454.    const int idx = ilo_format_translate(dev, format, PIPE_BIND_RENDER_TARGET);
  455.    const struct ilo_dp_cap *cap = (idx >= 0 && idx < Elements(ilo_dp_caps)) ?
  456.       &ilo_dp_caps[idx] : NULL;
  457.  
  458.    if (!cap || !cap->rt_write)
  459.       return false;
  460.  
  461.    assert(!cap->rt_write_blending || cap->rt_write_blending >= cap->rt_write);
  462.  
  463.    if (util_format_is_pure_integer(format))
  464.       return (ilo_dev_gen(dev) >= cap->rt_write);
  465.    else if (cap->rt_write_blending)
  466.       return (ilo_dev_gen(dev) >= cap->rt_write_blending);
  467.    else
  468.       return false;
  469. }
  470.  
  471. bool
  472. ilo_format_support_zs(const struct ilo_dev *dev,
  473.                       enum pipe_format format)
  474. {
  475.    switch (format) {
  476.    case PIPE_FORMAT_Z16_UNORM:
  477.    case PIPE_FORMAT_Z24X8_UNORM:
  478.    case PIPE_FORMAT_Z32_FLOAT:
  479.    case PIPE_FORMAT_Z24_UNORM_S8_UINT:
  480.    case PIPE_FORMAT_Z32_FLOAT_S8X24_UINT:
  481.       return true;
  482.    case PIPE_FORMAT_S8_UINT:
  483.       /* TODO separate stencil */
  484.    default:
  485.       return false;
  486.    }
  487. }
  488.  
  489. /**
  490.  * Translate a color (non-depth/stencil) pipe format to the matching hardware
  491.  * format.  Return -1 on errors.
  492.  */
  493. int
  494. ilo_format_translate_color(const struct ilo_dev *dev,
  495.                            enum pipe_format format)
  496. {
  497.    static const int format_mapping[PIPE_FORMAT_COUNT] = {
  498.       [PIPE_FORMAT_NONE]                  = 0,
  499.       [PIPE_FORMAT_B8G8R8A8_UNORM]        = GEN6_FORMAT_B8G8R8A8_UNORM,
  500.       [PIPE_FORMAT_B8G8R8X8_UNORM]        = GEN6_FORMAT_B8G8R8X8_UNORM,
  501.       [PIPE_FORMAT_A8R8G8B8_UNORM]        = 0,
  502.       [PIPE_FORMAT_X8R8G8B8_UNORM]        = 0,
  503.       [PIPE_FORMAT_B5G5R5A1_UNORM]        = GEN6_FORMAT_B5G5R5A1_UNORM,
  504.       [PIPE_FORMAT_B4G4R4A4_UNORM]        = GEN6_FORMAT_B4G4R4A4_UNORM,
  505.       [PIPE_FORMAT_B5G6R5_UNORM]          = GEN6_FORMAT_B5G6R5_UNORM,
  506.       [PIPE_FORMAT_R10G10B10A2_UNORM]     = GEN6_FORMAT_R10G10B10A2_UNORM,
  507.       [PIPE_FORMAT_L8_UNORM]              = GEN6_FORMAT_L8_UNORM,
  508.       [PIPE_FORMAT_A8_UNORM]              = GEN6_FORMAT_A8_UNORM,
  509.       [PIPE_FORMAT_I8_UNORM]              = GEN6_FORMAT_I8_UNORM,
  510.       [PIPE_FORMAT_L8A8_UNORM]            = GEN6_FORMAT_L8A8_UNORM,
  511.       [PIPE_FORMAT_L16_UNORM]             = GEN6_FORMAT_L16_UNORM,
  512.       [PIPE_FORMAT_UYVY]                  = GEN6_FORMAT_YCRCB_SWAPUVY,
  513.       [PIPE_FORMAT_YUYV]                  = GEN6_FORMAT_YCRCB_NORMAL,
  514.       [PIPE_FORMAT_Z16_UNORM]             = 0,
  515.       [PIPE_FORMAT_Z32_UNORM]             = 0,
  516.       [PIPE_FORMAT_Z32_FLOAT]             = 0,
  517.       [PIPE_FORMAT_Z24_UNORM_S8_UINT]     = 0,
  518.       [PIPE_FORMAT_S8_UINT_Z24_UNORM]     = 0,
  519.       [PIPE_FORMAT_Z24X8_UNORM]           = 0,
  520.       [PIPE_FORMAT_X8Z24_UNORM]           = 0,
  521.       [PIPE_FORMAT_S8_UINT]               = 0,
  522.       [PIPE_FORMAT_R64_FLOAT]             = GEN6_FORMAT_R64_FLOAT,
  523.       [PIPE_FORMAT_R64G64_FLOAT]          = GEN6_FORMAT_R64G64_FLOAT,
  524.       [PIPE_FORMAT_R64G64B64_FLOAT]       = GEN6_FORMAT_R64G64B64_FLOAT,
  525.       [PIPE_FORMAT_R64G64B64A64_FLOAT]    = GEN6_FORMAT_R64G64B64A64_FLOAT,
  526.       [PIPE_FORMAT_R32_FLOAT]             = GEN6_FORMAT_R32_FLOAT,
  527.       [PIPE_FORMAT_R32G32_FLOAT]          = GEN6_FORMAT_R32G32_FLOAT,
  528.       [PIPE_FORMAT_R32G32B32_FLOAT]       = GEN6_FORMAT_R32G32B32_FLOAT,
  529.       [PIPE_FORMAT_R32G32B32A32_FLOAT]    = GEN6_FORMAT_R32G32B32A32_FLOAT,
  530.       [PIPE_FORMAT_R32_UNORM]             = GEN6_FORMAT_R32_UNORM,
  531.       [PIPE_FORMAT_R32G32_UNORM]          = GEN6_FORMAT_R32G32_UNORM,
  532.       [PIPE_FORMAT_R32G32B32_UNORM]       = GEN6_FORMAT_R32G32B32_UNORM,
  533.       [PIPE_FORMAT_R32G32B32A32_UNORM]    = GEN6_FORMAT_R32G32B32A32_UNORM,
  534.       [PIPE_FORMAT_R32_USCALED]           = GEN6_FORMAT_R32_USCALED,
  535.       [PIPE_FORMAT_R32G32_USCALED]        = GEN6_FORMAT_R32G32_USCALED,
  536.       [PIPE_FORMAT_R32G32B32_USCALED]     = GEN6_FORMAT_R32G32B32_USCALED,
  537.       [PIPE_FORMAT_R32G32B32A32_USCALED]  = GEN6_FORMAT_R32G32B32A32_USCALED,
  538.       [PIPE_FORMAT_R32_SNORM]             = GEN6_FORMAT_R32_SNORM,
  539.       [PIPE_FORMAT_R32G32_SNORM]          = GEN6_FORMAT_R32G32_SNORM,
  540.       [PIPE_FORMAT_R32G32B32_SNORM]       = GEN6_FORMAT_R32G32B32_SNORM,
  541.       [PIPE_FORMAT_R32G32B32A32_SNORM]    = GEN6_FORMAT_R32G32B32A32_SNORM,
  542.       [PIPE_FORMAT_R32_SSCALED]           = GEN6_FORMAT_R32_SSCALED,
  543.       [PIPE_FORMAT_R32G32_SSCALED]        = GEN6_FORMAT_R32G32_SSCALED,
  544.       [PIPE_FORMAT_R32G32B32_SSCALED]     = GEN6_FORMAT_R32G32B32_SSCALED,
  545.       [PIPE_FORMAT_R32G32B32A32_SSCALED]  = GEN6_FORMAT_R32G32B32A32_SSCALED,
  546.       [PIPE_FORMAT_R16_UNORM]             = GEN6_FORMAT_R16_UNORM,
  547.       [PIPE_FORMAT_R16G16_UNORM]          = GEN6_FORMAT_R16G16_UNORM,
  548.       [PIPE_FORMAT_R16G16B16_UNORM]       = GEN6_FORMAT_R16G16B16_UNORM,
  549.       [PIPE_FORMAT_R16G16B16A16_UNORM]    = GEN6_FORMAT_R16G16B16A16_UNORM,
  550.       [PIPE_FORMAT_R16_USCALED]           = GEN6_FORMAT_R16_USCALED,
  551.       [PIPE_FORMAT_R16G16_USCALED]        = GEN6_FORMAT_R16G16_USCALED,
  552.       [PIPE_FORMAT_R16G16B16_USCALED]     = GEN6_FORMAT_R16G16B16_USCALED,
  553.       [PIPE_FORMAT_R16G16B16A16_USCALED]  = GEN6_FORMAT_R16G16B16A16_USCALED,
  554.       [PIPE_FORMAT_R16_SNORM]             = GEN6_FORMAT_R16_SNORM,
  555.       [PIPE_FORMAT_R16G16_SNORM]          = GEN6_FORMAT_R16G16_SNORM,
  556.       [PIPE_FORMAT_R16G16B16_SNORM]       = GEN6_FORMAT_R16G16B16_SNORM,
  557.       [PIPE_FORMAT_R16G16B16A16_SNORM]    = GEN6_FORMAT_R16G16B16A16_SNORM,
  558.       [PIPE_FORMAT_R16_SSCALED]           = GEN6_FORMAT_R16_SSCALED,
  559.       [PIPE_FORMAT_R16G16_SSCALED]        = GEN6_FORMAT_R16G16_SSCALED,
  560.       [PIPE_FORMAT_R16G16B16_SSCALED]     = GEN6_FORMAT_R16G16B16_SSCALED,
  561.       [PIPE_FORMAT_R16G16B16A16_SSCALED]  = GEN6_FORMAT_R16G16B16A16_SSCALED,
  562.       [PIPE_FORMAT_R8_UNORM]              = GEN6_FORMAT_R8_UNORM,
  563.       [PIPE_FORMAT_R8G8_UNORM]            = GEN6_FORMAT_R8G8_UNORM,
  564.       [PIPE_FORMAT_R8G8B8_UNORM]          = GEN6_FORMAT_R8G8B8_UNORM,
  565.       [PIPE_FORMAT_R8G8B8A8_UNORM]        = GEN6_FORMAT_R8G8B8A8_UNORM,
  566.       [PIPE_FORMAT_X8B8G8R8_UNORM]        = 0,
  567.       [PIPE_FORMAT_R8_USCALED]            = GEN6_FORMAT_R8_USCALED,
  568.       [PIPE_FORMAT_R8G8_USCALED]          = GEN6_FORMAT_R8G8_USCALED,
  569.       [PIPE_FORMAT_R8G8B8_USCALED]        = GEN6_FORMAT_R8G8B8_USCALED,
  570.       [PIPE_FORMAT_R8G8B8A8_USCALED]      = GEN6_FORMAT_R8G8B8A8_USCALED,
  571.       [PIPE_FORMAT_R8_SNORM]              = GEN6_FORMAT_R8_SNORM,
  572.       [PIPE_FORMAT_R8G8_SNORM]            = GEN6_FORMAT_R8G8_SNORM,
  573.       [PIPE_FORMAT_R8G8B8_SNORM]          = GEN6_FORMAT_R8G8B8_SNORM,
  574.       [PIPE_FORMAT_R8G8B8A8_SNORM]        = GEN6_FORMAT_R8G8B8A8_SNORM,
  575.       [PIPE_FORMAT_R8_SSCALED]            = GEN6_FORMAT_R8_SSCALED,
  576.       [PIPE_FORMAT_R8G8_SSCALED]          = GEN6_FORMAT_R8G8_SSCALED,
  577.       [PIPE_FORMAT_R8G8B8_SSCALED]        = GEN6_FORMAT_R8G8B8_SSCALED,
  578.       [PIPE_FORMAT_R8G8B8A8_SSCALED]      = GEN6_FORMAT_R8G8B8A8_SSCALED,
  579.       [PIPE_FORMAT_R32_FIXED]             = GEN6_FORMAT_R32_SFIXED,
  580.       [PIPE_FORMAT_R32G32_FIXED]          = GEN6_FORMAT_R32G32_SFIXED,
  581.       [PIPE_FORMAT_R32G32B32_FIXED]       = GEN6_FORMAT_R32G32B32_SFIXED,
  582.       [PIPE_FORMAT_R32G32B32A32_FIXED]    = GEN6_FORMAT_R32G32B32A32_SFIXED,
  583.       [PIPE_FORMAT_R16_FLOAT]             = GEN6_FORMAT_R16_FLOAT,
  584.       [PIPE_FORMAT_R16G16_FLOAT]          = GEN6_FORMAT_R16G16_FLOAT,
  585.       [PIPE_FORMAT_R16G16B16_FLOAT]       = GEN6_FORMAT_R16G16B16_FLOAT,
  586.       [PIPE_FORMAT_R16G16B16A16_FLOAT]    = GEN6_FORMAT_R16G16B16A16_FLOAT,
  587.       [PIPE_FORMAT_L8_SRGB]               = GEN6_FORMAT_L8_UNORM_SRGB,
  588.       [PIPE_FORMAT_L8A8_SRGB]             = GEN6_FORMAT_L8A8_UNORM_SRGB,
  589.       [PIPE_FORMAT_R8G8B8_SRGB]           = GEN6_FORMAT_R8G8B8_UNORM_SRGB,
  590.       [PIPE_FORMAT_A8B8G8R8_SRGB]         = 0,
  591.       [PIPE_FORMAT_X8B8G8R8_SRGB]         = 0,
  592.       [PIPE_FORMAT_B8G8R8A8_SRGB]         = GEN6_FORMAT_B8G8R8A8_UNORM_SRGB,
  593.       [PIPE_FORMAT_B8G8R8X8_SRGB]         = GEN6_FORMAT_B8G8R8X8_UNORM_SRGB,
  594.       [PIPE_FORMAT_A8R8G8B8_SRGB]         = 0,
  595.       [PIPE_FORMAT_X8R8G8B8_SRGB]         = 0,
  596.       [PIPE_FORMAT_R8G8B8A8_SRGB]         = GEN6_FORMAT_R8G8B8A8_UNORM_SRGB,
  597.       [PIPE_FORMAT_DXT1_RGB]              = GEN6_FORMAT_DXT1_RGB,
  598.       [PIPE_FORMAT_DXT1_RGBA]             = GEN6_FORMAT_BC1_UNORM,
  599.       [PIPE_FORMAT_DXT3_RGBA]             = GEN6_FORMAT_BC2_UNORM,
  600.       [PIPE_FORMAT_DXT5_RGBA]             = GEN6_FORMAT_BC3_UNORM,
  601.       [PIPE_FORMAT_DXT1_SRGB]             = GEN6_FORMAT_DXT1_RGB_SRGB,
  602.       [PIPE_FORMAT_DXT1_SRGBA]            = GEN6_FORMAT_BC1_UNORM_SRGB,
  603.       [PIPE_FORMAT_DXT3_SRGBA]            = GEN6_FORMAT_BC2_UNORM_SRGB,
  604.       [PIPE_FORMAT_DXT5_SRGBA]            = GEN6_FORMAT_BC3_UNORM_SRGB,
  605.       [PIPE_FORMAT_RGTC1_UNORM]           = GEN6_FORMAT_BC4_UNORM,
  606.       [PIPE_FORMAT_RGTC1_SNORM]           = GEN6_FORMAT_BC4_SNORM,
  607.       [PIPE_FORMAT_RGTC2_UNORM]           = GEN6_FORMAT_BC5_UNORM,
  608.       [PIPE_FORMAT_RGTC2_SNORM]           = GEN6_FORMAT_BC5_SNORM,
  609.       [PIPE_FORMAT_R8G8_B8G8_UNORM]       = 0,
  610.       [PIPE_FORMAT_G8R8_G8B8_UNORM]       = 0,
  611.       [PIPE_FORMAT_R8SG8SB8UX8U_NORM]     = 0,
  612.       [PIPE_FORMAT_R5SG5SB6U_NORM]        = 0,
  613.       [PIPE_FORMAT_A8B8G8R8_UNORM]        = 0,
  614.       [PIPE_FORMAT_B5G5R5X1_UNORM]        = GEN6_FORMAT_B5G5R5X1_UNORM,
  615.       [PIPE_FORMAT_R10G10B10A2_USCALED]   = GEN6_FORMAT_R10G10B10A2_USCALED,
  616.       [PIPE_FORMAT_R11G11B10_FLOAT]       = GEN6_FORMAT_R11G11B10_FLOAT,
  617.       [PIPE_FORMAT_R9G9B9E5_FLOAT]        = GEN6_FORMAT_R9G9B9E5_SHAREDEXP,
  618.       [PIPE_FORMAT_Z32_FLOAT_S8X24_UINT]  = 0,
  619.       [PIPE_FORMAT_R1_UNORM]              = GEN6_FORMAT_R1_UNORM,
  620.       [PIPE_FORMAT_R10G10B10X2_USCALED]   = GEN6_FORMAT_R10G10B10X2_USCALED,
  621.       [PIPE_FORMAT_R10G10B10X2_SNORM]     = 0,
  622.       [PIPE_FORMAT_L4A4_UNORM]            = 0,
  623.       [PIPE_FORMAT_B10G10R10A2_UNORM]     = GEN6_FORMAT_B10G10R10A2_UNORM,
  624.       [PIPE_FORMAT_R10SG10SB10SA2U_NORM]  = 0,
  625.       [PIPE_FORMAT_R8G8Bx_SNORM]          = 0,
  626.       [PIPE_FORMAT_R8G8B8X8_UNORM]        = GEN6_FORMAT_R8G8B8X8_UNORM,
  627.       [PIPE_FORMAT_B4G4R4X4_UNORM]        = 0,
  628.       [PIPE_FORMAT_X24S8_UINT]            = 0,
  629.       [PIPE_FORMAT_S8X24_UINT]            = 0,
  630.       [PIPE_FORMAT_X32_S8X24_UINT]        = 0,
  631.       [PIPE_FORMAT_B2G3R3_UNORM]          = 0,
  632.       [PIPE_FORMAT_L16A16_UNORM]          = GEN6_FORMAT_L16A16_UNORM,
  633.       [PIPE_FORMAT_A16_UNORM]             = GEN6_FORMAT_A16_UNORM,
  634.       [PIPE_FORMAT_I16_UNORM]             = GEN6_FORMAT_I16_UNORM,
  635.       [PIPE_FORMAT_LATC1_UNORM]           = 0,
  636.       [PIPE_FORMAT_LATC1_SNORM]           = 0,
  637.       [PIPE_FORMAT_LATC2_UNORM]           = 0,
  638.       [PIPE_FORMAT_LATC2_SNORM]           = 0,
  639.       [PIPE_FORMAT_A8_SNORM]              = 0,
  640.       [PIPE_FORMAT_L8_SNORM]              = 0,
  641.       [PIPE_FORMAT_L8A8_SNORM]            = 0,
  642.       [PIPE_FORMAT_I8_SNORM]              = 0,
  643.       [PIPE_FORMAT_A16_SNORM]             = 0,
  644.       [PIPE_FORMAT_L16_SNORM]             = 0,
  645.       [PIPE_FORMAT_L16A16_SNORM]          = 0,
  646.       [PIPE_FORMAT_I16_SNORM]             = 0,
  647.       [PIPE_FORMAT_A16_FLOAT]             = GEN6_FORMAT_A16_FLOAT,
  648.       [PIPE_FORMAT_L16_FLOAT]             = GEN6_FORMAT_L16_FLOAT,
  649.       [PIPE_FORMAT_L16A16_FLOAT]          = GEN6_FORMAT_L16A16_FLOAT,
  650.       [PIPE_FORMAT_I16_FLOAT]             = GEN6_FORMAT_I16_FLOAT,
  651.       [PIPE_FORMAT_A32_FLOAT]             = GEN6_FORMAT_A32_FLOAT,
  652.       [PIPE_FORMAT_L32_FLOAT]             = GEN6_FORMAT_L32_FLOAT,
  653.       [PIPE_FORMAT_L32A32_FLOAT]          = GEN6_FORMAT_L32A32_FLOAT,
  654.       [PIPE_FORMAT_I32_FLOAT]             = GEN6_FORMAT_I32_FLOAT,
  655.       [PIPE_FORMAT_YV12]                  = 0,
  656.       [PIPE_FORMAT_YV16]                  = 0,
  657.       [PIPE_FORMAT_IYUV]                  = 0,
  658.       [PIPE_FORMAT_NV12]                  = 0,
  659.       [PIPE_FORMAT_NV21]                  = 0,
  660.       [PIPE_FORMAT_A4R4_UNORM]            = 0,
  661.       [PIPE_FORMAT_R4A4_UNORM]            = 0,
  662.       [PIPE_FORMAT_R8A8_UNORM]            = 0,
  663.       [PIPE_FORMAT_A8R8_UNORM]            = 0,
  664.       [PIPE_FORMAT_R10G10B10A2_SSCALED]   = GEN6_FORMAT_R10G10B10A2_SSCALED,
  665.       [PIPE_FORMAT_R10G10B10A2_SNORM]     = GEN6_FORMAT_R10G10B10A2_SNORM,
  666.       [PIPE_FORMAT_B10G10R10A2_USCALED]   = GEN6_FORMAT_B10G10R10A2_USCALED,
  667.       [PIPE_FORMAT_B10G10R10A2_SSCALED]   = GEN6_FORMAT_B10G10R10A2_SSCALED,
  668.       [PIPE_FORMAT_B10G10R10A2_SNORM]     = GEN6_FORMAT_B10G10R10A2_SNORM,
  669.       [PIPE_FORMAT_R8_UINT]               = GEN6_FORMAT_R8_UINT,
  670.       [PIPE_FORMAT_R8G8_UINT]             = GEN6_FORMAT_R8G8_UINT,
  671.       [PIPE_FORMAT_R8G8B8_UINT]           = GEN6_FORMAT_R8G8B8_UINT,
  672.       [PIPE_FORMAT_R8G8B8A8_UINT]         = GEN6_FORMAT_R8G8B8A8_UINT,
  673.       [PIPE_FORMAT_R8_SINT]               = GEN6_FORMAT_R8_SINT,
  674.       [PIPE_FORMAT_R8G8_SINT]             = GEN6_FORMAT_R8G8_SINT,
  675.       [PIPE_FORMAT_R8G8B8_SINT]           = GEN6_FORMAT_R8G8B8_SINT,
  676.       [PIPE_FORMAT_R8G8B8A8_SINT]         = GEN6_FORMAT_R8G8B8A8_SINT,
  677.       [PIPE_FORMAT_R16_UINT]              = GEN6_FORMAT_R16_UINT,
  678.       [PIPE_FORMAT_R16G16_UINT]           = GEN6_FORMAT_R16G16_UINT,
  679.       [PIPE_FORMAT_R16G16B16_UINT]        = GEN6_FORMAT_R16G16B16_UINT,
  680.       [PIPE_FORMAT_R16G16B16A16_UINT]     = GEN6_FORMAT_R16G16B16A16_UINT,
  681.       [PIPE_FORMAT_R16_SINT]              = GEN6_FORMAT_R16_SINT,
  682.       [PIPE_FORMAT_R16G16_SINT]           = GEN6_FORMAT_R16G16_SINT,
  683.       [PIPE_FORMAT_R16G16B16_SINT]        = GEN6_FORMAT_R16G16B16_SINT,
  684.       [PIPE_FORMAT_R16G16B16A16_SINT]     = GEN6_FORMAT_R16G16B16A16_SINT,
  685.       [PIPE_FORMAT_R32_UINT]              = GEN6_FORMAT_R32_UINT,
  686.       [PIPE_FORMAT_R32G32_UINT]           = GEN6_FORMAT_R32G32_UINT,
  687.       [PIPE_FORMAT_R32G32B32_UINT]        = GEN6_FORMAT_R32G32B32_UINT,
  688.       [PIPE_FORMAT_R32G32B32A32_UINT]     = GEN6_FORMAT_R32G32B32A32_UINT,
  689.       [PIPE_FORMAT_R32_SINT]              = GEN6_FORMAT_R32_SINT,
  690.       [PIPE_FORMAT_R32G32_SINT]           = GEN6_FORMAT_R32G32_SINT,
  691.       [PIPE_FORMAT_R32G32B32_SINT]        = GEN6_FORMAT_R32G32B32_SINT,
  692.       [PIPE_FORMAT_R32G32B32A32_SINT]     = GEN6_FORMAT_R32G32B32A32_SINT,
  693.       [PIPE_FORMAT_A8_UINT]               = 0,
  694.       [PIPE_FORMAT_I8_UINT]               = GEN6_FORMAT_I8_UINT,
  695.       [PIPE_FORMAT_L8_UINT]               = GEN6_FORMAT_L8_UINT,
  696.       [PIPE_FORMAT_L8A8_UINT]             = GEN6_FORMAT_L8A8_UINT,
  697.       [PIPE_FORMAT_A8_SINT]               = 0,
  698.       [PIPE_FORMAT_I8_SINT]               = GEN6_FORMAT_I8_SINT,
  699.       [PIPE_FORMAT_L8_SINT]               = GEN6_FORMAT_L8_SINT,
  700.       [PIPE_FORMAT_L8A8_SINT]             = GEN6_FORMAT_L8A8_SINT,
  701.       [PIPE_FORMAT_A16_UINT]              = 0,
  702.       [PIPE_FORMAT_I16_UINT]              = 0,
  703.       [PIPE_FORMAT_L16_UINT]              = 0,
  704.       [PIPE_FORMAT_L16A16_UINT]           = 0,
  705.       [PIPE_FORMAT_A16_SINT]              = 0,
  706.       [PIPE_FORMAT_I16_SINT]              = 0,
  707.       [PIPE_FORMAT_L16_SINT]              = 0,
  708.       [PIPE_FORMAT_L16A16_SINT]           = 0,
  709.       [PIPE_FORMAT_A32_UINT]              = 0,
  710.       [PIPE_FORMAT_I32_UINT]              = 0,
  711.       [PIPE_FORMAT_L32_UINT]              = 0,
  712.       [PIPE_FORMAT_L32A32_UINT]           = 0,
  713.       [PIPE_FORMAT_A32_SINT]              = 0,
  714.       [PIPE_FORMAT_I32_SINT]              = 0,
  715.       [PIPE_FORMAT_L32_SINT]              = 0,
  716.       [PIPE_FORMAT_L32A32_SINT]           = 0,
  717.       [PIPE_FORMAT_B10G10R10A2_UINT]      = GEN6_FORMAT_B10G10R10A2_UINT,
  718.       [PIPE_FORMAT_ETC1_RGB8]             = GEN6_FORMAT_ETC1_RGB8,
  719.       [PIPE_FORMAT_R8G8_R8B8_UNORM]       = 0,
  720.       [PIPE_FORMAT_G8R8_B8R8_UNORM]       = 0,
  721.       [PIPE_FORMAT_R8G8B8X8_SNORM]        = 0,
  722.       [PIPE_FORMAT_R8G8B8X8_SRGB]         = 0,
  723.       [PIPE_FORMAT_R8G8B8X8_UINT]         = 0,
  724.       [PIPE_FORMAT_R8G8B8X8_SINT]         = 0,
  725.       [PIPE_FORMAT_B10G10R10X2_UNORM]     = GEN6_FORMAT_B10G10R10X2_UNORM,
  726.       [PIPE_FORMAT_R16G16B16X16_UNORM]    = GEN6_FORMAT_R16G16B16X16_UNORM,
  727.       [PIPE_FORMAT_R16G16B16X16_SNORM]    = 0,
  728.       [PIPE_FORMAT_R16G16B16X16_FLOAT]    = GEN6_FORMAT_R16G16B16X16_FLOAT,
  729.       [PIPE_FORMAT_R16G16B16X16_UINT]     = 0,
  730.       [PIPE_FORMAT_R16G16B16X16_SINT]     = 0,
  731.       [PIPE_FORMAT_R32G32B32X32_FLOAT]    = GEN6_FORMAT_R32G32B32X32_FLOAT,
  732.       [PIPE_FORMAT_R32G32B32X32_UINT]     = 0,
  733.       [PIPE_FORMAT_R32G32B32X32_SINT]     = 0,
  734.       [PIPE_FORMAT_R8A8_SNORM]            = 0,
  735.       [PIPE_FORMAT_R16A16_UNORM]          = 0,
  736.       [PIPE_FORMAT_R16A16_SNORM]          = 0,
  737.       [PIPE_FORMAT_R16A16_FLOAT]          = 0,
  738.       [PIPE_FORMAT_R32A32_FLOAT]          = 0,
  739.       [PIPE_FORMAT_R8A8_UINT]             = 0,
  740.       [PIPE_FORMAT_R8A8_SINT]             = 0,
  741.       [PIPE_FORMAT_R16A16_UINT]           = 0,
  742.       [PIPE_FORMAT_R16A16_SINT]           = 0,
  743.       [PIPE_FORMAT_R32A32_UINT]           = 0,
  744.       [PIPE_FORMAT_R32A32_SINT]           = 0,
  745.       [PIPE_FORMAT_R10G10B10A2_UINT]      = GEN6_FORMAT_R10G10B10A2_UINT,
  746.       [PIPE_FORMAT_B5G6R5_SRGB]           = GEN6_FORMAT_B5G6R5_UNORM_SRGB,
  747.    };
  748.    int sfmt = format_mapping[format];
  749.  
  750.    /* GEN6_FORMAT_R32G32B32A32_FLOAT happens to be 0 */
  751.    if (!sfmt && format != PIPE_FORMAT_R32G32B32A32_FLOAT)
  752.       sfmt = -1;
  753.  
  754.    return sfmt;
  755. }
  756.