Mesa (master): zink: handle errors in nir_to_spirv
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Mon Mar 29 15:26:42 UTC 2021
Module: Mesa
Branch: master
Commit: 904b5eb2af5b2afa3f4ac267d0e04ba39c412c0a
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=904b5eb2af5b2afa3f4ac267d0e04ba39c412c0a
Author: Erik Faye-Lund <erik.faye-lund at collabora.com>
Date: Thu Feb 4 14:28:46 2021 +0100
zink: handle errors in nir_to_spirv
We already have some appropriate error-handling further down here.
Reviewed-By: Mike Blumenkrantz <michael.blumenkrantz at gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/9836>
---
src/gallium/drivers/zink/zink_compiler.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/src/gallium/drivers/zink/zink_compiler.c b/src/gallium/drivers/zink/zink_compiler.c
index 09d90dee267..fbbe66e99a7 100644
--- a/src/gallium/drivers/zink/zink_compiler.c
+++ b/src/gallium/drivers/zink/zink_compiler.c
@@ -506,7 +506,8 @@ zink_shader_compile(struct zink_screen *screen, struct zink_shader *zs, struct z
}
NIR_PASS_V(nir, nir_convert_from_ssa, true);
struct spirv_shader *spirv = nir_to_spirv(nir, streamout, shader_slot_map, shader_slots_reserved);
- assert(spirv);
+ if (!spirv)
+ goto done;
if (zink_debug & ZINK_DEBUG_SPIRV) {
char buf[256];
@@ -528,6 +529,7 @@ zink_shader_compile(struct zink_screen *screen, struct zink_shader *zs, struct z
if (vkCreateShaderModule(screen->dev, &smci, NULL, &mod) != VK_SUCCESS)
mod = VK_NULL_HANDLE;
+done:
if (nir != zs->nir)
ralloc_free(nir);
More information about the mesa-commit
mailing list