lvp: free up hwvulkan_device_t upon driver unloading

Per <hardware/hwvulkan.h>, the hw_device_t::close() function is called
upon driver unloading. The behavior has been like this since Android 10.

Acked-by: Rob Clark <robdclark@chromium.org>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/35561>
This commit is contained in:
Yiwei Zhang
2025-06-16 01:10:12 -07:00
committed by Marge Bot
parent 02c65181c1
commit a2ca6843c7
+7 -2
View File
@@ -101,8 +101,13 @@ lvp_hal_open(const struct hw_module_t *mod,
static int
lvp_hal_close(struct hw_device_t *dev)
{
/* hwvulkan.h claims that hw_device_t::close() is never called. */
return -1;
/* the hw_device_t::close() function is called upon driver unloading */
assert(dev->version == HWVULKAN_DEVICE_API_VERSION_0_1);
assert(dev->module == &HAL_MODULE_INFO_SYM.common);
hwvulkan_device_t *hal_dev = container_of(dev, hwvulkan_device_t, common);
free(hal_dev);
return 0;
}
VKAPI_ATTR VkResult VKAPI_CALL