1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker * Copyright © 2020 Raspberry Pi Ltd
3*61046927SAndroid Build Coastguard Worker * based on intel anv code:
4*61046927SAndroid Build Coastguard Worker * Copyright © 2015 Intel Corporation
5*61046927SAndroid Build Coastguard Worker
6*61046927SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a
7*61046927SAndroid Build Coastguard Worker * copy of this software and associated documentation files (the "Software"),
8*61046927SAndroid Build Coastguard Worker * to deal in the Software without restriction, including without limitation
9*61046927SAndroid Build Coastguard Worker * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10*61046927SAndroid Build Coastguard Worker * and/or sell copies of the Software, and to permit persons to whom the
11*61046927SAndroid Build Coastguard Worker * Software is furnished to do so, subject to the following conditions:
12*61046927SAndroid Build Coastguard Worker *
13*61046927SAndroid Build Coastguard Worker * The above copyright notice and this permission notice (including the next
14*61046927SAndroid Build Coastguard Worker * paragraph) shall be included in all copies or substantial portions of the
15*61046927SAndroid Build Coastguard Worker * Software.
16*61046927SAndroid Build Coastguard Worker *
17*61046927SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18*61046927SAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19*61046927SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20*61046927SAndroid Build Coastguard Worker * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21*61046927SAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
22*61046927SAndroid Build Coastguard Worker * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
23*61046927SAndroid Build Coastguard Worker * IN THE SOFTWARE.
24*61046927SAndroid Build Coastguard Worker */
25*61046927SAndroid Build Coastguard Worker
26*61046927SAndroid Build Coastguard Worker #include "v3dv_private.h"
27*61046927SAndroid Build Coastguard Worker #include "vk_util.h"
28*61046927SAndroid Build Coastguard Worker #include "wsi_common.h"
29*61046927SAndroid Build Coastguard Worker #include "wsi_common_drm.h"
30*61046927SAndroid Build Coastguard Worker #include "wsi_common_entrypoints.h"
31*61046927SAndroid Build Coastguard Worker
32*61046927SAndroid Build Coastguard Worker static VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL
v3dv_wsi_proc_addr(VkPhysicalDevice physicalDevice,const char * pName)33*61046927SAndroid Build Coastguard Worker v3dv_wsi_proc_addr(VkPhysicalDevice physicalDevice, const char *pName)
34*61046927SAndroid Build Coastguard Worker {
35*61046927SAndroid Build Coastguard Worker V3DV_FROM_HANDLE(v3dv_physical_device, pdevice, physicalDevice);
36*61046927SAndroid Build Coastguard Worker return vk_instance_get_proc_addr_unchecked(pdevice->vk.instance, pName);
37*61046927SAndroid Build Coastguard Worker }
38*61046927SAndroid Build Coastguard Worker
39*61046927SAndroid Build Coastguard Worker static bool
v3dv_wsi_can_present_on_device(VkPhysicalDevice _pdevice,int fd)40*61046927SAndroid Build Coastguard Worker v3dv_wsi_can_present_on_device(VkPhysicalDevice _pdevice, int fd)
41*61046927SAndroid Build Coastguard Worker {
42*61046927SAndroid Build Coastguard Worker V3DV_FROM_HANDLE(v3dv_physical_device, pdevice, _pdevice);
43*61046927SAndroid Build Coastguard Worker assert(pdevice->display_fd != -1);
44*61046927SAndroid Build Coastguard Worker return wsi_common_drm_devices_equal(fd, pdevice->display_fd);
45*61046927SAndroid Build Coastguard Worker }
46*61046927SAndroid Build Coastguard Worker
47*61046927SAndroid Build Coastguard Worker
48*61046927SAndroid Build Coastguard Worker static void
filter_surface_capabilities(VkSurfaceKHR _surface,VkSurfaceCapabilitiesKHR * caps)49*61046927SAndroid Build Coastguard Worker filter_surface_capabilities(VkSurfaceKHR _surface,
50*61046927SAndroid Build Coastguard Worker VkSurfaceCapabilitiesKHR *caps)
51*61046927SAndroid Build Coastguard Worker {
52*61046927SAndroid Build Coastguard Worker ICD_FROM_HANDLE(VkIcdSurfaceBase, surface, _surface);
53*61046927SAndroid Build Coastguard Worker
54*61046927SAndroid Build Coastguard Worker /* Display images must be linear so they are restricted. This would
55*61046927SAndroid Build Coastguard Worker * affect sampling usages too, but we don't restrict those since we
56*61046927SAndroid Build Coastguard Worker * support on-the-fly conversion to UIF when sampling for simple 2D
57*61046927SAndroid Build Coastguard Worker * images at a performance penalty.
58*61046927SAndroid Build Coastguard Worker */
59*61046927SAndroid Build Coastguard Worker if (surface->platform == VK_ICD_WSI_PLATFORM_DISPLAY)
60*61046927SAndroid Build Coastguard Worker caps->supportedUsageFlags &= ~VK_IMAGE_USAGE_STORAGE_BIT;
61*61046927SAndroid Build Coastguard Worker }
62*61046927SAndroid Build Coastguard Worker
63*61046927SAndroid Build Coastguard Worker VKAPI_ATTR VkResult VKAPI_CALL
v3dv_GetPhysicalDeviceSurfaceCapabilitiesKHR(VkPhysicalDevice physicalDevice,VkSurfaceKHR surface,VkSurfaceCapabilitiesKHR * pSurfaceCapabilities)64*61046927SAndroid Build Coastguard Worker v3dv_GetPhysicalDeviceSurfaceCapabilitiesKHR(
65*61046927SAndroid Build Coastguard Worker VkPhysicalDevice physicalDevice,
66*61046927SAndroid Build Coastguard Worker VkSurfaceKHR surface,
67*61046927SAndroid Build Coastguard Worker VkSurfaceCapabilitiesKHR* pSurfaceCapabilities)
68*61046927SAndroid Build Coastguard Worker {
69*61046927SAndroid Build Coastguard Worker VkResult result;
70*61046927SAndroid Build Coastguard Worker result = wsi_GetPhysicalDeviceSurfaceCapabilitiesKHR(physicalDevice,
71*61046927SAndroid Build Coastguard Worker surface,
72*61046927SAndroid Build Coastguard Worker pSurfaceCapabilities);
73*61046927SAndroid Build Coastguard Worker filter_surface_capabilities(surface, pSurfaceCapabilities);
74*61046927SAndroid Build Coastguard Worker return result;
75*61046927SAndroid Build Coastguard Worker }
76*61046927SAndroid Build Coastguard Worker
77*61046927SAndroid Build Coastguard Worker VKAPI_ATTR VkResult VKAPI_CALL
v3dv_GetPhysicalDeviceSurfaceCapabilities2KHR(VkPhysicalDevice physicalDevice,const VkPhysicalDeviceSurfaceInfo2KHR * pSurfaceInfo,VkSurfaceCapabilities2KHR * pSurfaceCapabilities)78*61046927SAndroid Build Coastguard Worker v3dv_GetPhysicalDeviceSurfaceCapabilities2KHR(
79*61046927SAndroid Build Coastguard Worker VkPhysicalDevice physicalDevice,
80*61046927SAndroid Build Coastguard Worker const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo,
81*61046927SAndroid Build Coastguard Worker VkSurfaceCapabilities2KHR* pSurfaceCapabilities)
82*61046927SAndroid Build Coastguard Worker {
83*61046927SAndroid Build Coastguard Worker VkResult result;
84*61046927SAndroid Build Coastguard Worker result = wsi_GetPhysicalDeviceSurfaceCapabilities2KHR(physicalDevice,
85*61046927SAndroid Build Coastguard Worker pSurfaceInfo,
86*61046927SAndroid Build Coastguard Worker pSurfaceCapabilities);
87*61046927SAndroid Build Coastguard Worker filter_surface_capabilities(pSurfaceInfo->surface,
88*61046927SAndroid Build Coastguard Worker &pSurfaceCapabilities->surfaceCapabilities);
89*61046927SAndroid Build Coastguard Worker return result;
90*61046927SAndroid Build Coastguard Worker }
91*61046927SAndroid Build Coastguard Worker
92*61046927SAndroid Build Coastguard Worker VkResult
v3dv_wsi_init(struct v3dv_physical_device * physical_device)93*61046927SAndroid Build Coastguard Worker v3dv_wsi_init(struct v3dv_physical_device *physical_device)
94*61046927SAndroid Build Coastguard Worker {
95*61046927SAndroid Build Coastguard Worker VkResult result;
96*61046927SAndroid Build Coastguard Worker
97*61046927SAndroid Build Coastguard Worker result = wsi_device_init(&physical_device->wsi_device,
98*61046927SAndroid Build Coastguard Worker v3dv_physical_device_to_handle(physical_device),
99*61046927SAndroid Build Coastguard Worker v3dv_wsi_proc_addr,
100*61046927SAndroid Build Coastguard Worker &physical_device->vk.instance->alloc,
101*61046927SAndroid Build Coastguard Worker physical_device->display_fd, NULL,
102*61046927SAndroid Build Coastguard Worker &(struct wsi_device_options){.sw_device = false});
103*61046927SAndroid Build Coastguard Worker
104*61046927SAndroid Build Coastguard Worker if (result != VK_SUCCESS)
105*61046927SAndroid Build Coastguard Worker return result;
106*61046927SAndroid Build Coastguard Worker
107*61046927SAndroid Build Coastguard Worker physical_device->wsi_device.supports_modifiers = true;
108*61046927SAndroid Build Coastguard Worker physical_device->wsi_device.can_present_on_device =
109*61046927SAndroid Build Coastguard Worker v3dv_wsi_can_present_on_device;
110*61046927SAndroid Build Coastguard Worker
111*61046927SAndroid Build Coastguard Worker physical_device->vk.wsi_device = &physical_device->wsi_device;
112*61046927SAndroid Build Coastguard Worker
113*61046927SAndroid Build Coastguard Worker return VK_SUCCESS;
114*61046927SAndroid Build Coastguard Worker }
115*61046927SAndroid Build Coastguard Worker
116*61046927SAndroid Build Coastguard Worker void
v3dv_wsi_finish(struct v3dv_physical_device * physical_device)117*61046927SAndroid Build Coastguard Worker v3dv_wsi_finish(struct v3dv_physical_device *physical_device)
118*61046927SAndroid Build Coastguard Worker {
119*61046927SAndroid Build Coastguard Worker physical_device->vk.wsi_device = NULL;
120*61046927SAndroid Build Coastguard Worker wsi_device_finish(&physical_device->wsi_device,
121*61046927SAndroid Build Coastguard Worker &physical_device->vk.instance->alloc);
122*61046927SAndroid Build Coastguard Worker }
123*61046927SAndroid Build Coastguard Worker
124*61046927SAndroid Build Coastguard Worker struct v3dv_image *
v3dv_wsi_get_image_from_swapchain(VkSwapchainKHR swapchain,uint32_t index)125*61046927SAndroid Build Coastguard Worker v3dv_wsi_get_image_from_swapchain(VkSwapchainKHR swapchain, uint32_t index)
126*61046927SAndroid Build Coastguard Worker {
127*61046927SAndroid Build Coastguard Worker VkImage image = wsi_common_get_image(swapchain, index);
128*61046927SAndroid Build Coastguard Worker return v3dv_image_from_handle(image);
129*61046927SAndroid Build Coastguard Worker }
130