1 /*
2 * Copyright © 2017 Keith Packard
3 *
4 * Permission to use, copy, modify, distribute, and sell this software and its
5 * documentation for any purpose is hereby granted without fee, provided that
6 * the above copyright notice appear in all copies and that both that copyright
7 * notice and this permission notice appear in supporting documentation, and
8 * that the name of the copyright holders not be used in advertising or
9 * publicity pertaining to distribution of the software without specific,
10 * written prior permission. The copyright holders make no representations
11 * about the suitability of this software for any purpose. It is provided "as
12 * is" without express or implied warranty.
13 *
14 * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
15 * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
16 * EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY SPECIAL, INDIRECT OR
17 * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
18 * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
19 * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
20 * OF THIS SOFTWARE.
21 */
22
23 #include "anv_private.h"
24 #include "wsi_common.h"
25 #include "vk_format_info.h"
26 #include "vk_util.h"
27 #include "wsi_common_display.h"
28
29 VkResult
anv_GetPhysicalDeviceDisplayPropertiesKHR(VkPhysicalDevice physical_device,uint32_t * property_count,VkDisplayPropertiesKHR * properties)30 anv_GetPhysicalDeviceDisplayPropertiesKHR(VkPhysicalDevice physical_device,
31 uint32_t *property_count,
32 VkDisplayPropertiesKHR *properties)
33 {
34 ANV_FROM_HANDLE(anv_physical_device, pdevice, physical_device);
35
36 return wsi_display_get_physical_device_display_properties(
37 physical_device,
38 &pdevice->wsi_device,
39 property_count,
40 properties);
41 }
42
43 VkResult
anv_GetPhysicalDeviceDisplayProperties2KHR(VkPhysicalDevice physicalDevice,uint32_t * pPropertyCount,VkDisplayProperties2KHR * pProperties)44 anv_GetPhysicalDeviceDisplayProperties2KHR(
45 VkPhysicalDevice physicalDevice,
46 uint32_t* pPropertyCount,
47 VkDisplayProperties2KHR* pProperties)
48 {
49 ANV_FROM_HANDLE(anv_physical_device, pdevice, physicalDevice);
50
51 return wsi_display_get_physical_device_display_properties2(
52 physicalDevice, &pdevice->wsi_device,
53 pPropertyCount, pProperties);
54 }
55
56 VkResult
anv_GetPhysicalDeviceDisplayPlanePropertiesKHR(VkPhysicalDevice physical_device,uint32_t * property_count,VkDisplayPlanePropertiesKHR * properties)57 anv_GetPhysicalDeviceDisplayPlanePropertiesKHR(
58 VkPhysicalDevice physical_device,
59 uint32_t *property_count,
60 VkDisplayPlanePropertiesKHR *properties)
61 {
62 ANV_FROM_HANDLE(anv_physical_device, pdevice, physical_device);
63
64 return wsi_display_get_physical_device_display_plane_properties(
65 physical_device, &pdevice->wsi_device,
66 property_count, properties);
67 }
68
69 VkResult
anv_GetPhysicalDeviceDisplayPlaneProperties2KHR(VkPhysicalDevice physicalDevice,uint32_t * pPropertyCount,VkDisplayPlaneProperties2KHR * pProperties)70 anv_GetPhysicalDeviceDisplayPlaneProperties2KHR(
71 VkPhysicalDevice physicalDevice,
72 uint32_t* pPropertyCount,
73 VkDisplayPlaneProperties2KHR* pProperties)
74 {
75 ANV_FROM_HANDLE(anv_physical_device, pdevice, physicalDevice);
76
77 return wsi_display_get_physical_device_display_plane_properties2(
78 physicalDevice, &pdevice->wsi_device,
79 pPropertyCount, pProperties);
80 }
81
82 VkResult
anv_GetDisplayPlaneSupportedDisplaysKHR(VkPhysicalDevice physical_device,uint32_t plane_index,uint32_t * display_count,VkDisplayKHR * displays)83 anv_GetDisplayPlaneSupportedDisplaysKHR(VkPhysicalDevice physical_device,
84 uint32_t plane_index,
85 uint32_t *display_count,
86 VkDisplayKHR *displays)
87 {
88 ANV_FROM_HANDLE(anv_physical_device, pdevice, physical_device);
89
90 return wsi_display_get_display_plane_supported_displays(physical_device,
91 &pdevice->wsi_device,
92 plane_index,
93 display_count,
94 displays);
95 }
96
97
98 VkResult
anv_GetDisplayModePropertiesKHR(VkPhysicalDevice physical_device,VkDisplayKHR display,uint32_t * property_count,VkDisplayModePropertiesKHR * properties)99 anv_GetDisplayModePropertiesKHR(VkPhysicalDevice physical_device,
100 VkDisplayKHR display,
101 uint32_t *property_count,
102 VkDisplayModePropertiesKHR *properties)
103 {
104 ANV_FROM_HANDLE(anv_physical_device, pdevice, physical_device);
105
106 return wsi_display_get_display_mode_properties(physical_device,
107 &pdevice->wsi_device,
108 display,
109 property_count,
110 properties);
111 }
112
113 VkResult
anv_GetDisplayModeProperties2KHR(VkPhysicalDevice physicalDevice,VkDisplayKHR display,uint32_t * pPropertyCount,VkDisplayModeProperties2KHR * pProperties)114 anv_GetDisplayModeProperties2KHR(
115 VkPhysicalDevice physicalDevice,
116 VkDisplayKHR display,
117 uint32_t* pPropertyCount,
118 VkDisplayModeProperties2KHR* pProperties)
119 {
120 ANV_FROM_HANDLE(anv_physical_device, pdevice, physicalDevice);
121
122 return wsi_display_get_display_mode_properties2(physicalDevice,
123 &pdevice->wsi_device,
124 display,
125 pPropertyCount,
126 pProperties);
127 }
128
129 VkResult
anv_CreateDisplayModeKHR(VkPhysicalDevice physical_device,VkDisplayKHR display,const VkDisplayModeCreateInfoKHR * create_info,const VkAllocationCallbacks * allocator,VkDisplayModeKHR * mode)130 anv_CreateDisplayModeKHR(VkPhysicalDevice physical_device,
131 VkDisplayKHR display,
132 const VkDisplayModeCreateInfoKHR *create_info,
133 const VkAllocationCallbacks *allocator,
134 VkDisplayModeKHR *mode)
135 {
136 ANV_FROM_HANDLE(anv_physical_device, pdevice, physical_device);
137
138 return wsi_display_create_display_mode(physical_device,
139 &pdevice->wsi_device,
140 display,
141 create_info,
142 allocator,
143 mode);
144 }
145
146 VkResult
anv_GetDisplayPlaneCapabilitiesKHR(VkPhysicalDevice physical_device,VkDisplayModeKHR mode_khr,uint32_t plane_index,VkDisplayPlaneCapabilitiesKHR * capabilities)147 anv_GetDisplayPlaneCapabilitiesKHR(VkPhysicalDevice physical_device,
148 VkDisplayModeKHR mode_khr,
149 uint32_t plane_index,
150 VkDisplayPlaneCapabilitiesKHR *capabilities)
151 {
152 ANV_FROM_HANDLE(anv_physical_device, pdevice, physical_device);
153
154 return wsi_get_display_plane_capabilities(physical_device,
155 &pdevice->wsi_device,
156 mode_khr,
157 plane_index,
158 capabilities);
159 }
160
161 VkResult
anv_GetDisplayPlaneCapabilities2KHR(VkPhysicalDevice physicalDevice,const VkDisplayPlaneInfo2KHR * pDisplayPlaneInfo,VkDisplayPlaneCapabilities2KHR * pCapabilities)162 anv_GetDisplayPlaneCapabilities2KHR(
163 VkPhysicalDevice physicalDevice,
164 const VkDisplayPlaneInfo2KHR* pDisplayPlaneInfo,
165 VkDisplayPlaneCapabilities2KHR* pCapabilities)
166 {
167 ANV_FROM_HANDLE(anv_physical_device, pdevice, physicalDevice);
168
169 return wsi_get_display_plane_capabilities2(physicalDevice,
170 &pdevice->wsi_device,
171 pDisplayPlaneInfo,
172 pCapabilities);
173 }
174
175 VkResult
anv_CreateDisplayPlaneSurfaceKHR(VkInstance _instance,const VkDisplaySurfaceCreateInfoKHR * create_info,const VkAllocationCallbacks * allocator,VkSurfaceKHR * surface)176 anv_CreateDisplayPlaneSurfaceKHR(
177 VkInstance _instance,
178 const VkDisplaySurfaceCreateInfoKHR *create_info,
179 const VkAllocationCallbacks *allocator,
180 VkSurfaceKHR *surface)
181 {
182 ANV_FROM_HANDLE(anv_instance, instance, _instance);
183 const VkAllocationCallbacks *alloc;
184
185 if (allocator)
186 alloc = allocator;
187 else
188 alloc = &instance->alloc;
189
190 return wsi_create_display_surface(_instance, alloc, create_info, surface);
191 }
192
193 VkResult
anv_ReleaseDisplayEXT(VkPhysicalDevice physical_device,VkDisplayKHR display)194 anv_ReleaseDisplayEXT(VkPhysicalDevice physical_device,
195 VkDisplayKHR display)
196 {
197 ANV_FROM_HANDLE(anv_physical_device, pdevice, physical_device);
198
199 return wsi_release_display(physical_device,
200 &pdevice->wsi_device,
201 display);
202 }
203
204 #ifdef VK_USE_PLATFORM_XLIB_XRANDR_EXT
205 VkResult
anv_AcquireXlibDisplayEXT(VkPhysicalDevice physical_device,Display * dpy,VkDisplayKHR display)206 anv_AcquireXlibDisplayEXT(VkPhysicalDevice physical_device,
207 Display *dpy,
208 VkDisplayKHR display)
209 {
210 ANV_FROM_HANDLE(anv_physical_device, pdevice, physical_device);
211
212 return wsi_acquire_xlib_display(physical_device,
213 &pdevice->wsi_device,
214 dpy,
215 display);
216 }
217
218 VkResult
anv_GetRandROutputDisplayEXT(VkPhysicalDevice physical_device,Display * dpy,RROutput output,VkDisplayKHR * display)219 anv_GetRandROutputDisplayEXT(VkPhysicalDevice physical_device,
220 Display *dpy,
221 RROutput output,
222 VkDisplayKHR *display)
223 {
224 ANV_FROM_HANDLE(anv_physical_device, pdevice, physical_device);
225
226 return wsi_get_randr_output_display(physical_device,
227 &pdevice->wsi_device,
228 dpy,
229 output,
230 display);
231 }
232 #endif /* VK_USE_PLATFORM_XLIB_XRANDR_EXT */
233
234 /* VK_EXT_display_control */
235
236 VkResult
anv_DisplayPowerControlEXT(VkDevice _device,VkDisplayKHR display,const VkDisplayPowerInfoEXT * display_power_info)237 anv_DisplayPowerControlEXT(VkDevice _device,
238 VkDisplayKHR display,
239 const VkDisplayPowerInfoEXT *display_power_info)
240 {
241 ANV_FROM_HANDLE(anv_device, device, _device);
242
243 return wsi_display_power_control(
244 _device, &device->physical->wsi_device,
245 display, display_power_info);
246 }
247
248 VkResult
anv_RegisterDeviceEventEXT(VkDevice _device,const VkDeviceEventInfoEXT * device_event_info,const VkAllocationCallbacks * allocator,VkFence * _fence)249 anv_RegisterDeviceEventEXT(VkDevice _device,
250 const VkDeviceEventInfoEXT *device_event_info,
251 const VkAllocationCallbacks *allocator,
252 VkFence *_fence)
253 {
254 ANV_FROM_HANDLE(anv_device, device, _device);
255 struct anv_fence *fence;
256 VkResult ret;
257
258 fence = vk_zalloc2(&device->vk.alloc, allocator, sizeof (*fence), 8,
259 VK_SYSTEM_ALLOCATION_SCOPE_OBJECT);
260 if (!fence)
261 return vk_error(VK_ERROR_OUT_OF_HOST_MEMORY);
262
263 fence->permanent.type = ANV_FENCE_TYPE_WSI;
264
265 ret = wsi_register_device_event(_device,
266 &device->physical->wsi_device,
267 device_event_info,
268 allocator,
269 &fence->permanent.fence_wsi,
270 -1);
271 if (ret == VK_SUCCESS)
272 *_fence = anv_fence_to_handle(fence);
273 else
274 vk_free2(&device->vk.alloc, allocator, fence);
275 return ret;
276 }
277
278 VkResult
anv_RegisterDisplayEventEXT(VkDevice _device,VkDisplayKHR display,const VkDisplayEventInfoEXT * display_event_info,const VkAllocationCallbacks * allocator,VkFence * _fence)279 anv_RegisterDisplayEventEXT(VkDevice _device,
280 VkDisplayKHR display,
281 const VkDisplayEventInfoEXT *display_event_info,
282 const VkAllocationCallbacks *allocator,
283 VkFence *_fence)
284 {
285 ANV_FROM_HANDLE(anv_device, device, _device);
286 struct anv_fence *fence;
287 VkResult ret;
288
289 fence = vk_zalloc2(&device->vk.alloc, allocator, sizeof (*fence), 8,
290 VK_SYSTEM_ALLOCATION_SCOPE_OBJECT);
291 if (!fence)
292 return VK_ERROR_OUT_OF_HOST_MEMORY;
293
294 fence->permanent.type = ANV_FENCE_TYPE_WSI;
295
296 ret = wsi_register_display_event(
297 _device, &device->physical->wsi_device,
298 display, display_event_info, allocator, &fence->permanent.fence_wsi, -1);
299
300 if (ret == VK_SUCCESS)
301 *_fence = anv_fence_to_handle(fence);
302 else
303 vk_free2(&device->vk.alloc, allocator, fence);
304 return ret;
305 }
306
307 VkResult
anv_GetSwapchainCounterEXT(VkDevice _device,VkSwapchainKHR swapchain,VkSurfaceCounterFlagBitsEXT flag_bits,uint64_t * value)308 anv_GetSwapchainCounterEXT(VkDevice _device,
309 VkSwapchainKHR swapchain,
310 VkSurfaceCounterFlagBitsEXT flag_bits,
311 uint64_t *value)
312 {
313 ANV_FROM_HANDLE(anv_device, device, _device);
314
315 return wsi_get_swapchain_counter(
316 _device, &device->physical->wsi_device,
317 swapchain, flag_bits, value);
318 }
319