diff --git a/system/vulkan/func_table.cpp b/system/vulkan/func_table.cpp index 44e385ded8f52fbe902dfce9aa4fc4dc8a4b94a9..f5b380e23c6df69a7ddf52a9c4b1ffa71f9299cf 100644 --- a/system/vulkan/func_table.cpp +++ b/system/vulkan/func_table.cpp @@ -666,7 +666,8 @@ static VkResult entry_vkCreateImageView( AEMU_SCOPED_TRACE("vkCreateImageView"); auto vkEnc = HostConnection::get()->vkEncoder(); VkResult vkCreateImageView_VkResult_return = (VkResult)0; - vkCreateImageView_VkResult_return = vkEnc->vkCreateImageView(device, pCreateInfo, pAllocator, pView); + auto resources = ResourceTracker::get(); + vkCreateImageView_VkResult_return = resources->on_vkCreateImageView(vkEnc, VK_SUCCESS, device, pCreateInfo, pAllocator, pView); return vkCreateImageView_VkResult_return; } static void entry_vkDestroyImageView( diff --git a/system/vulkan_enc/ResourceTracker.cpp b/system/vulkan_enc/ResourceTracker.cpp index 623859a50cc11d2bfc5c3a5b1911655bbc7920f7..4e86c20adb518da9c8ab150e029f2070d6239a1b 100644 --- a/system/vulkan_enc/ResourceTracker.cpp +++ b/system/vulkan_enc/ResourceTracker.cpp @@ -3122,6 +3122,32 @@ public: return VK_SUCCESS; } + VkResult on_vkCreateImageView( + void* context, VkResult input_result, + VkDevice device, + const VkImageViewCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkImageView* pView) { + + VkEncoder* enc = (VkEncoder*)context; + (void)input_result; + + VkImageViewCreateInfo localCreateInfo = vk_make_orphan_copy(*pCreateInfo); + +#ifdef VK_USE_PLATFORM_ANDROID_KHR + const VkExternalFormatANDROID* extFormatAndroidPtr = + vk_find_struct<VkExternalFormatANDROID>(pCreateInfo); + if (extFormatAndroidPtr) { + if (extFormatAndroidPtr->externalFormat) { + localCreateInfo.format = + vk_format_from_android(extFormatAndroidPtr->externalFormat); + } + } +#endif + + return enc->vkCreateImageView(device, &localCreateInfo, pAllocator, pView); + } + uint32_t getApiVersionFromInstance(VkInstance instance) const { AutoLock lock(mLock); uint32_t api = kMinApiVersion; @@ -3763,6 +3789,16 @@ VkResult ResourceTracker::on_vkResetCommandBuffer( context, input_result, commandBuffer, flags); } +VkResult ResourceTracker::on_vkCreateImageView( + void* context, VkResult input_result, + VkDevice device, + const VkImageViewCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkImageView* pView) { + return mImpl->on_vkCreateImageView( + context, input_result, device, pCreateInfo, pAllocator, pView); +} + void ResourceTracker::deviceMemoryTransform_tohost( VkDeviceMemory* memory, uint32_t memoryCount, VkDeviceSize* offset, uint32_t offsetCount, diff --git a/system/vulkan_enc/ResourceTracker.h b/system/vulkan_enc/ResourceTracker.h index 1f073c8f24897fc8e93b4ee7c74b84ff1e351461..6429d6f4be713e016c22df07eb3b16d339ab0836 100644 --- a/system/vulkan_enc/ResourceTracker.h +++ b/system/vulkan_enc/ResourceTracker.h @@ -334,6 +334,13 @@ public: VkCommandBuffer commandBuffer, VkCommandBufferResetFlags flags); + VkResult on_vkCreateImageView( + void* context, VkResult input_result, + VkDevice device, + const VkImageViewCreateInfo* pCreateInfo, + const VkAllocationCallbacks* pAllocator, + VkImageView* pView); + bool isMemoryTypeHostVisible(VkDevice device, uint32_t typeIndex) const; uint8_t* getMappedPointer(VkDeviceMemory memory); VkDeviceSize getMappedSize(VkDeviceMemory memory); diff --git a/system/vulkan_enc/vk_struct_id.h b/system/vulkan_enc/vk_struct_id.h index c2c9ad90a988c621576861de7c743a1280e64bf6..893389c7e064ed616081237a970b5d8d61124c33 100644 --- a/system/vulkan_enc/vk_struct_id.h +++ b/system/vulkan_enc/vk_struct_id.h @@ -42,6 +42,7 @@ REGISTER_VK_STRUCT_ID(VkSemaphoreCreateInfo, VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_ REGISTER_VK_STRUCT_ID(VkExportSemaphoreCreateInfoKHR, VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO_KHR); REGISTER_VK_STRUCT_ID(VkSamplerYcbcrConversionCreateInfo, VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO); REGISTER_VK_STRUCT_ID(VkImportColorBufferGOOGLE, VK_STRUCTURE_TYPE_IMPORT_COLOR_BUFFER_GOOGLE); +REGISTER_VK_STRUCT_ID(VkImageViewCreateInfo, VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO); #ifdef VK_USE_PLATFORM_ANDROID_KHR // These two should be under Android