mesa/src/imagination/vulkan/pvr_wsi.c
Faith Ekstrand 59f85e678f vulkan/wsi: Take a vk_queue in wsi_common_queue_present()
The common entrypoint wrapper already depends on vk_queue, as do all the
drivers that implement drv_QueuePresentKHR() so there's no point in
passing through Vulkan API types anymore.

The one functional change here is that ANV is no longer forcing the
queue index to be zero, which I suspect was a mistake in the first
place.

Reviewed-by: Lars-Ivar Hesselberg Simonsen <lars-ivar.simonsen@arm.com>
Reviewed-by: Adam Jackson <ajax@redhat.com>
Reviewed-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/36827>
2025-08-22 23:05:02 +00:00

85 lines
2.9 KiB
C

/*
* Copyright © 2022 Imagination Technologies Ltd.
*
* based on intel anv code:
* Copyright © 2015 Intel Corporation
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice (including the next
* paragraph) shall be included in all copies or substantial portions of the
* Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#include <stdint.h>
#include <stddef.h>
#include <stdbool.h>
#include <vulkan/vulkan.h>
#include "pvr_private.h"
#include "util/u_atomic.h"
#include "vk_object.h"
#include "wsi_common.h"
static PFN_vkVoidFunction pvr_wsi_proc_addr(VkPhysicalDevice physicalDevice,
const char *pName)
{
PVR_FROM_HANDLE(pvr_physical_device, pdevice, physicalDevice);
return vk_instance_get_proc_addr_unchecked(&pdevice->instance->vk, pName);
}
VkResult pvr_wsi_init(struct pvr_physical_device *pdevice)
{
VkResult result;
result = wsi_device_init(&pdevice->wsi_device,
pvr_physical_device_to_handle(pdevice),
pvr_wsi_proc_addr,
&pdevice->vk.instance->alloc,
pdevice->ws->display_fd,
NULL,
&(struct wsi_device_options){ .sw_device = false });
if (result != VK_SUCCESS)
return result;
pdevice->wsi_device.supports_modifiers = true;
pdevice->vk.wsi_device = &pdevice->wsi_device;
return VK_SUCCESS;
}
void pvr_wsi_finish(struct pvr_physical_device *pdevice)
{
pdevice->vk.wsi_device = NULL;
wsi_device_finish(&pdevice->wsi_device, &pdevice->vk.instance->alloc);
}
VkResult pvr_QueuePresentKHR(VkQueue _queue,
const VkPresentInfoKHR *pPresentInfo)
{
PVR_FROM_HANDLE(pvr_queue, queue, _queue);
VkResult result;
result = wsi_common_queue_present(&queue->device->pdevice->wsi_device,
&queue->vk, pPresentInfo);
if (result != VK_SUCCESS)
return result;
p_atomic_inc(&queue->device->global_queue_present_count);
return VK_SUCCESS;
}