<p dir="ltr"></p>
<p dir="ltr">On Nov 24, 2016 12:42 PM, "Emil Velikov" <<a href="mailto:emil.l.velikov@gmail.com">emil.l.velikov@gmail.com</a>> wrote:<br>
><br>
> From: Emil Velikov <<a href="mailto:emil.velikov@collabora.com">emil.velikov@collabora.com</a>><br>
><br>
> Port of an equivalent commit for radv.<br>
><br>
> Signed-off-by: Emil Velikov <<a href="mailto:emil.velikov@collabora.com">emil.velikov@collabora.com</a>><br>
> ---<br>
> src/intel/vulkan/anv_device.c | 18 ++++++++++--------<br>
> src/intel/vulkan/anv_pipeline_cache.c | 8 ++++----<br>
> src/intel/vulkan/anv_private.h | 4 ++--<br>
> 3 files changed, 16 insertions(+), 14 deletions(-)<br>
><br>
> diff --git a/src/intel/vulkan/anv_device.c b/src/intel/vulkan/anv_device.c<br>
> index 2c8ac49..58c6b3f 100644<br>
> --- a/src/intel/vulkan/anv_device.c<br>
> +++ b/src/intel/vulkan/anv_device.c<br>
> @@ -53,6 +53,13 @@ compiler_perf_log(void *data, const char *fmt, ...)<br>
> va_end(args);<br>
> }<br>
><br>
> +static void<br>
> +anv_device_get_cache_uuid(void *uuid)<br>
> +{<br>
> + memset(uuid, 0, VK_UUID_SIZE);<br>
> + snprintf(uuid, VK_UUID_SIZE, "anv-%s", ANV_TIMESTAMP);</p>
<p dir="ltr">This is just two lines. Let's inline it. Also, it occurs to new that we should also be including the PCI ID in the UUID so that you don't end up using cached shaders on the wrong hardware when using distro builds. If you want that to be a separate patch that's fine. I can also do it. In any case, this seems reasonable. With this guy inlined,</p>
<p dir="ltr">Reviewed-by: Jason Ekstrand <<a href="mailto:jason@jlekstrand.net">jason@jlekstrand.net</a>></p>
<p dir="ltr">> +}<br>
> +<br>
> static VkResult<br>
> anv_physical_device_init(struct anv_physical_device *device,<br>
> struct anv_instance *instance,<br>
> @@ -179,6 +186,8 @@ anv_physical_device_init(struct anv_physical_device *device,<br>
> if (result != VK_SUCCESS)<br>
> goto fail;<br>
><br>
> + anv_device_get_cache_uuid(device->uuid);<br>
> +<br>
> /* XXX: Actually detect bit6 swizzling */<br>
> isl_device_init(&device->isl_dev, &device->info, swizzled);<br>
><br>
> @@ -455,13 +464,6 @@ void anv_GetPhysicalDeviceFeatures(<br>
> pdevice->compiler->scalar_stage[MESA_SHADER_GEOMETRY];<br>
> }<br>
><br>
> -void<br>
> -anv_device_get_cache_uuid(void *uuid)<br>
> -{<br>
> - memset(uuid, 0, VK_UUID_SIZE);<br>
> - snprintf(uuid, VK_UUID_SIZE, "anv-%s", ANV_TIMESTAMP);<br>
> -}<br>
> -<br>
> void anv_GetPhysicalDeviceProperties(<br>
> VkPhysicalDevice physicalDevice,<br>
> VkPhysicalDeviceProperties* pProperties)<br>
> @@ -602,7 +604,7 @@ void anv_GetPhysicalDeviceProperties(<br>
> };<br>
><br>
> strcpy(pProperties->deviceName, pdevice->name);<br>
> - anv_device_get_cache_uuid(pProperties->pipelineCacheUUID);<br>
> + memcpy(pProperties->pipelineCacheUUID, pdevice->uuid, VK_UUID_SIZE);<br>
> }<br>
><br>
> void anv_GetPhysicalDeviceQueueFamilyProperties(<br>
> diff --git a/src/intel/vulkan/anv_pipeline_cache.c b/src/intel/vulkan/anv_pipeline_cache.c<br>
> index ddd51db..a8ea80f 100644<br>
> --- a/src/intel/vulkan/anv_pipeline_cache.c<br>
> +++ b/src/intel/vulkan/anv_pipeline_cache.c<br>
> @@ -333,8 +333,8 @@ anv_pipeline_cache_load(struct anv_pipeline_cache *cache,<br>
> const void *data, size_t size)<br>
> {<br>
> struct anv_device *device = cache->device;<br>
> + struct anv_physical_device *pdevice = &device->instance->physicalDevice;<br>
> struct cache_header header;<br>
> - uint8_t uuid[VK_UUID_SIZE];<br>
><br>
> if (cache->cache == NULL)<br>
> return;<br>
> @@ -350,8 +350,7 @@ anv_pipeline_cache_load(struct anv_pipeline_cache *cache,<br>
> return;<br>
> if (header.device_id != device->chipset_id)<br>
> return;<br>
> - anv_device_get_cache_uuid(uuid);<br>
> - if (memcmp(header.uuid, uuid, VK_UUID_SIZE) != 0)<br>
> + if (memcmp(header.uuid, pdevice->uuid, VK_UUID_SIZE) != 0)<br>
> return;<br>
><br>
> const void *end = data + size;<br>
> @@ -470,6 +469,7 @@ VkResult anv_GetPipelineCacheData(<br>
> {<br>
> ANV_FROM_HANDLE(anv_device, device, _device);<br>
> ANV_FROM_HANDLE(anv_pipeline_cache, cache, _cache);<br>
> + struct anv_physical_device *pdevice = &device->instance->physicalDevice;<br>
> struct cache_header *header;<br>
><br>
> if (pData == NULL) {<br>
> @@ -497,7 +497,7 @@ VkResult anv_GetPipelineCacheData(<br>
> header->header_version = VK_PIPELINE_CACHE_HEADER_VERSION_ONE;<br>
> header->vendor_id = 0x8086;<br>
> header->device_id = device->chipset_id;<br>
> - anv_device_get_cache_uuid(header->uuid);<br>
> + memcpy(header->uuid, pdevice->uuid, VK_UUID_SIZE);<br>
> p += align_u32(header->header_size, 8);<br>
><br>
> uint32_t *count = p;<br>
> diff --git a/src/intel/vulkan/anv_private.h b/src/intel/vulkan/anv_private.h<br>
> index 2fc543d..d3f98e8 100644<br>
> --- a/src/intel/vulkan/anv_private.h<br>
> +++ b/src/intel/vulkan/anv_private.h<br>
> @@ -505,6 +505,8 @@ struct anv_physical_device {<br>
> uint32_t eu_total;<br>
> uint32_t subslice_total;<br>
><br>
> + uint8_t uuid[VK_UUID_SIZE];<br>
> +<br>
> struct wsi_device wsi_device;<br>
> };<br>
><br>
> @@ -596,8 +598,6 @@ struct anv_device {<br>
> pthread_cond_t queue_submit;<br>
> };<br>
><br>
> -void anv_device_get_cache_uuid(void *uuid);<br>
> -<br>
> void anv_device_init_blorp(struct anv_device *device);<br>
> void anv_device_finish_blorp(struct anv_device *device);<br>
><br>
> --<br>
> 2.10.2<br>
><br>
> _______________________________________________<br>
> mesa-dev mailing list<br>
> <a href="mailto:mesa-dev@lists.freedesktop.org">mesa-dev@lists.freedesktop.org</a><br>
> <a href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev">https://lists.freedesktop.org/mailman/listinfo/mesa-dev</a><br></p>