From: Matt Turner Date: Tue, 14 Feb 2017 16:21:43 +0000 (-0800) Subject: anv: Use build-id for pipeline cache UUID. X-Git-Tag: upstream/17.1.0~2234 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=656e30b6860461b2bd725590488126d5e7e10ec1;p=platform%2Fupstream%2Fmesa.git anv: Use build-id for pipeline cache UUID. The --build-id=... ld flag has been present since binutils-2.18, released 28 Aug 2007. Reviewed-by: Jason Ekstrand Reviewed-by: Chad Versace --- diff --git a/src/intel/vulkan/Makefile.am b/src/intel/vulkan/Makefile.am index 95f276e..4197b0e 100644 --- a/src/intel/vulkan/Makefile.am +++ b/src/intel/vulkan/Makefile.am @@ -165,6 +165,7 @@ libvulkan_intel_la_LDFLAGS = \ -module \ -no-undefined \ -avoid-version \ + -Wl,--build-id=sha1 \ $(BSYMBOLIC) \ $(GC_SECTIONS) \ $(LD_NO_UNDEFINED) diff --git a/src/intel/vulkan/anv_device.c b/src/intel/vulkan/anv_device.c index d1a6cc8..cae5fef 100644 --- a/src/intel/vulkan/anv_device.c +++ b/src/intel/vulkan/anv_device.c @@ -21,18 +21,17 @@ * IN THE SOFTWARE. */ -#include #include #include #include #include -#include #include #include #include "anv_private.h" #include "util/strtod.h" #include "util/debug.h" +#include "util/build_id.h" #include "util/vk_util.h" #include "genxml/gen7_pack.h" @@ -56,30 +55,17 @@ compiler_perf_log(void *data, const char *fmt, ...) } static bool -anv_get_function_timestamp(void *ptr, uint32_t* timestamp) -{ - Dl_info info; - struct stat st; - if (!dladdr(ptr, &info) || !info.dli_fname) - return false; - - if (stat(info.dli_fname, &st)) - return false; - - *timestamp = st.st_mtim.tv_sec; - return true; -} - -static bool anv_device_get_cache_uuid(void *uuid) { - uint32_t timestamp; + const struct build_id_note *note = build_id_find_nhdr("libvulkan_intel.so"); + if (!note) + return false; - memset(uuid, 0, VK_UUID_SIZE); - if (!anv_get_function_timestamp(anv_device_get_cache_uuid, ×tamp)) + unsigned len = build_id_length(note); + if (len < VK_UUID_SIZE) return false; - snprintf(uuid, VK_UUID_SIZE, "anv-%d", timestamp); + build_id_read(note, uuid, VK_UUID_SIZE); return true; }