Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 1 | /* |
| 2 | * XGL |
| 3 | * |
| 4 | * Copyright (C) 2014 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. |
Chia-I Wu | 44e4236 | 2014-09-02 08:32:09 +0800 | [diff] [blame] | 23 | * |
| 24 | * Authors: |
| 25 | * Courtney Goeltzenleuchter <courtney@lunarg.com> |
| 26 | * Chia-I Wu <olv@lunarg.com> |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 27 | */ |
| 28 | |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 29 | #include "dev.h" |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 30 | #include "shader.h" |
Cody Northrop | 0eb5eea | 2014-09-19 15:11:52 -0600 | [diff] [blame] | 31 | #include "compiler/shader/compiler_interface.h" |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 32 | |
Courtney Goeltzenleuchter | abf612b | 2014-10-06 12:44:43 -0600 | [diff] [blame^] | 33 | static XGL_RESULT shader_parse_glsl(struct intel_shader *sh, |
| 34 | const struct intel_gpu *gpu, |
| 35 | const XGL_INTEL_COMPILE_GLSL *glsl_header, |
| 36 | XGL_SIZE size) |
| 37 | { |
| 38 | struct intel_ir *ir; |
| 39 | |
| 40 | ir = icd_alloc(sizeof(*ir), 0, XGL_SYSTEM_ALLOC_INTERNAL_SHADER); |
| 41 | if (!ir) |
| 42 | return XGL_ERROR_OUT_OF_MEMORY; |
| 43 | |
| 44 | // invoke our program creation as well |
| 45 | ir->shader_program = shader_create_program(sh, glsl_header); |
| 46 | if (!ir->shader_program) |
| 47 | return XGL_ERROR_BAD_SHADER_CODE; |
| 48 | |
| 49 | // TODO: set necessary shader information. This should really |
| 50 | // happen as result of create_program call. |
| 51 | sh->ir = ir; |
| 52 | switch (glsl_header->stage) { |
| 53 | case XGL_SHADER_STAGE_VERTEX: |
| 54 | sh->uses |= INTEL_SHADER_USE_VID; |
| 55 | sh->in_count = 1; |
| 56 | sh->out_count = 2; |
| 57 | sh->urb_grf_start = 1; |
| 58 | break; |
| 59 | case XGL_SHADER_STAGE_FRAGMENT: |
| 60 | sh->out_count = 1; |
| 61 | sh->surface_count = 1; |
| 62 | sh->urb_grf_start = 2; |
| 63 | break; |
| 64 | default: |
| 65 | break; |
| 66 | } |
| 67 | |
| 68 | return XGL_SUCCESS; |
| 69 | } |
| 70 | |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 71 | static XGL_RESULT shader_parse_bil(struct intel_shader *sh, |
| 72 | const struct intel_gpu *gpu, |
| 73 | const struct icd_bil_header *bil, |
| 74 | XGL_SIZE size) |
| 75 | { |
| 76 | struct intel_ir *ir; |
| 77 | |
| 78 | ir = icd_alloc(sizeof(*ir), 0, XGL_SYSTEM_ALLOC_INTERNAL_SHADER); |
| 79 | if (!ir) |
| 80 | return XGL_ERROR_OUT_OF_MEMORY; |
| 81 | |
| 82 | ir->size = size - sizeof(*bil); |
| 83 | |
| 84 | ir->kernel = icd_alloc(ir->size, 0, XGL_SYSTEM_ALLOC_INTERNAL_SHADER); |
| 85 | if (!ir->kernel) { |
| 86 | icd_free(ir); |
| 87 | return XGL_ERROR_OUT_OF_MEMORY; |
| 88 | } |
| 89 | |
Courtney Goeltzenleuchter | abf612b | 2014-10-06 12:44:43 -0600 | [diff] [blame^] | 90 | // TODO: Translate BIL header to internal-IR |
Cody Northrop | 0eb5eea | 2014-09-19 15:11:52 -0600 | [diff] [blame] | 91 | |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 92 | sh->ir = ir; |
Chia-I Wu | c123b7f | 2014-08-28 12:18:43 +0800 | [diff] [blame] | 93 | switch (bil->gen_magic) { |
| 94 | case 'v': |
| 95 | sh->uses |= INTEL_SHADER_USE_VID; |
| 96 | sh->in_count = 1; |
Chia-I Wu | 277a8e9 | 2014-08-29 20:02:06 +0800 | [diff] [blame] | 97 | sh->out_count = 2; |
Chia-I Wu | 29641c1 | 2014-08-31 00:35:27 +0800 | [diff] [blame] | 98 | sh->urb_grf_start = 1; |
Chia-I Wu | c123b7f | 2014-08-28 12:18:43 +0800 | [diff] [blame] | 99 | break; |
| 100 | case 'w': |
| 101 | sh->out_count = 1; |
Chia-I Wu | 8108b4f | 2014-08-29 15:07:19 +0800 | [diff] [blame] | 102 | sh->surface_count = 1; |
Chia-I Wu | 29641c1 | 2014-08-31 00:35:27 +0800 | [diff] [blame] | 103 | sh->urb_grf_start = 2; |
Chia-I Wu | c123b7f | 2014-08-28 12:18:43 +0800 | [diff] [blame] | 104 | break; |
| 105 | default: |
| 106 | break; |
| 107 | } |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 108 | |
| 109 | return XGL_SUCCESS; |
| 110 | } |
| 111 | |
Courtney Goeltzenleuchter | 4250999 | 2014-08-21 17:33:46 -0600 | [diff] [blame] | 112 | static void shader_destroy(struct intel_obj *obj) |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 113 | { |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 114 | struct intel_shader *sh = intel_shader_from_obj(obj); |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 115 | |
Cody Northrop | 0eb5eea | 2014-09-19 15:11:52 -0600 | [diff] [blame] | 116 | shader_destroy_program(sh->ir->shader_program); |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 117 | icd_free(sh->ir); |
| 118 | intel_base_destroy(&sh->obj.base); |
| 119 | } |
| 120 | |
| 121 | static XGL_RESULT shader_create(struct intel_dev *dev, |
| 122 | const XGL_SHADER_CREATE_INFO *info, |
| 123 | struct intel_shader **sh_ret) |
| 124 | { |
| 125 | const struct icd_bil_header *bil = |
| 126 | (const struct icd_bil_header *) info->pCode; |
| 127 | struct intel_shader *sh; |
| 128 | XGL_RESULT ret; |
| 129 | |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 130 | sh = (struct intel_shader *) intel_base_create(dev, sizeof(*sh), |
| 131 | dev->base.dbg, XGL_DBG_OBJECT_SHADER, info, 0); |
| 132 | if (!sh) |
| 133 | return XGL_ERROR_OUT_OF_MEMORY; |
| 134 | |
Courtney Goeltzenleuchter | d7f0dce | 2014-10-06 09:45:33 -0600 | [diff] [blame] | 135 | if (dev->exts[INTEL_EXT_COMPILE_GLSL] && |
| 136 | info->sType == (XGL_STRUCTURE_TYPE) XGL_INTEL_STRUCTURE_TYPE_SHADER_CREATE_INFO) { |
| 137 | // use GLSL compiler extension |
Courtney Goeltzenleuchter | abf612b | 2014-10-06 12:44:43 -0600 | [diff] [blame^] | 138 | ret = shader_parse_glsl(sh, dev->gpu, info->pCode, info->codeSize); |
| 139 | if (ret != XGL_SUCCESS) { |
| 140 | shader_destroy(&sh->obj); |
| 141 | return ret; |
| 142 | } |
Courtney Goeltzenleuchter | d7f0dce | 2014-10-06 09:45:33 -0600 | [diff] [blame] | 143 | } else { |
| 144 | if (info->codeSize < sizeof(*bil)) |
| 145 | return XGL_ERROR_INVALID_MEMORY_SIZE; |
| 146 | if (bil->magic != ICD_BIL_MAGIC) |
| 147 | return XGL_ERROR_BAD_SHADER_CODE; |
| 148 | |
| 149 | |
| 150 | ret = shader_parse_bil(sh, dev->gpu, bil, info->codeSize); |
| 151 | if (ret != XGL_SUCCESS) { |
| 152 | shader_destroy(&sh->obj); |
| 153 | return ret; |
| 154 | } |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 155 | } |
| 156 | |
| 157 | sh->obj.destroy = shader_destroy; |
| 158 | |
| 159 | *sh_ret = sh; |
| 160 | |
| 161 | return XGL_SUCCESS; |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 162 | } |
| 163 | |
| 164 | XGL_RESULT XGLAPI intelCreateShader( |
| 165 | XGL_DEVICE device, |
| 166 | const XGL_SHADER_CREATE_INFO* pCreateInfo, |
| 167 | XGL_SHADER* pShader) |
| 168 | { |
| 169 | struct intel_dev *dev = intel_dev(device); |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 170 | |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 171 | return shader_create(dev, pCreateInfo, (struct intel_shader **) pShader); |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 172 | } |
Courtney Goeltzenleuchter | ff87c82 | 2014-10-03 18:05:10 -0600 | [diff] [blame] | 173 | |
| 174 | XGL_RESULT XGLAPI intelCreateShaderfromGLSL( |
| 175 | XGL_DEVICE device, |
| 176 | const XGL_SHADER_CREATE_INFO* pCreateInfo, |
| 177 | XGL_SHADER* pShader) |
| 178 | { |
| 179 | struct intel_dev *dev = intel_dev(device); |
| 180 | |
| 181 | return shader_create(dev, pCreateInfo, (struct intel_shader **) pShader); |
| 182 | } |