From: Jason Ekstrand Date: Fri, 7 Oct 2016 00:16:51 +0000 (-0700) Subject: anv/entrypoints: Save off the entire devinfo rather than a pointer X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=82b4f1c47b1d6ca326dbd863253d89337f565309;p=mesa.git anv/entrypoints: Save off the entire devinfo rather than a pointer Since the gen_device_info structs are no longer just constant memory, a pointer to one is not a pointer to something in the .data section so we shouldn't be storing it in a static variable. Instead, we should just store the entire device_info structure. Signed-off-by: Jason Ekstrand --- diff --git a/src/intel/vulkan/anv_entrypoints_gen.py b/src/intel/vulkan/anv_entrypoints_gen.py index b0264950d62..aeaeb1db8d5 100644 --- a/src/intel/vulkan/anv_entrypoints_gen.py +++ b/src/intel/vulkan/anv_entrypoints_gen.py @@ -214,22 +214,22 @@ for layer in [ "anv", "gen7", "gen75", "gen8", "gen9" ]: print "};\n" print """ -static const struct gen_device_info *dispatch_devinfo; +static struct gen_device_info dispatch_devinfo; void anv_set_dispatch_devinfo(const struct gen_device_info *devinfo) { - dispatch_devinfo = devinfo; + dispatch_devinfo = *devinfo; } void * __attribute__ ((noinline)) anv_resolve_entrypoint(uint32_t index) { - if (dispatch_devinfo == NULL) { + if (dispatch_devinfo.gen == 0) { return anv_layer.entrypoints[index]; } - switch (dispatch_devinfo->gen) { + switch (dispatch_devinfo.gen) { case 9: if (gen9_layer.entrypoints[index]) return gen9_layer.entrypoints[index]; @@ -239,7 +239,7 @@ anv_resolve_entrypoint(uint32_t index) return gen8_layer.entrypoints[index]; /* fall through */ case 7: - if (dispatch_devinfo->is_haswell && gen75_layer.entrypoints[index]) + if (dispatch_devinfo.is_haswell && gen75_layer.entrypoints[index]) return gen75_layer.entrypoints[index]; if (gen7_layer.entrypoints[index])