<div dir="ltr">It's not the job of the driver to check these things. Developers should be running with validation layers enabled which are supposed to catch this. There are so many other ways things can go wrong if the user provides bad input and this only fixes one tiny one.<br></div><br><div class="gmail_quote"><div dir="ltr">On Mon, Sep 17, 2018 at 4:18 AM Samuel Pitoiset <<a href="mailto:samuel.pitoiset@gmail.com">samuel.pitoiset@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">And return a better error value.<br>
<br>
Bugzilla: <a href="https://bugs.freedesktop.org/show_bug.cgi?id=107954" rel="noreferrer" target="_blank">https://bugs.freedesktop.org/show_bug.cgi?id=107954</a><br>
Signed-off-by: Samuel Pitoiset <<a href="mailto:samuel.pitoiset@gmail.com" target="_blank">samuel.pitoiset@gmail.com</a>><br>
---<br>
src/amd/vulkan/radv_pipeline.c | 32 +++++++++++++++++++++++++-------<br>
src/amd/vulkan/radv_shader.c | 3 +++<br>
2 files changed, 28 insertions(+), 7 deletions(-)<br>
<br>
diff --git a/src/amd/vulkan/radv_pipeline.c b/src/amd/vulkan/radv_pipeline.c<br>
index ae269c32c49..f1e3c6f9fe9 100644<br>
--- a/src/amd/vulkan/radv_pipeline.c<br>
+++ b/src/amd/vulkan/radv_pipeline.c<br>
@@ -1983,8 +1983,8 @@ merge_tess_info(struct shader_info *tes_info,<br>
tes_info->tess.point_mode |= tcs_info->tess.point_mode;<br>
}<br>
<br>
-static<br>
-void radv_create_shaders(struct radv_pipeline *pipeline,<br>
+static VkResult<br>
+radv_create_shaders(struct radv_pipeline *pipeline,<br>
struct radv_device *device,<br>
struct radv_pipeline_cache *cache,<br>
struct radv_pipeline_key key,<br>
@@ -2023,7 +2023,7 @@ void radv_create_shaders(struct radv_pipeline *pipeline,<br>
<br>
if (radv_create_shader_variants_from_pipeline_cache(device, cache, hash, pipeline->shaders) &&<br>
(!modules[MESA_SHADER_GEOMETRY] || pipeline->gs_copy_shader)) {<br>
- return;<br>
+ return VK_SUCCESS;<br>
}<br>
<br>
if (!modules[MESA_SHADER_FRAGMENT] && !modules[MESA_SHADER_COMPUTE]) {<br>
@@ -2056,6 +2056,9 @@ void radv_create_shaders(struct radv_pipeline *pipeline,<br>
stage ? stage->pSpecializationInfo : NULL,<br>
flags);<br>
<br>
+ if (!nir[i])<br>
+ goto fail;<br>
+<br>
/* We don't want to alter meta shaders IR directly so clone it<br>
* first.<br>
*/<br>
@@ -2202,6 +2205,14 @@ void radv_create_shaders(struct radv_pipeline *pipeline,<br>
<br>
if (fs_m.nir)<br>
ralloc_free(fs_m.nir);<br>
+<br>
+ return VK_SUCCESS;<br>
+<br>
+fail:<br>
+ for (int i = 0; i < MESA_SHADER_STAGES; ++i)<br>
+ ralloc_free(nir[i]);<br>
+ ralloc_free(fs_m.nir);<br>
+ return VK_ERROR_INVALID_SHADER_NV;<br>
}<br>
<br>
static uint32_t<br>
@@ -3448,9 +3459,11 @@ radv_pipeline_init(struct radv_pipeline *pipeline,<br>
pStages[stage] = &pCreateInfo->pStages[i];<br>
}<br>
<br>
- radv_create_shaders(pipeline, device, cache, <br>
- radv_generate_graphics_pipeline_key(pipeline, pCreateInfo, &blend, has_view_index),<br>
- pStages, pCreateInfo->flags);<br>
+ result = radv_create_shaders(pipeline, device, cache,<br>
+ radv_generate_graphics_pipeline_key(pipeline, pCreateInfo, &blend, has_view_index),<br>
+ pStages, pCreateInfo->flags);<br>
+ if (result != VK_SUCCESS)<br>
+ return result;<br>
<br>
pipeline->graphics.spi_baryc_cntl = S_0286E0_FRONT_FACE_ALL_BITS(1);<br>
radv_pipeline_init_multisample_state(pipeline, &blend, pCreateInfo);<br>
@@ -3683,7 +3696,12 @@ static VkResult radv_compute_pipeline_create(<br>
assert(pipeline->layout);<br>
<br>
pStages[MESA_SHADER_COMPUTE] = &pCreateInfo->stage;<br>
- radv_create_shaders(pipeline, device, cache, (struct radv_pipeline_key) {0}, pStages, pCreateInfo->flags);<br>
+ result = radv_create_shaders(pipeline, device, cache,<br>
+ (struct radv_pipeline_key) {0}, pStages, pCreateInfo->flags);<br>
+ if (result != VK_SUCCESS) {<br>
+ radv_pipeline_destroy(device, pipeline, pAllocator);<br>
+ return result;<br>
+ }<br>
<br>
pipeline->user_data_0[MESA_SHADER_COMPUTE] = radv_pipeline_stage_to_user_data_0(pipeline, MESA_SHADER_COMPUTE, device->physical_device->rad_info.chip_class);<br>
pipeline->need_indirect_descriptor_sets |= pipeline->shaders[MESA_SHADER_COMPUTE]->info.need_indirect_descriptor_sets;<br>
diff --git a/src/amd/vulkan/radv_shader.c b/src/amd/vulkan/radv_shader.c<br>
index 51e0b7d65fc..9fd7b478a3e 100644<br>
--- a/src/amd/vulkan/radv_shader.c<br>
+++ b/src/amd/vulkan/radv_shader.c<br>
@@ -230,6 +230,9 @@ radv_shader_compile_to_nir(struct radv_device *device,<br>
spec_entries, num_spec_entries,<br>
stage, entrypoint_name,<br>
&spirv_options, &nir_options);<br>
+ if (!entry_point)<br>
+ return NULL;<br>
+<br>
nir = entry_point->shader;<br>
assert(nir->info.stage == stage);<br>
nir_validate_shader(nir);<br>
-- <br>
2.19.0<br>
<br>
_______________________________________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org" target="_blank">mesa-dev@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev" rel="noreferrer" target="_blank">https://lists.freedesktop.org/mailman/listinfo/mesa-dev</a><br>
</blockquote></div>