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. |
| 23 | */ |
| 24 | |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 25 | #include "dev.h" |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 26 | #include "shader.h" |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 27 | |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 28 | static XGL_RESULT shader_parse_bil(struct intel_shader *sh, |
| 29 | const struct intel_gpu *gpu, |
| 30 | const struct icd_bil_header *bil, |
| 31 | XGL_SIZE size) |
| 32 | { |
| 33 | struct intel_ir *ir; |
| 34 | |
| 35 | ir = icd_alloc(sizeof(*ir), 0, XGL_SYSTEM_ALLOC_INTERNAL_SHADER); |
| 36 | if (!ir) |
| 37 | return XGL_ERROR_OUT_OF_MEMORY; |
| 38 | |
| 39 | ir->size = size - sizeof(*bil); |
| 40 | |
| 41 | ir->kernel = icd_alloc(ir->size, 0, XGL_SYSTEM_ALLOC_INTERNAL_SHADER); |
| 42 | if (!ir->kernel) { |
| 43 | icd_free(ir); |
| 44 | return XGL_ERROR_OUT_OF_MEMORY; |
| 45 | } |
| 46 | |
| 47 | memcpy(ir->kernel, bil + 1, ir->size); |
| 48 | |
| 49 | sh->ir = ir; |
Chia-I Wu | c123b7f | 2014-08-28 12:18:43 +0800 | [diff] [blame] | 50 | switch (bil->gen_magic) { |
| 51 | case 'v': |
| 52 | sh->uses |= INTEL_SHADER_USE_VID; |
| 53 | sh->in_count = 1; |
Chia-I Wu | 277a8e9 | 2014-08-29 20:02:06 +0800 | [diff] [blame] | 54 | sh->out_count = 2; |
Chia-I Wu | 29641c1 | 2014-08-31 00:35:27 +0800 | [diff] [blame] | 55 | sh->urb_grf_start = 1; |
Courtney Goeltzenleuchter | 39e0021 | 2014-08-29 16:23:22 -0600 | [diff] [blame^] | 56 | sh->urb_read_length = 1; |
Chia-I Wu | c123b7f | 2014-08-28 12:18:43 +0800 | [diff] [blame] | 57 | break; |
| 58 | case 'w': |
| 59 | sh->out_count = 1; |
Chia-I Wu | 8108b4f | 2014-08-29 15:07:19 +0800 | [diff] [blame] | 60 | sh->surface_count = 1; |
Chia-I Wu | 29641c1 | 2014-08-31 00:35:27 +0800 | [diff] [blame] | 61 | sh->urb_grf_start = 2; |
Chia-I Wu | c123b7f | 2014-08-28 12:18:43 +0800 | [diff] [blame] | 62 | break; |
| 63 | default: |
| 64 | break; |
| 65 | } |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 66 | |
| 67 | return XGL_SUCCESS; |
| 68 | } |
| 69 | |
Courtney Goeltzenleuchter | 4250999 | 2014-08-21 17:33:46 -0600 | [diff] [blame] | 70 | static void shader_destroy(struct intel_obj *obj) |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 71 | { |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 72 | struct intel_shader *sh = intel_shader_from_obj(obj); |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 73 | |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 74 | icd_free(sh->ir); |
| 75 | intel_base_destroy(&sh->obj.base); |
| 76 | } |
| 77 | |
| 78 | static XGL_RESULT shader_create(struct intel_dev *dev, |
| 79 | const XGL_SHADER_CREATE_INFO *info, |
| 80 | struct intel_shader **sh_ret) |
| 81 | { |
| 82 | const struct icd_bil_header *bil = |
| 83 | (const struct icd_bil_header *) info->pCode; |
| 84 | struct intel_shader *sh; |
| 85 | XGL_RESULT ret; |
| 86 | |
| 87 | if (info->codeSize < sizeof(*bil)) |
| 88 | return XGL_ERROR_INVALID_MEMORY_SIZE; |
| 89 | if (bil->magic != ICD_BIL_MAGIC) |
| 90 | return XGL_ERROR_BAD_SHADER_CODE; |
| 91 | |
| 92 | sh = (struct intel_shader *) intel_base_create(dev, sizeof(*sh), |
| 93 | dev->base.dbg, XGL_DBG_OBJECT_SHADER, info, 0); |
| 94 | if (!sh) |
| 95 | return XGL_ERROR_OUT_OF_MEMORY; |
| 96 | |
| 97 | ret = shader_parse_bil(sh, dev->gpu, bil, info->codeSize); |
| 98 | if (ret != XGL_SUCCESS) { |
| 99 | shader_destroy(&sh->obj); |
| 100 | return ret; |
| 101 | } |
| 102 | |
| 103 | sh->obj.destroy = shader_destroy; |
| 104 | |
| 105 | *sh_ret = sh; |
| 106 | |
| 107 | return XGL_SUCCESS; |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 108 | } |
| 109 | |
| 110 | XGL_RESULT XGLAPI intelCreateShader( |
| 111 | XGL_DEVICE device, |
| 112 | const XGL_SHADER_CREATE_INFO* pCreateInfo, |
| 113 | XGL_SHADER* pShader) |
| 114 | { |
| 115 | struct intel_dev *dev = intel_dev(device); |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 116 | |
Chia-I Wu | 9194a6d | 2014-08-28 11:36:48 +0800 | [diff] [blame] | 117 | return shader_create(dev, pCreateInfo, (struct intel_shader **) pShader); |
Courtney Goeltzenleuchter | 52ec336 | 2014-08-19 11:52:02 -0600 | [diff] [blame] | 118 | } |