From: Lionel Landwerlin Date: Wed, 11 Oct 2017 16:21:53 +0000 (+0100) Subject: anv: bo_cache: allow importing a BO larger than needed X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=c0a4f56fb9945e36a004bc38852fbb801aae3bd5;p=mesa.git anv: bo_cache: allow importing a BO larger than needed It's not a problem if a BO has been allocated larger than we need it to be. Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=102940 Fixes: 818b857914 ("anv: Use the BO cache for DeviceMemory allocations") Signed-off-by: Lionel Landwerlin Reviewed-by: Daniel Stone Cc: mesa-stable@lists.freedesktop.org --- diff --git a/src/intel/vulkan/anv_allocator.c b/src/intel/vulkan/anv_allocator.c index be750adeb52..0f123563f79 100644 --- a/src/intel/vulkan/anv_allocator.c +++ b/src/intel/vulkan/anv_allocator.c @@ -1302,7 +1302,7 @@ anv_bo_cache_import(struct anv_device *device, * this sort of attack but only if it can trust the buffer size. */ off_t import_size = lseek(fd, 0, SEEK_END); - if (import_size == (off_t)-1 || import_size != size) { + if (import_size == (off_t)-1 || import_size < size) { anv_gem_close(device, gem_handle); pthread_mutex_unlock(&cache->mutex); return vk_error(VK_ERROR_INVALID_EXTERNAL_HANDLE_KHR);