Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 1 | /************************************************************************** |
| 2 | * |
José Fonseca | 8771285 | 2014-01-17 16:27:50 +0000 | [diff] [blame] | 3 | * Copyright 2008 VMware, Inc. |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 4 | * All Rights Reserved. |
| 5 | * |
| 6 | * Permission is hereby granted, free of charge, to any person obtaining a |
| 7 | * copy of this software and associated documentation files (the |
| 8 | * "Software"), to deal in the Software without restriction, including |
| 9 | * without limitation the rights to use, copy, modify, merge, publish, |
| 10 | * distribute, sub license, and/or sell copies of the Software, and to |
| 11 | * permit persons to whom the Software is furnished to do so, subject to |
| 12 | * the following conditions: |
| 13 | * |
| 14 | * The above copyright notice and this permission notice (including the |
| 15 | * next paragraph) shall be included in all copies or substantial portions |
| 16 | * of the Software. |
| 17 | * |
| 18 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| 19 | * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| 20 | * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. |
José Fonseca | 8771285 | 2014-01-17 16:27:50 +0000 | [diff] [blame] | 21 | * IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 22 | * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
| 23 | * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
| 24 | * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
| 25 | * |
| 26 | **************************************************************************/ |
| 27 | |
| 28 | |
Vinson Lee | d4d48c0 | 2010-09-13 23:42:35 -0700 | [diff] [blame] | 29 | #include "draw/draw_context.h" |
Emil Velikov | 5b9cb13 | 2014-08-14 20:11:32 +0100 | [diff] [blame] | 30 | #include "os/os_misc.h" |
Marcin Slusarz | b5dfc38 | 2011-04-16 22:15:52 +0200 | [diff] [blame] | 31 | #include "util/u_format.h" |
Christopher Egert | 608a4a1 | 2011-04-29 02:13:35 +0200 | [diff] [blame] | 32 | #include "util/u_format_s3tc.h" |
José Fonseca | 2848688 | 2010-02-02 14:42:17 +0000 | [diff] [blame] | 33 | #include "util/u_inlines.h" |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 34 | #include "util/u_memory.h" |
José Fonseca | 5b8fa51 | 2008-04-14 23:55:36 +0900 | [diff] [blame] | 35 | #include "util/u_string.h" |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 36 | |
| 37 | #include "i915_reg.h" |
Jakob Bornecrantz | abbb1bd | 2010-06-12 14:09:59 +0200 | [diff] [blame] | 38 | #include "i915_debug.h" |
José Fonseca | f81b7a6 | 2008-02-27 15:59:09 +0900 | [diff] [blame] | 39 | #include "i915_context.h" |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 40 | #include "i915_screen.h" |
Keith Whitwell | 287c94e | 2010-04-10 16:05:54 +0100 | [diff] [blame] | 41 | #include "i915_resource.h" |
Jakob Bornecrantz | bc88c95 | 2010-03-25 19:19:00 +0100 | [diff] [blame] | 42 | #include "i915_winsys.h" |
Jakob Bornecrantz | c701587 | 2010-06-01 04:38:24 +0100 | [diff] [blame] | 43 | #include "i915_public.h" |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 44 | |
| 45 | |
| 46 | /* |
| 47 | * Probe functions |
| 48 | */ |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 49 | |
| 50 | |
| 51 | static const char * |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 52 | i915_get_vendor(struct pipe_screen *screen) |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 53 | { |
José Fonseca | a1e528a | 2014-01-20 14:15:04 +0000 | [diff] [blame] | 54 | return "Mesa Project"; |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 55 | } |
| 56 | |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 57 | static const char * |
Giuseppe Bilotta | 76039b3 | 2015-03-22 07:21:01 +0100 | [diff] [blame] | 58 | i915_get_device_vendor(struct pipe_screen *screen) |
| 59 | { |
| 60 | return "Intel"; |
| 61 | } |
| 62 | |
| 63 | static const char * |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 64 | i915_get_name(struct pipe_screen *screen) |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 65 | { |
| 66 | static char buffer[128]; |
| 67 | const char *chipset; |
| 68 | |
Jakob Bornecrantz | 835f5a6 | 2010-05-29 13:29:44 +0200 | [diff] [blame] | 69 | switch (i915_screen(screen)->iws->pci_id) { |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 70 | case PCI_CHIP_I915_G: |
| 71 | chipset = "915G"; |
| 72 | break; |
| 73 | case PCI_CHIP_I915_GM: |
| 74 | chipset = "915GM"; |
| 75 | break; |
| 76 | case PCI_CHIP_I945_G: |
| 77 | chipset = "945G"; |
| 78 | break; |
| 79 | case PCI_CHIP_I945_GM: |
| 80 | chipset = "945GM"; |
| 81 | break; |
| 82 | case PCI_CHIP_I945_GME: |
| 83 | chipset = "945GME"; |
| 84 | break; |
| 85 | case PCI_CHIP_G33_G: |
| 86 | chipset = "G33"; |
| 87 | break; |
| 88 | case PCI_CHIP_Q35_G: |
| 89 | chipset = "Q35"; |
| 90 | break; |
| 91 | case PCI_CHIP_Q33_G: |
| 92 | chipset = "Q33"; |
| 93 | break; |
Daniel Vetter | 8624fe7 | 2010-11-19 23:38:20 +0100 | [diff] [blame] | 94 | case PCI_CHIP_PINEVIEW_G: |
| 95 | chipset = "Pineview G"; |
| 96 | break; |
| 97 | case PCI_CHIP_PINEVIEW_M: |
| 98 | chipset = "Pineview M"; |
| 99 | break; |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 100 | default: |
| 101 | chipset = "unknown"; |
| 102 | break; |
| 103 | } |
| 104 | |
José Fonseca | 5b8fa51 | 2008-04-14 23:55:36 +0900 | [diff] [blame] | 105 | util_snprintf(buffer, sizeof(buffer), "i915 (chipset: %s)", chipset); |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 106 | return buffer; |
| 107 | } |
| 108 | |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 109 | static int |
Brian Paul | 637e571 | 2017-03-05 12:13:02 -0700 | [diff] [blame] | 110 | i915_get_shader_param(struct pipe_screen *screen, |
| 111 | enum pipe_shader_type shader, |
| 112 | enum pipe_shader_cap cap) |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 113 | { |
| 114 | switch(shader) { |
| 115 | case PIPE_SHADER_VERTEX: |
Marek Olšák | f5bfe54 | 2011-09-27 22:22:06 +0200 | [diff] [blame] | 116 | switch (cap) { |
| 117 | case PIPE_SHADER_CAP_MAX_TEXTURE_SAMPLERS: |
Roland Scheidegger | 2983c03 | 2013-11-26 02:30:41 +0100 | [diff] [blame] | 118 | case PIPE_SHADER_CAP_MAX_SAMPLER_VIEWS: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 119 | if (debug_get_bool_option("DRAW_USE_LLVM", TRUE)) |
Brian Paul | cab2fed | 2012-08-09 20:59:44 -0600 | [diff] [blame] | 120 | return PIPE_MAX_SAMPLERS; |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 121 | else |
| 122 | return 0; |
Stéphane Marchesin | 45fc069 | 2012-06-25 19:45:56 -0700 | [diff] [blame] | 123 | default: |
Marek Olšák | f5bfe54 | 2011-09-27 22:22:06 +0200 | [diff] [blame] | 124 | return draw_get_shader_param(shader, cap); |
| 125 | } |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 126 | case PIPE_SHADER_FRAGMENT: |
Stéphane Marchesin | 642d11d | 2011-12-08 19:22:13 -0800 | [diff] [blame] | 127 | /* XXX: some of these are just shader model 2.0 values, fix this! */ |
Stéphane Marchesin | cd41960 | 2011-10-08 17:12:37 -0700 | [diff] [blame] | 128 | switch(cap) { |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 129 | case PIPE_SHADER_CAP_MAX_INSTRUCTIONS: |
Stéphane Marchesin | 0b3842e | 2011-10-17 21:43:19 -0700 | [diff] [blame] | 130 | return I915_MAX_ALU_INSN + I915_MAX_TEX_INSN; |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 131 | case PIPE_SHADER_CAP_MAX_ALU_INSTRUCTIONS: |
Stéphane Marchesin | 0b3842e | 2011-10-17 21:43:19 -0700 | [diff] [blame] | 132 | return I915_MAX_ALU_INSN; |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 133 | case PIPE_SHADER_CAP_MAX_TEX_INSTRUCTIONS: |
Stéphane Marchesin | 0b3842e | 2011-10-17 21:43:19 -0700 | [diff] [blame] | 134 | return I915_MAX_TEX_INSN; |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 135 | case PIPE_SHADER_CAP_MAX_TEX_INDIRECTIONS: |
| 136 | return 8; |
| 137 | case PIPE_SHADER_CAP_MAX_CONTROL_FLOW_DEPTH: |
| 138 | return 0; |
| 139 | case PIPE_SHADER_CAP_MAX_INPUTS: |
| 140 | return 10; |
Marek Olšák | 5f5b83c | 2014-10-01 20:28:17 +0200 | [diff] [blame] | 141 | case PIPE_SHADER_CAP_MAX_OUTPUTS: |
| 142 | return 1; |
Marek Olšák | 04f2c88 | 2014-07-24 20:32:08 +0200 | [diff] [blame] | 143 | case PIPE_SHADER_CAP_MAX_CONST_BUFFER_SIZE: |
| 144 | return 32 * sizeof(float[4]); |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 145 | case PIPE_SHADER_CAP_MAX_CONST_BUFFERS: |
| 146 | return 1; |
| 147 | case PIPE_SHADER_CAP_MAX_TEMPS: |
| 148 | return 12; /* XXX: 12 -> 32 ? */ |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 149 | case PIPE_SHADER_CAP_TGSI_CONT_SUPPORTED: |
Brian Paul | 13f3ae5 | 2013-02-01 11:16:54 -0700 | [diff] [blame] | 150 | case PIPE_SHADER_CAP_TGSI_SQRT_SUPPORTED: |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 151 | return 0; |
Marek Olšák | 5bf7d66 | 2010-11-12 03:03:43 +0100 | [diff] [blame] | 152 | case PIPE_SHADER_CAP_INDIRECT_INPUT_ADDR: |
| 153 | case PIPE_SHADER_CAP_INDIRECT_OUTPUT_ADDR: |
| 154 | case PIPE_SHADER_CAP_INDIRECT_TEMP_ADDR: |
| 155 | case PIPE_SHADER_CAP_INDIRECT_CONST_ADDR: |
| 156 | return 1; |
Marek Olšák | 9aa089e | 2010-11-14 15:34:59 +0100 | [diff] [blame] | 157 | case PIPE_SHADER_CAP_SUBROUTINES: |
| 158 | return 0; |
Bryan Cain | 17b695e | 2011-05-05 21:10:28 -0500 | [diff] [blame] | 159 | case PIPE_SHADER_CAP_INTEGERS: |
| 160 | return 0; |
Marek Olšák | f5bfe54 | 2011-09-27 22:22:06 +0200 | [diff] [blame] | 161 | case PIPE_SHADER_CAP_MAX_TEXTURE_SAMPLERS: |
Roland Scheidegger | 2983c03 | 2013-11-26 02:30:41 +0100 | [diff] [blame] | 162 | case PIPE_SHADER_CAP_MAX_SAMPLER_VIEWS: |
Stéphane Marchesin | 0b3842e | 2011-10-17 21:43:19 -0700 | [diff] [blame] | 163 | return I915_TEX_UNITS; |
Ilia Mirkin | c85a686 | 2015-02-19 23:30:36 -0500 | [diff] [blame] | 164 | case PIPE_SHADER_CAP_TGSI_DROUND_SUPPORTED: |
| 165 | case PIPE_SHADER_CAP_TGSI_DFRACEXP_DLDEXP_SUPPORTED: |
Marek Olšák | 216543e | 2015-02-28 00:26:31 +0100 | [diff] [blame] | 166 | case PIPE_SHADER_CAP_TGSI_FMA_SUPPORTED: |
Marek Olšák | b6ebe7e | 2015-05-25 19:30:44 +0200 | [diff] [blame] | 167 | case PIPE_SHADER_CAP_TGSI_ANY_INOUT_DECL_RANGE: |
Ilia Mirkin | c85a686 | 2015-02-19 23:30:36 -0500 | [diff] [blame] | 168 | return 0; |
Marek Olšák | 814f314 | 2015-10-20 18:26:02 +0200 | [diff] [blame] | 169 | case PIPE_SHADER_CAP_MAX_UNROLL_ITERATIONS_HINT: |
| 170 | return 32; |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 171 | default: |
Vinson Lee | ac85ab0 | 2011-05-12 23:21:36 -0700 | [diff] [blame] | 172 | debug_printf("%s: Unknown cap %u.\n", __FUNCTION__, cap); |
Vinson Lee | 706380c | 2010-09-13 23:58:42 -0700 | [diff] [blame] | 173 | return 0; |
Stéphane Marchesin | cd41960 | 2011-10-08 17:12:37 -0700 | [diff] [blame] | 174 | } |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 175 | break; |
Stéphane Marchesin | cd41960 | 2011-10-08 17:12:37 -0700 | [diff] [blame] | 176 | default: |
| 177 | return 0; |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 178 | } |
Stéphane Marchesin | cd41960 | 2011-10-08 17:12:37 -0700 | [diff] [blame] | 179 | |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 180 | } |
| 181 | |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 182 | static int |
| 183 | i915_get_param(struct pipe_screen *screen, enum pipe_cap cap) |
| 184 | { |
| 185 | struct i915_screen *is = i915_screen(screen); |
| 186 | |
| 187 | switch (cap) { |
| 188 | /* Supported features (boolean caps). */ |
| 189 | case PIPE_CAP_ANISOTROPIC_FILTER: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 190 | case PIPE_CAP_NPOT_TEXTURES: |
Ilia Mirkin | 12d39b4 | 2013-10-04 04:32:15 -0400 | [diff] [blame] | 191 | case PIPE_CAP_MIXED_FRAMEBUFFER_SIZES: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 192 | case PIPE_CAP_POINT_SPRITE: |
| 193 | case PIPE_CAP_PRIMITIVE_RESTART: /* draw module */ |
| 194 | case PIPE_CAP_TEXTURE_SHADOW_MAP: |
| 195 | case PIPE_CAP_TWO_SIDED_STENCIL: |
| 196 | case PIPE_CAP_VERTEX_ELEMENT_INSTANCE_DIVISOR: |
| 197 | case PIPE_CAP_BLEND_EQUATION_SEPARATE: |
Stéphane Marchesin | 9977fb4 | 2011-10-09 17:14:16 -0700 | [diff] [blame] | 198 | case PIPE_CAP_TGSI_INSTANCEID: |
Marek Olšák | bc1c836 | 2012-01-23 03:11:17 +0100 | [diff] [blame] | 199 | case PIPE_CAP_VERTEX_COLOR_CLAMPED: |
Marek Olšák | 978c1aa1 | 2012-04-11 15:40:00 +0200 | [diff] [blame] | 200 | case PIPE_CAP_USER_VERTEX_BUFFERS: |
Marek Olšák | 437ab1d | 2012-04-24 15:19:31 +0200 | [diff] [blame] | 201 | case PIPE_CAP_USER_CONSTANT_BUFFERS: |
Ilia Mirkin | 9515d65 | 2016-08-20 22:40:33 -0400 | [diff] [blame] | 202 | case PIPE_CAP_MIXED_COLOR_DEPTH_BITS: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 203 | return 1; |
| 204 | |
| 205 | /* Unsupported features (boolean caps). */ |
| 206 | case PIPE_CAP_MAX_TEXTURE_ARRAY_LAYERS: |
Marek Olšák | dc4c821 | 2012-01-10 00:19:00 +0100 | [diff] [blame] | 207 | case PIPE_CAP_DEPTH_CLIP_DISABLE: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 208 | case PIPE_CAP_INDEP_BLEND_ENABLE: |
| 209 | case PIPE_CAP_INDEP_BLEND_FUNC: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 210 | case PIPE_CAP_SHADER_STENCIL_EXPORT: |
| 211 | case PIPE_CAP_TEXTURE_MIRROR_CLAMP: |
| 212 | case PIPE_CAP_TEXTURE_SWIZZLE: |
José Fonseca | 9976216 | 2012-12-09 09:50:34 +0000 | [diff] [blame] | 213 | case PIPE_CAP_QUERY_TIME_ELAPSED: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 214 | case PIPE_CAP_SM3: |
| 215 | case PIPE_CAP_SEAMLESS_CUBE_MAP: |
| 216 | case PIPE_CAP_SEAMLESS_CUBE_MAP_PER_TEXTURE: |
Marek Olšák | bc1c836 | 2012-01-23 03:11:17 +0100 | [diff] [blame] | 217 | case PIPE_CAP_FRAGMENT_COLOR_CLAMPED: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 218 | case PIPE_CAP_MIXED_COLORBUFFER_FORMATS: |
| 219 | case PIPE_CAP_CONDITIONAL_RENDER: |
| 220 | case PIPE_CAP_TEXTURE_BARRIER: |
Stéphane Marchesin | 3c01aef | 2011-12-15 11:10:32 -0800 | [diff] [blame] | 221 | case PIPE_CAP_TGSI_CAN_COMPACT_CONSTANTS: |
Marek Olšák | bc1c836 | 2012-01-23 03:11:17 +0100 | [diff] [blame] | 222 | case PIPE_CAP_VERTEX_COLOR_UNCLAMPED: |
Christoph Bumiller | 8b4f7b0 | 2012-02-06 16:29:03 +0100 | [diff] [blame] | 223 | case PIPE_CAP_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION: |
Fredrik Höglund | af37212 | 2012-06-18 22:50:02 +0200 | [diff] [blame] | 224 | case PIPE_CAP_START_INSTANCE: |
Marek Olšák | bcc735a | 2012-07-05 20:04:02 +0200 | [diff] [blame] | 225 | case PIPE_CAP_QUERY_TIMESTAMP: |
Christoph Bumiller | f35e96d | 2013-03-29 13:02:49 +0100 | [diff] [blame] | 226 | case PIPE_CAP_QUERY_PIPELINE_STATISTICS: |
Marek Olšák | b9c9dd4 | 2012-09-11 22:41:20 +0200 | [diff] [blame] | 227 | case PIPE_CAP_TEXTURE_MULTISAMPLE: |
Christoph Bumiller | 729abfd | 2013-04-12 13:42:01 +0200 | [diff] [blame] | 228 | case PIPE_CAP_TEXTURE_BORDER_COLOR_QUIRK: |
Stéphane Marchesin | 023a50d | 2014-01-28 18:28:56 -0800 | [diff] [blame] | 229 | case PIPE_CAP_CUBE_MAP_ARRAY: |
| 230 | case PIPE_CAP_TEXTURE_BUFFER_OBJECTS: |
| 231 | case PIPE_CAP_TGSI_TEXCOORD: |
| 232 | case PIPE_CAP_PREFER_BLIT_BASED_TEXTURE_TRANSFER: |
Dave Airlie | 2fcbec4 | 2013-09-21 18:45:43 +1000 | [diff] [blame] | 233 | case PIPE_CAP_MAX_TEXTURE_GATHER_COMPONENTS: |
| 234 | case PIPE_CAP_TEXTURE_GATHER_SM5: |
Dave Airlie | 76ba50a | 2013-11-27 19:47:51 +1000 | [diff] [blame] | 235 | case PIPE_CAP_FAKE_SW_MSAA: |
Dave Airlie | be5276a | 2014-02-11 13:26:08 +1000 | [diff] [blame] | 236 | case PIPE_CAP_TEXTURE_QUERY_LOD: |
Ilia Mirkin | 88d8d88 | 2014-03-30 18:21:04 -0400 | [diff] [blame] | 237 | case PIPE_CAP_SAMPLE_SHADING: |
Ilia Mirkin | d95df4f | 2014-04-26 23:44:57 -0400 | [diff] [blame] | 238 | case PIPE_CAP_TEXTURE_GATHER_OFFSETS: |
Christoph Bumiller | 4b586a2 | 2014-05-17 01:20:19 +0200 | [diff] [blame] | 239 | case PIPE_CAP_TGSI_VS_WINDOW_SPACE_POSITION: |
Tobias Klausmann | fd5edee | 2014-08-17 03:37:19 +0200 | [diff] [blame] | 240 | case PIPE_CAP_CONDITIONAL_RENDER_INVERTED: |
Mathias Fröhlich | 5608813 | 2014-09-14 15:17:07 +0200 | [diff] [blame] | 241 | case PIPE_CAP_CLIP_HALFZ: |
Roland Scheidegger | ade8b26 | 2014-12-12 04:13:43 +0100 | [diff] [blame] | 242 | case PIPE_CAP_VERTEXID_NOBASE: |
Ilia Mirkin | 7c211a1 | 2015-02-01 09:01:50 -0500 | [diff] [blame] | 243 | case PIPE_CAP_POLYGON_OFFSET_CLAMP: |
Axel Davy | eb1c12d | 2015-01-17 14:30:17 +0100 | [diff] [blame] | 244 | case PIPE_CAP_MULTISAMPLE_Z_RESOLVE: |
Marek Olšák | 8b587ee | 2015-02-10 14:00:57 +0100 | [diff] [blame] | 245 | case PIPE_CAP_RESOURCE_FROM_USER_MEMORY: |
Marek Olšák | 79ffc08a | 2015-04-29 15:44:55 +0200 | [diff] [blame] | 246 | case PIPE_CAP_DEVICE_RESET_STATUS_QUERY: |
Marek Olšák | 2622293 | 2015-06-12 14:24:17 +0200 | [diff] [blame] | 247 | case PIPE_CAP_MAX_SHADER_PATCH_VARYINGS: |
Marek Olšák | 44dc1d3 | 2015-08-10 19:37:01 +0200 | [diff] [blame] | 248 | case PIPE_CAP_TEXTURE_FLOAT_LINEAR: |
| 249 | case PIPE_CAP_TEXTURE_HALF_FLOAT_LINEAR: |
Marek Olšák | 3b7800e | 2015-08-10 02:11:48 +0200 | [diff] [blame] | 250 | case PIPE_CAP_DEPTH_BOUNDS_TEST: |
Ilia Mirkin | f46a53f | 2015-09-11 17:29:49 -0400 | [diff] [blame] | 251 | case PIPE_CAP_TGSI_TXQS: |
Marek Olšák | f3b37e3 | 2015-09-27 19:32:07 +0200 | [diff] [blame] | 252 | case PIPE_CAP_FORCE_PERSAMPLE_INTERP: |
Marek Olšák | d74e7b6 | 2015-09-27 21:02:15 +0200 | [diff] [blame] | 253 | case PIPE_CAP_SHAREABLE_SHADERS: |
Marek Olšák | ce9db16 | 2015-08-24 01:19:35 +0200 | [diff] [blame] | 254 | case PIPE_CAP_COPY_BETWEEN_COMPRESSED_AND_PLAIN_FORMATS: |
Ilia Mirkin | 3695b25 | 2015-11-09 13:27:07 -0500 | [diff] [blame] | 255 | case PIPE_CAP_CLEAR_TEXTURE: |
Ilia Mirkin | 87b4e4e | 2015-12-29 16:49:32 -0500 | [diff] [blame] | 256 | case PIPE_CAP_DRAW_PARAMETERS: |
Ilia Mirkin | e9f43d6 | 2016-01-02 18:55:48 -0500 | [diff] [blame] | 257 | case PIPE_CAP_TGSI_PACK_HALF_FLOAT: |
Marek Olšák | 34738a9 | 2016-01-02 20:45:00 +0100 | [diff] [blame] | 258 | case PIPE_CAP_TGSI_FS_POSITION_IS_SYSVAL: |
| 259 | case PIPE_CAP_TGSI_FS_FACE_IS_INTEGER_SYSVAL: |
Ilia Mirkin | ebfb544 | 2016-01-02 21:56:45 -0500 | [diff] [blame] | 260 | case PIPE_CAP_SHADER_BUFFER_OFFSET_ALIGNMENT: |
Nicolai Hähnle | 654670b | 2016-01-11 17:38:08 -0500 | [diff] [blame] | 261 | case PIPE_CAP_INVALIDATE_BUFFER: |
Charmaine Lee | 3038e89 | 2016-01-14 10:22:17 -0700 | [diff] [blame] | 262 | case PIPE_CAP_GENERATE_MIPMAP: |
Rob Clark | d640837 | 2015-08-10 11:41:29 -0400 | [diff] [blame] | 263 | case PIPE_CAP_STRING_MARKER: |
Nicolai Hähnle | 3abb548 | 2016-01-26 10:26:30 -0500 | [diff] [blame] | 264 | case PIPE_CAP_BUFFER_SAMPLER_VIEW_RGBA_ONLY: |
Nicolai Hähnle | 6af6d7b | 2016-01-26 10:27:58 -0500 | [diff] [blame] | 265 | case PIPE_CAP_SURFACE_REINTERPRET_BLOCKS: |
Marek Olšák | d2e4c9e | 2016-02-01 21:56:50 +0100 | [diff] [blame] | 266 | case PIPE_CAP_QUERY_MEMORY_INFO: |
Marek Olšák | dcb2b77 | 2016-02-29 20:22:37 +0100 | [diff] [blame] | 267 | case PIPE_CAP_PCI_GROUP: |
| 268 | case PIPE_CAP_PCI_BUS: |
| 269 | case PIPE_CAP_PCI_DEVICE: |
| 270 | case PIPE_CAP_PCI_FUNCTION: |
Edward O'Callaghan | 4bc9130 | 2016-02-17 20:59:52 +1100 | [diff] [blame] | 271 | case PIPE_CAP_FRAMEBUFFER_NO_ATTACHMENT: |
Bas Nieuwenhuizen | 70dcd84 | 2016-04-12 15:00:31 +0200 | [diff] [blame] | 272 | case PIPE_CAP_ROBUST_BUFFER_ACCESS_BEHAVIOR: |
Tobias Klausmann | 2be258e | 2016-05-08 22:44:07 +0200 | [diff] [blame] | 273 | case PIPE_CAP_CULL_DISTANCE: |
Kenneth Graunke | 70048eb | 2016-05-20 21:05:34 -0700 | [diff] [blame] | 274 | case PIPE_CAP_PRIMITIVE_RESTART_FOR_PATCHES: |
Dave Airlie | c6b14ba | 2016-06-07 18:30:54 +1000 | [diff] [blame] | 275 | case PIPE_CAP_TGSI_VOTE: |
Ilia Mirkin | 07fcb06 | 2016-06-11 15:26:45 -0400 | [diff] [blame] | 276 | case PIPE_CAP_MAX_WINDOW_RECTANGLES: |
Axel Davy | 59a6929 | 2016-06-13 22:28:32 +0200 | [diff] [blame] | 277 | case PIPE_CAP_POLYGON_OFFSET_UNITS_UNSCALED: |
Nicolai Hähnle | 700a571 | 2016-10-07 09:42:55 +0200 | [diff] [blame] | 278 | case PIPE_CAP_TGSI_ARRAY_COMPONENTS: |
Lyude | ffe2bd6 | 2017-03-16 18:00:05 -0400 | [diff] [blame] | 279 | case PIPE_CAP_POLYGON_MODE_FILL_RECTANGLE: |
Lyude | 467af44 | 2017-05-24 15:42:39 -0400 | [diff] [blame] | 280 | case PIPE_CAP_POST_DEPTH_COVERAGE: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 281 | return 0; |
Stéphane Marchesin | 023a50d | 2014-01-28 18:28:56 -0800 | [diff] [blame] | 282 | |
Stéphane Marchesin | 7f7c7fd | 2012-11-11 02:10:29 -0800 | [diff] [blame] | 283 | case PIPE_CAP_MAX_DUAL_SOURCE_RENDER_TARGETS: |
| 284 | case PIPE_CAP_STREAM_OUTPUT_PAUSE_RESUME: |
Ilia Mirkin | 3fdeb7c | 2016-10-14 00:03:12 -0400 | [diff] [blame] | 285 | case PIPE_CAP_STREAM_OUTPUT_INTERLEAVE_BUFFERS: |
Stéphane Marchesin | 7f7c7fd | 2012-11-11 02:10:29 -0800 | [diff] [blame] | 286 | case PIPE_CAP_VERTEX_BUFFER_OFFSET_4BYTE_ALIGNED_ONLY: |
| 287 | case PIPE_CAP_VERTEX_BUFFER_STRIDE_4BYTE_ALIGNED_ONLY: |
| 288 | case PIPE_CAP_VERTEX_ELEMENT_SRC_OFFSET_4BYTE_ALIGNED_ONLY: |
Ilia Mirkin | 32b7124 | 2014-07-03 11:15:18 -0400 | [diff] [blame] | 289 | case PIPE_CAP_TGSI_VS_LAYER_VIEWPORT: |
Marek Olšák | db8886e | 2014-01-27 21:57:42 +0100 | [diff] [blame] | 290 | case PIPE_CAP_BUFFER_MAP_PERSISTENT_COHERENT: |
Christoph Bumiller | bc198f8 | 2013-04-05 14:29:36 +0200 | [diff] [blame] | 291 | case PIPE_CAP_DRAW_INDIRECT: |
Ilia Mirkin | d67b9ba | 2015-12-31 13:30:13 -0500 | [diff] [blame] | 292 | case PIPE_CAP_MULTI_DRAW_INDIRECT: |
| 293 | case PIPE_CAP_MULTI_DRAW_INDIRECT_PARAMS: |
Ilia Mirkin | 8ee74ce | 2014-08-14 00:04:41 -0400 | [diff] [blame] | 294 | case PIPE_CAP_TGSI_FS_FINE_DERIVATIVE: |
Ilia Mirkin | c113095 | 2014-08-20 19:45:10 -0400 | [diff] [blame] | 295 | case PIPE_CAP_SAMPLER_VIEW_TARGET: |
Józef Kucia | 3cd28fe | 2016-07-19 13:07:24 +0200 | [diff] [blame] | 296 | case PIPE_CAP_VIEWPORT_SUBPIXEL_BITS: |
Nicolai Hähnle | 611166b | 2016-11-18 20:49:54 +0100 | [diff] [blame] | 297 | case PIPE_CAP_TGSI_CAN_READ_OUTPUTS: |
Rob Clark | 026a722 | 2016-04-01 16:10:42 -0400 | [diff] [blame] | 298 | case PIPE_CAP_NATIVE_FENCE_FD: |
Marek Olšák | e51baeb | 2016-12-31 13:34:11 +0100 | [diff] [blame] | 299 | case PIPE_CAP_GLSL_OPTIMIZE_CONSERVATIVELY: |
Ilia Mirkin | ee3ebe6 | 2017-01-01 23:10:00 -0500 | [diff] [blame] | 300 | case PIPE_CAP_TGSI_FS_FBFETCH: |
Ilia Mirkin | 6e40938 | 2017-01-16 22:14:38 -0500 | [diff] [blame] | 301 | case PIPE_CAP_TGSI_MUL_ZERO_WINS: |
Nicolai Hähnle | a020cb3 | 2017-01-27 10:35:13 +0100 | [diff] [blame] | 302 | case PIPE_CAP_DOUBLES: |
Dave Airlie | f804506 | 2016-06-09 10:13:03 +1000 | [diff] [blame] | 303 | case PIPE_CAP_INT64: |
Ilia Mirkin | b090033 | 2017-02-04 22:31:29 -0500 | [diff] [blame] | 304 | case PIPE_CAP_INT64_DIVMOD: |
Marek Olšák | bf3cdf0 | 2017-03-07 02:09:03 +0100 | [diff] [blame] | 305 | case PIPE_CAP_TGSI_TEX_TXF_LZ: |
Nicolai Hähnle | d0c7f92 | 2017-03-29 20:44:57 +0200 | [diff] [blame] | 306 | case PIPE_CAP_TGSI_CLOCK: |
Nicolai Hähnle | d6e6fa0 | 2017-02-02 21:10:44 +0100 | [diff] [blame] | 307 | case PIPE_CAP_SPARSE_BUFFER_PAGE_SIZE: |
Nicolai Hähnle | d3e6f6d | 2017-03-30 11:16:09 +0200 | [diff] [blame] | 308 | case PIPE_CAP_TGSI_BALLOT: |
Nicolai Hähnle | 17f24a9 | 2017-04-13 21:54:54 +0200 | [diff] [blame] | 309 | case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT: |
Marek Olšák | 70dcb73 | 2017-04-30 01:18:43 +0200 | [diff] [blame] | 310 | case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX: |
Marek Olšák | 5018937 | 2017-05-15 16:30:30 +0200 | [diff] [blame] | 311 | case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION: |
Samuel Pitoiset | 973822b | 2017-02-16 13:43:16 +0100 | [diff] [blame] | 312 | case PIPE_CAP_BINDLESS_TEXTURE: |
Nicolai Hähnle | 01f1598 | 2017-06-25 18:31:11 +0200 | [diff] [blame] | 313 | case PIPE_CAP_NIR_SAMPLERS_AS_DEREF: |
Nicolai Hähnle | a677799 | 2017-07-26 19:16:14 +0200 | [diff] [blame] | 314 | case PIPE_CAP_QUERY_SO_OVERFLOW: |
Timothy Arceri | 4e4042d | 2017-08-03 13:54:45 +1000 | [diff] [blame^] | 315 | case PIPE_CAP_MEMOBJ: |
Stéphane Marchesin | 023a50d | 2014-01-28 18:28:56 -0800 | [diff] [blame] | 316 | return 0; |
Stéphane Marchesin | 7f7c7fd | 2012-11-11 02:10:29 -0800 | [diff] [blame] | 317 | |
Kenneth Graunke | 2b6e703 | 2014-11-11 17:08:22 -0800 | [diff] [blame] | 318 | case PIPE_CAP_MAX_VIEWPORTS: |
| 319 | return 1; |
| 320 | |
Siavash Eliasi | d273fe7 | 2013-12-03 08:23:06 +0330 | [diff] [blame] | 321 | case PIPE_CAP_MIN_MAP_BUFFER_ALIGNMENT: |
| 322 | return 64; |
| 323 | |
Stéphane Marchesin | 7f7c7fd | 2012-11-11 02:10:29 -0800 | [diff] [blame] | 324 | case PIPE_CAP_GLSL_FEATURE_LEVEL: |
| 325 | return 120; |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 326 | |
Marek Olšák | 1b749dc | 2012-04-24 17:31:17 +0200 | [diff] [blame] | 327 | case PIPE_CAP_CONSTANT_BUFFER_OFFSET_ALIGNMENT: |
| 328 | return 16; |
| 329 | |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 330 | /* Features we can lie about (boolean caps). */ |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 331 | case PIPE_CAP_OCCLUSION_QUERY: |
| 332 | return is->debug.lie ? 1 : 0; |
| 333 | |
| 334 | /* Texturing. */ |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 335 | case PIPE_CAP_MAX_TEXTURE_2D_LEVELS: |
| 336 | return I915_MAX_TEXTURE_2D_LEVELS; |
| 337 | case PIPE_CAP_MAX_TEXTURE_3D_LEVELS: |
| 338 | return I915_MAX_TEXTURE_3D_LEVELS; |
| 339 | case PIPE_CAP_MAX_TEXTURE_CUBE_LEVELS: |
| 340 | return I915_MAX_TEXTURE_2D_LEVELS; |
| 341 | case PIPE_CAP_MIN_TEXEL_OFFSET: |
| 342 | case PIPE_CAP_MAX_TEXEL_OFFSET: |
Ilia Mirkin | c2f9ad5 | 2014-04-09 14:58:53 -0400 | [diff] [blame] | 343 | case PIPE_CAP_MIN_TEXTURE_GATHER_OFFSET: |
| 344 | case PIPE_CAP_MAX_TEXTURE_GATHER_OFFSET: |
Stéphane Marchesin | 67e6a40 | 2011-12-15 12:55:18 -0800 | [diff] [blame] | 345 | case PIPE_CAP_MAX_STREAM_OUTPUT_BUFFERS: |
| 346 | case PIPE_CAP_MAX_STREAM_OUTPUT_SEPARATE_COMPONENTS: |
| 347 | case PIPE_CAP_MAX_STREAM_OUTPUT_INTERLEAVED_COMPONENTS: |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 348 | return 0; |
| 349 | |
| 350 | /* Render targets. */ |
| 351 | case PIPE_CAP_MAX_RENDER_TARGETS: |
| 352 | return 1; |
| 353 | |
Grigori Goronzy | d34d5fd | 2014-02-09 22:56:20 +0100 | [diff] [blame] | 354 | /* Geometry shader output, unsupported. */ |
| 355 | case PIPE_CAP_MAX_GEOMETRY_OUTPUT_VERTICES: |
| 356 | case PIPE_CAP_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS: |
Ilia Mirkin | 746e526 | 2014-06-26 20:01:50 -0400 | [diff] [blame] | 357 | case PIPE_CAP_MAX_VERTEX_STREAMS: |
Grigori Goronzy | d34d5fd | 2014-02-09 22:56:20 +0100 | [diff] [blame] | 358 | return 0; |
| 359 | |
Timothy Arceri | 89e6806 | 2014-08-19 21:09:58 -1000 | [diff] [blame] | 360 | case PIPE_CAP_MAX_VERTEX_ATTRIB_STRIDE: |
| 361 | return 2048; |
| 362 | |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 363 | /* Fragment coordinate conventions. */ |
| 364 | case PIPE_CAP_TGSI_FS_COORD_ORIGIN_UPPER_LEFT: |
| 365 | case PIPE_CAP_TGSI_FS_COORD_PIXEL_CENTER_HALF_INTEGER: |
| 366 | return 1; |
| 367 | case PIPE_CAP_TGSI_FS_COORD_ORIGIN_LOWER_LEFT: |
| 368 | case PIPE_CAP_TGSI_FS_COORD_PIXEL_CENTER_INTEGER: |
| 369 | return 0; |
Tom Stellard | 4e90bc9 | 2013-07-09 21:21:39 -0700 | [diff] [blame] | 370 | case PIPE_CAP_ENDIANNESS: |
| 371 | return PIPE_ENDIAN_LITTLE; |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 372 | |
Emil Velikov | 5b9cb13 | 2014-08-14 20:11:32 +0100 | [diff] [blame] | 373 | case PIPE_CAP_VENDOR_ID: |
| 374 | return 0x8086; |
| 375 | case PIPE_CAP_DEVICE_ID: |
| 376 | return is->iws->pci_id; |
| 377 | case PIPE_CAP_ACCELERATED: |
| 378 | return 1; |
| 379 | case PIPE_CAP_VIDEO_MEMORY: { |
| 380 | /* Once a batch uses more than 75% of the maximum mappable size, we |
| 381 | * assume that there's some fragmentation, and we start doing extra |
| 382 | * flushing, etc. That's the big cliff apps will care about. |
| 383 | */ |
| 384 | const int gpu_mappable_megabytes = is->iws->aperture_size(is->iws) * 3 / 4; |
| 385 | uint64_t system_memory; |
| 386 | |
| 387 | if (!os_get_total_physical_memory(&system_memory)) |
| 388 | return 0; |
| 389 | |
Emil Velikov | cc313b3 | 2014-08-14 20:46:29 +0100 | [diff] [blame] | 390 | return MIN2(gpu_mappable_megabytes, (int)(system_memory >> 20)); |
Emil Velikov | 5b9cb13 | 2014-08-14 20:11:32 +0100 | [diff] [blame] | 391 | } |
| 392 | case PIPE_CAP_UMA: |
| 393 | return 1; |
| 394 | |
Stéphane Marchesin | 8a22064 | 2011-10-08 23:54:53 -0700 | [diff] [blame] | 395 | default: |
| 396 | debug_printf("%s: Unknown cap %u.\n", __FUNCTION__, cap); |
| 397 | return 0; |
| 398 | } |
| 399 | } |
| 400 | |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 401 | static float |
Marek Olšák | bb71f92 | 2011-11-19 22:38:22 +0100 | [diff] [blame] | 402 | i915_get_paramf(struct pipe_screen *screen, enum pipe_capf cap) |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 403 | { |
Jakob Bornecrantz | e3c9bf1 | 2011-02-20 11:45:48 +0100 | [diff] [blame] | 404 | switch(cap) { |
Marek Olšák | bb71f92 | 2011-11-19 22:38:22 +0100 | [diff] [blame] | 405 | case PIPE_CAPF_MAX_LINE_WIDTH: |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 406 | /* fall-through */ |
Marek Olšák | bb71f92 | 2011-11-19 22:38:22 +0100 | [diff] [blame] | 407 | case PIPE_CAPF_MAX_LINE_WIDTH_AA: |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 408 | return 7.5; |
| 409 | |
Marek Olšák | bb71f92 | 2011-11-19 22:38:22 +0100 | [diff] [blame] | 410 | case PIPE_CAPF_MAX_POINT_WIDTH: |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 411 | /* fall-through */ |
Marek Olšák | bb71f92 | 2011-11-19 22:38:22 +0100 | [diff] [blame] | 412 | case PIPE_CAPF_MAX_POINT_WIDTH_AA: |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 413 | return 255.0; |
| 414 | |
Marek Olšák | bb71f92 | 2011-11-19 22:38:22 +0100 | [diff] [blame] | 415 | case PIPE_CAPF_MAX_TEXTURE_ANISOTROPY: |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 416 | return 4.0; |
| 417 | |
Marek Olšák | bb71f92 | 2011-11-19 22:38:22 +0100 | [diff] [blame] | 418 | case PIPE_CAPF_MAX_TEXTURE_LOD_BIAS: |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 419 | return 16.0; |
| 420 | |
| 421 | default: |
Vinson Lee | ac85ab0 | 2011-05-12 23:21:36 -0700 | [diff] [blame] | 422 | debug_printf("%s: Unknown cap %u.\n", __FUNCTION__, cap); |
Brian | 17188e4 | 2008-02-27 10:15:37 -0700 | [diff] [blame] | 423 | return 0; |
| 424 | } |
| 425 | } |
| 426 | |
Stéphane Marchesin | 1a69b50 | 2011-06-24 16:18:58 -0700 | [diff] [blame] | 427 | boolean |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 428 | i915_is_format_supported(struct pipe_screen *screen, |
Roland Scheidegger | bccf31b | 2010-05-17 21:24:04 +0200 | [diff] [blame] | 429 | enum pipe_format format, |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 430 | enum pipe_texture_target target, |
Roland Scheidegger | bccf31b | 2010-05-17 21:24:04 +0200 | [diff] [blame] | 431 | unsigned sample_count, |
Marek Olšák | e968975 | 2011-03-08 00:01:58 +0100 | [diff] [blame] | 432 | unsigned tex_usage) |
Brian | 364f8ca | 2008-02-27 13:58:06 -0700 | [diff] [blame] | 433 | { |
| 434 | static const enum pipe_format tex_supported[] = { |
José Fonseca | b2b1e89 | 2010-03-01 18:12:19 +0000 | [diff] [blame] | 435 | PIPE_FORMAT_B8G8R8A8_UNORM, |
Stéphane Marchesin | 45fc069 | 2012-06-25 19:45:56 -0700 | [diff] [blame] | 436 | PIPE_FORMAT_B8G8R8A8_SRGB, |
Jakob Bornecrantz | b4b4ac6 | 2010-03-25 00:41:21 +0100 | [diff] [blame] | 437 | PIPE_FORMAT_B8G8R8X8_UNORM, |
Stéphane Marchesin | 465183c | 2011-06-22 16:23:02 -0700 | [diff] [blame] | 438 | PIPE_FORMAT_R8G8B8A8_UNORM, |
| 439 | PIPE_FORMAT_R8G8B8X8_UNORM, |
Stéphane Marchesin | 9020734 | 2014-11-22 00:11:21 -0800 | [diff] [blame] | 440 | PIPE_FORMAT_B4G4R4A4_UNORM, |
José Fonseca | b2b1e89 | 2010-03-01 18:12:19 +0000 | [diff] [blame] | 441 | PIPE_FORMAT_B5G6R5_UNORM, |
Stéphane Marchesin | 9020734 | 2014-11-22 00:11:21 -0800 | [diff] [blame] | 442 | PIPE_FORMAT_B5G5R5A1_UNORM, |
Stéphane Marchesin | 2e481e5 | 2011-06-28 01:41:57 -0700 | [diff] [blame] | 443 | PIPE_FORMAT_B10G10R10A2_UNORM, |
Brian Paul | 54f94a7 | 2008-04-30 16:50:17 -0600 | [diff] [blame] | 444 | PIPE_FORMAT_L8_UNORM, |
| 445 | PIPE_FORMAT_A8_UNORM, |
| 446 | PIPE_FORMAT_I8_UNORM, |
José Fonseca | b2b1e89 | 2010-03-01 18:12:19 +0000 | [diff] [blame] | 447 | PIPE_FORMAT_L8A8_UNORM, |
| 448 | PIPE_FORMAT_UYVY, |
| 449 | PIPE_FORMAT_YUYV, |
Roland Scheidegger | 4bc7b14 | 2010-05-29 01:28:21 +0200 | [diff] [blame] | 450 | /* XXX why not? |
| 451 | PIPE_FORMAT_Z16_UNORM, */ |
Christopher Egert | 608a4a1 | 2011-04-29 02:13:35 +0200 | [diff] [blame] | 452 | PIPE_FORMAT_DXT1_RGB, |
| 453 | PIPE_FORMAT_DXT1_RGBA, |
| 454 | PIPE_FORMAT_DXT3_RGBA, |
| 455 | PIPE_FORMAT_DXT5_RGBA, |
Roland Scheidegger | 4bc7b14 | 2010-05-29 01:28:21 +0200 | [diff] [blame] | 456 | PIPE_FORMAT_Z24X8_UNORM, |
Dave Airlie | 866f9b1 | 2011-09-11 09:45:10 +0100 | [diff] [blame] | 457 | PIPE_FORMAT_Z24_UNORM_S8_UINT, |
Brian | 364f8ca | 2008-02-27 13:58:06 -0700 | [diff] [blame] | 458 | PIPE_FORMAT_NONE /* list terminator */ |
| 459 | }; |
Roland Scheidegger | bccf31b | 2010-05-17 21:24:04 +0200 | [diff] [blame] | 460 | static const enum pipe_format render_supported[] = { |
José Fonseca | b2b1e89 | 2010-03-01 18:12:19 +0000 | [diff] [blame] | 461 | PIPE_FORMAT_B8G8R8A8_UNORM, |
Vasily Khoruzhick | 1f3c5ea | 2011-11-22 19:04:04 +0300 | [diff] [blame] | 462 | PIPE_FORMAT_B8G8R8X8_UNORM, |
Stéphane Marchesin | 465183c | 2011-06-22 16:23:02 -0700 | [diff] [blame] | 463 | PIPE_FORMAT_R8G8B8A8_UNORM, |
Vasily Khoruzhick | 1f3c5ea | 2011-11-22 19:04:04 +0300 | [diff] [blame] | 464 | PIPE_FORMAT_R8G8B8X8_UNORM, |
José Fonseca | b2b1e89 | 2010-03-01 18:12:19 +0000 | [diff] [blame] | 465 | PIPE_FORMAT_B5G6R5_UNORM, |
Stéphane Marchesin | 9020734 | 2014-11-22 00:11:21 -0800 | [diff] [blame] | 466 | PIPE_FORMAT_B5G5R5A1_UNORM, |
| 467 | PIPE_FORMAT_B4G4R4A4_UNORM, |
Stéphane Marchesin | 2e481e5 | 2011-06-28 01:41:57 -0700 | [diff] [blame] | 468 | PIPE_FORMAT_B10G10R10A2_UNORM, |
Stéphane Marchesin | 465183c | 2011-06-22 16:23:02 -0700 | [diff] [blame] | 469 | PIPE_FORMAT_L8_UNORM, |
| 470 | PIPE_FORMAT_A8_UNORM, |
| 471 | PIPE_FORMAT_I8_UNORM, |
Roland Scheidegger | bccf31b | 2010-05-17 21:24:04 +0200 | [diff] [blame] | 472 | PIPE_FORMAT_NONE /* list terminator */ |
| 473 | }; |
| 474 | static const enum pipe_format depth_supported[] = { |
Roland Scheidegger | 4bc7b14 | 2010-05-29 01:28:21 +0200 | [diff] [blame] | 475 | /* XXX why not? |
| 476 | PIPE_FORMAT_Z16_UNORM, */ |
| 477 | PIPE_FORMAT_Z24X8_UNORM, |
Dave Airlie | 866f9b1 | 2011-09-11 09:45:10 +0100 | [diff] [blame] | 478 | PIPE_FORMAT_Z24_UNORM_S8_UINT, |
Brian | 364f8ca | 2008-02-27 13:58:06 -0700 | [diff] [blame] | 479 | PIPE_FORMAT_NONE /* list terminator */ |
| 480 | }; |
| 481 | const enum pipe_format *list; |
| 482 | uint i; |
| 483 | |
Marek Olšák | 75fa5c9 | 2011-04-11 06:23:00 +0200 | [diff] [blame] | 484 | if (!util_format_is_supported(format, tex_usage)) |
| 485 | return FALSE; |
| 486 | |
Roland Scheidegger | bccf31b | 2010-05-17 21:24:04 +0200 | [diff] [blame] | 487 | if (sample_count > 1) |
| 488 | return FALSE; |
| 489 | |
| 490 | if(tex_usage & PIPE_BIND_DEPTH_STENCIL) |
| 491 | list = depth_supported; |
| 492 | else if (tex_usage & PIPE_BIND_RENDER_TARGET) |
| 493 | list = render_supported; |
Marek Olšák | 79eafc1 | 2012-04-11 15:16:09 +0200 | [diff] [blame] | 494 | else if (tex_usage & PIPE_BIND_SAMPLER_VIEW) |
José Fonseca | 8aafc03 | 2008-07-19 12:04:37 +0900 | [diff] [blame] | 495 | list = tex_supported; |
Marek Olšák | 79eafc1 | 2012-04-11 15:16:09 +0200 | [diff] [blame] | 496 | else |
| 497 | return TRUE; /* PIPE_BIND_{VERTEX,INDEX}_BUFFER */ |
Brian | 364f8ca | 2008-02-27 13:58:06 -0700 | [diff] [blame] | 498 | |
| 499 | for (i = 0; list[i] != PIPE_FORMAT_NONE; i++) { |
| 500 | if (list[i] == format) |
| 501 | return TRUE; |
| 502 | } |
| 503 | |
| 504 | return FALSE; |
| 505 | } |
| 506 | |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 507 | |
| 508 | /* |
| 509 | * Fence functions |
| 510 | */ |
| 511 | |
| 512 | |
| 513 | static void |
| 514 | i915_fence_reference(struct pipe_screen *screen, |
| 515 | struct pipe_fence_handle **ptr, |
| 516 | struct pipe_fence_handle *fence) |
| 517 | { |
| 518 | struct i915_screen *is = i915_screen(screen); |
| 519 | |
| 520 | is->iws->fence_reference(is->iws, ptr, fence); |
| 521 | } |
| 522 | |
Marek Olšák | bfe88e6 | 2011-03-07 22:57:54 +0100 | [diff] [blame] | 523 | static boolean |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 524 | i915_fence_finish(struct pipe_screen *screen, |
Marek Olšák | 54272e1 | 2016-08-06 16:41:42 +0200 | [diff] [blame] | 525 | struct pipe_context *ctx, |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 526 | struct pipe_fence_handle *fence, |
Marek Olšák | b39bccb | 2011-03-05 21:23:54 +0100 | [diff] [blame] | 527 | uint64_t timeout) |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 528 | { |
| 529 | struct i915_screen *is = i915_screen(screen); |
| 530 | |
Marek Olšák | 3da1c79 | 2015-06-26 13:13:16 +0200 | [diff] [blame] | 531 | if (!timeout) |
| 532 | return is->iws->fence_signalled(is->iws, fence) == 1; |
| 533 | |
Stéphane Marchesin | 2b4afdb | 2012-01-18 19:23:48 -0800 | [diff] [blame] | 534 | return is->iws->fence_finish(is->iws, fence) == 1; |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 535 | } |
| 536 | |
| 537 | |
| 538 | /* |
| 539 | * Generic functions |
| 540 | */ |
| 541 | |
| 542 | |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 543 | static void |
Jakob Bornecrantz | ec3c5ac | 2011-02-20 11:46:17 +0100 | [diff] [blame] | 544 | i915_flush_frontbuffer(struct pipe_screen *screen, |
| 545 | struct pipe_resource *resource, |
| 546 | unsigned level, unsigned layer, |
Dave Airlie | ba00f2f | 2013-11-28 11:08:11 +1000 | [diff] [blame] | 547 | void *winsys_drawable_handle, |
| 548 | struct pipe_box *sub_box) |
Jakob Bornecrantz | ec3c5ac | 2011-02-20 11:46:17 +0100 | [diff] [blame] | 549 | { |
| 550 | /* XXX: Dummy right now. */ |
| 551 | (void)screen; |
| 552 | (void)resource; |
| 553 | (void)level; |
| 554 | (void)layer; |
| 555 | (void)winsys_drawable_handle; |
Dave Airlie | ba00f2f | 2013-11-28 11:08:11 +1000 | [diff] [blame] | 556 | (void)sub_box; |
Jakob Bornecrantz | ec3c5ac | 2011-02-20 11:46:17 +0100 | [diff] [blame] | 557 | } |
| 558 | |
| 559 | static void |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 560 | i915_destroy_screen(struct pipe_screen *screen) |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 561 | { |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 562 | struct i915_screen *is = i915_screen(screen); |
José Fonseca | 9dcb956 | 2008-08-08 12:23:21 +0100 | [diff] [blame] | 563 | |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 564 | if (is->iws) |
| 565 | is->iws->destroy(is->iws); |
José Fonseca | 9dcb956 | 2008-08-08 12:23:21 +0100 | [diff] [blame] | 566 | |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 567 | FREE(is); |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 568 | } |
| 569 | |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 570 | /** |
| 571 | * Create a new i915_screen object |
| 572 | */ |
| 573 | struct pipe_screen * |
Jakob Bornecrantz | 835f5a6 | 2010-05-29 13:29:44 +0200 | [diff] [blame] | 574 | i915_screen_create(struct i915_winsys *iws) |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 575 | { |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 576 | struct i915_screen *is = CALLOC_STRUCT(i915_screen); |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 577 | |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 578 | if (!is) |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 579 | return NULL; |
| 580 | |
Jakob Bornecrantz | 835f5a6 | 2010-05-29 13:29:44 +0200 | [diff] [blame] | 581 | switch (iws->pci_id) { |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 582 | case PCI_CHIP_I915_G: |
| 583 | case PCI_CHIP_I915_GM: |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 584 | is->is_i945 = FALSE; |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 585 | break; |
| 586 | |
| 587 | case PCI_CHIP_I945_G: |
| 588 | case PCI_CHIP_I945_GM: |
| 589 | case PCI_CHIP_I945_GME: |
| 590 | case PCI_CHIP_G33_G: |
| 591 | case PCI_CHIP_Q33_G: |
| 592 | case PCI_CHIP_Q35_G: |
Daniel Vetter | 8624fe7 | 2010-11-19 23:38:20 +0100 | [diff] [blame] | 593 | case PCI_CHIP_PINEVIEW_G: |
| 594 | case PCI_CHIP_PINEVIEW_M: |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 595 | is->is_i945 = TRUE; |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 596 | break; |
| 597 | |
| 598 | default: |
José Fonseca | baab98a | 2008-03-31 09:02:08 +0900 | [diff] [blame] | 599 | debug_printf("%s: unknown pci id 0x%x, cannot create screen\n", |
Jakob Bornecrantz | 835f5a6 | 2010-05-29 13:29:44 +0200 | [diff] [blame] | 600 | __FUNCTION__, iws->pci_id); |
Vinson Lee | 520b6ab | 2009-11-06 12:00:14 -0800 | [diff] [blame] | 601 | FREE(is); |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 602 | return NULL; |
| 603 | } |
| 604 | |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 605 | is->iws = iws; |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 606 | |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 607 | is->base.destroy = i915_destroy_screen; |
Jakob Bornecrantz | ec3c5ac | 2011-02-20 11:46:17 +0100 | [diff] [blame] | 608 | is->base.flush_frontbuffer = i915_flush_frontbuffer; |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 609 | |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 610 | is->base.get_name = i915_get_name; |
| 611 | is->base.get_vendor = i915_get_vendor; |
Giuseppe Bilotta | 76039b3 | 2015-03-22 07:21:01 +0100 | [diff] [blame] | 612 | is->base.get_device_vendor = i915_get_device_vendor; |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 613 | is->base.get_param = i915_get_param; |
Luca Barbieri | a508d2d | 2010-09-05 20:50:50 +0200 | [diff] [blame] | 614 | is->base.get_shader_param = i915_get_shader_param; |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 615 | is->base.get_paramf = i915_get_paramf; |
| 616 | is->base.is_format_supported = i915_is_format_supported; |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 617 | |
Keith Whitwell | 7f41f54 | 2010-02-08 12:55:59 +0000 | [diff] [blame] | 618 | is->base.context_create = i915_create_context; |
| 619 | |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 620 | is->base.fence_reference = i915_fence_reference; |
Jakob Bornecrantz | d211006 | 2009-08-30 20:49:01 +0100 | [diff] [blame] | 621 | is->base.fence_finish = i915_fence_finish; |
| 622 | |
Keith Whitwell | 287c94e | 2010-04-10 16:05:54 +0100 | [diff] [blame] | 623 | i915_init_screen_resource_functions(is); |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 624 | |
Jakob Bornecrantz | abbb1bd | 2010-06-12 14:09:59 +0200 | [diff] [blame] | 625 | i915_debug_init(is); |
| 626 | |
Christopher Egert | 608a4a1 | 2011-04-29 02:13:35 +0200 | [diff] [blame] | 627 | util_format_s3tc_init(); |
| 628 | |
Jakob Bornecrantz | 1bb3a2c | 2009-08-30 21:10:36 +0100 | [diff] [blame] | 629 | return &is->base; |
Brian | aa59a93 | 2008-02-26 20:15:14 -0700 | [diff] [blame] | 630 | } |