blob: f676573de98e671dd105e357d281f58569e9a10e [file] [log] [blame]
Chia-I Wueb7db122016-03-24 09:11:06 +08001/*
2 * Copyright 2016 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17// WARNING: This file is generated. See ../README.md for instructions.
18
Yiwei Zhang6d78a572019-04-10 15:35:38 -070019#include <log/log.h>
Chia-I Wueb7db122016-03-24 09:11:06 +080020#include <string.h>
Mark Salyzyna5e161b2016-09-29 08:08:05 -070021
Chia-I Wueb7db122016-03-24 09:11:06 +080022#include <algorithm>
Mark Salyzyna5e161b2016-09-29 08:08:05 -070023
Chia-I Wueb7db122016-03-24 09:11:06 +080024#include "driver.h"
Chia-I Wueb7db122016-03-24 09:11:06 +080025
26namespace vulkan {
27namespace driver {
28
29namespace {
30
31// clang-format off
32
Chia-I Wueb7db122016-03-24 09:11:06 +080033VKAPI_ATTR VkResult checkedCreateSwapchainKHR(VkDevice device, const VkSwapchainCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchain) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080034 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
35 return CreateSwapchainKHR(device, pCreateInfo, pAllocator, pSwapchain);
36 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080037 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkCreateSwapchainKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080038 return VK_SUCCESS;
39 }
Chia-I Wueb7db122016-03-24 09:11:06 +080040}
41
42VKAPI_ATTR void checkedDestroySwapchainKHR(VkDevice device, VkSwapchainKHR swapchain, const VkAllocationCallbacks* pAllocator) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080043 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
44 DestroySwapchainKHR(device, swapchain, pAllocator);
45 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080046 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkDestroySwapchainKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080047 }
Chia-I Wueb7db122016-03-24 09:11:06 +080048}
49
50VKAPI_ATTR VkResult checkedGetSwapchainImagesKHR(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pSwapchainImageCount, VkImage* pSwapchainImages) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080051 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
52 return GetSwapchainImagesKHR(device, swapchain, pSwapchainImageCount, pSwapchainImages);
53 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080054 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkGetSwapchainImagesKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080055 return VK_SUCCESS;
56 }
Chia-I Wueb7db122016-03-24 09:11:06 +080057}
58
59VKAPI_ATTR VkResult checkedAcquireNextImageKHR(VkDevice device, VkSwapchainKHR swapchain, uint64_t timeout, VkSemaphore semaphore, VkFence fence, uint32_t* pImageIndex) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080060 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
61 return AcquireNextImageKHR(device, swapchain, timeout, semaphore, fence, pImageIndex);
62 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080063 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkAcquireNextImageKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080064 return VK_SUCCESS;
65 }
Chia-I Wueb7db122016-03-24 09:11:06 +080066}
67
68VKAPI_ATTR VkResult checkedQueuePresentKHR(VkQueue queue, const VkPresentInfoKHR* pPresentInfo) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080069 if (GetData(queue).hook_extensions[ProcHook::KHR_swapchain]) {
70 return QueuePresentKHR(queue, pPresentInfo);
71 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080072 Logger(queue).Err(queue, "VK_KHR_swapchain not enabled. vkQueuePresentKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080073 return VK_SUCCESS;
74 }
Chia-I Wueb7db122016-03-24 09:11:06 +080075}
76
Adithya Srinivasan8dce9d72019-07-11 14:26:04 -070077VKAPI_ATTR VkResult checkedBindImageMemory2KHR(VkDevice device, uint32_t bindInfoCount, const VkBindImageMemoryInfo* pBindInfos) {
78 if (GetData(device).hook_extensions[ProcHook::KHR_bind_memory2]) {
79 return BindImageMemory2KHR(device, bindInfoCount, pBindInfos);
80 } else {
81 Logger(device).Err(device, "VK_KHR_bind_memory2 not enabled. vkBindImageMemory2KHR not executed.");
82 return VK_SUCCESS;
83 }
84}
85
Daniel Kochf25f5bb2017-10-05 00:26:58 -040086VKAPI_ATTR VkResult checkedGetDeviceGroupPresentCapabilitiesKHR(VkDevice device, VkDeviceGroupPresentCapabilitiesKHR* pDeviceGroupPresentCapabilities) {
87 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
88 return GetDeviceGroupPresentCapabilitiesKHR(device, pDeviceGroupPresentCapabilities);
89 } else {
90 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkGetDeviceGroupPresentCapabilitiesKHR not executed.");
91 return VK_SUCCESS;
92 }
93}
94
95VKAPI_ATTR VkResult checkedGetDeviceGroupSurfacePresentModesKHR(VkDevice device, VkSurfaceKHR surface, VkDeviceGroupPresentModeFlagsKHR* pModes) {
96 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
97 return GetDeviceGroupSurfacePresentModesKHR(device, surface, pModes);
98 } else {
99 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkGetDeviceGroupSurfacePresentModesKHR not executed.");
100 return VK_SUCCESS;
101 }
102}
103
104VKAPI_ATTR VkResult checkedAcquireNextImage2KHR(VkDevice device, const VkAcquireNextImageInfoKHR* pAcquireInfo, uint32_t* pImageIndex) {
105 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
106 return AcquireNextImage2KHR(device, pAcquireInfo, pImageIndex);
107 } else {
108 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkAcquireNextImage2KHR not executed.");
109 return VK_SUCCESS;
110 }
111}
112
Jesse Hall889cd9a2017-02-25 22:12:23 -0800113VKAPI_ATTR void checkedSetHdrMetadataEXT(VkDevice device, uint32_t swapchainCount, const VkSwapchainKHR* pSwapchains, const VkHdrMetadataEXT* pMetadata) {
114 if (GetData(device).hook_extensions[ProcHook::EXT_hdr_metadata]) {
115 SetHdrMetadataEXT(device, swapchainCount, pSwapchains, pMetadata);
116 } else {
117 Logger(device).Err(device, "VK_EXT_hdr_metadata not enabled. vkSetHdrMetadataEXT not executed.");
118 }
119}
120
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300121VKAPI_ATTR VkResult checkedGetSwapchainStatusKHR(VkDevice device, VkSwapchainKHR swapchain) {
Chris Forbes1d5f68c2017-01-31 10:17:01 +1300122 if (GetData(device).hook_extensions[ProcHook::KHR_shared_presentable_image]) {
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300123 return GetSwapchainStatusKHR(device, swapchain);
124 } else {
Chris Forbes1d5f68c2017-01-31 10:17:01 +1300125 Logger(device).Err(device, "VK_KHR_shared_presentable_image not enabled. vkGetSwapchainStatusKHR not executed.");
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300126 return VK_SUCCESS;
127 }
128}
129
Adithya Srinivasan8dce9d72019-07-11 14:26:04 -0700130VKAPI_ATTR VkResult checkedGetRefreshCycleDurationGOOGLE(VkDevice device, VkSwapchainKHR swapchain, VkRefreshCycleDurationGOOGLE* pDisplayTimingProperties) {
131 if (GetData(device).hook_extensions[ProcHook::GOOGLE_display_timing]) {
132 return GetRefreshCycleDurationGOOGLE(device, swapchain, pDisplayTimingProperties);
Yiwei Zhang23143102019-04-10 18:24:05 -0700133 } else {
Adithya Srinivasan8dce9d72019-07-11 14:26:04 -0700134 Logger(device).Err(device, "VK_GOOGLE_display_timing not enabled. vkGetRefreshCycleDurationGOOGLE not executed.");
135 return VK_SUCCESS;
136 }
137}
138
139VKAPI_ATTR VkResult checkedGetPastPresentationTimingGOOGLE(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pPresentationTimingCount, VkPastPresentationTimingGOOGLE* pPresentationTimings) {
140 if (GetData(device).hook_extensions[ProcHook::GOOGLE_display_timing]) {
141 return GetPastPresentationTimingGOOGLE(device, swapchain, pPresentationTimingCount, pPresentationTimings);
142 } else {
143 Logger(device).Err(device, "VK_GOOGLE_display_timing not enabled. vkGetPastPresentationTimingGOOGLE not executed.");
Yiwei Zhang23143102019-04-10 18:24:05 -0700144 return VK_SUCCESS;
145 }
146}
147
Chia-I Wueb7db122016-03-24 09:11:06 +0800148// clang-format on
149
150const ProcHook g_proc_hooks[] = {
151 // clang-format off
152 {
153 "vkAcquireImageANDROID",
154 ProcHook::DEVICE,
155 ProcHook::ANDROID_native_buffer,
156 nullptr,
157 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800158 },
159 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400160 "vkAcquireNextImage2KHR",
161 ProcHook::DEVICE,
162 ProcHook::KHR_swapchain,
163 reinterpret_cast<PFN_vkVoidFunction>(AcquireNextImage2KHR),
164 reinterpret_cast<PFN_vkVoidFunction>(checkedAcquireNextImage2KHR),
165 },
166 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800167 "vkAcquireNextImageKHR",
168 ProcHook::DEVICE,
169 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800170 reinterpret_cast<PFN_vkVoidFunction>(AcquireNextImageKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800171 reinterpret_cast<PFN_vkVoidFunction>(checkedAcquireNextImageKHR),
172 },
173 {
174 "vkAllocateCommandBuffers",
175 ProcHook::DEVICE,
176 ProcHook::EXTENSION_CORE,
Chia-I Wu6a58a8a2016-03-24 16:29:51 +0800177 reinterpret_cast<PFN_vkVoidFunction>(AllocateCommandBuffers),
Chia-I Wueb7db122016-03-24 09:11:06 +0800178 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800179 },
180 {
Yiwei Zhang23143102019-04-10 18:24:05 -0700181 "vkBindImageMemory2",
182 ProcHook::DEVICE,
183 ProcHook::EXTENSION_CORE,
184 reinterpret_cast<PFN_vkVoidFunction>(BindImageMemory2),
185 nullptr,
186 },
187 {
188 "vkBindImageMemory2KHR",
189 ProcHook::DEVICE,
190 ProcHook::KHR_bind_memory2,
191 reinterpret_cast<PFN_vkVoidFunction>(BindImageMemory2KHR),
192 reinterpret_cast<PFN_vkVoidFunction>(checkedBindImageMemory2KHR),
193 },
194 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800195 "vkCreateAndroidSurfaceKHR",
196 ProcHook::INSTANCE,
197 ProcHook::KHR_android_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800198 reinterpret_cast<PFN_vkVoidFunction>(CreateAndroidSurfaceKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800199 nullptr,
200 },
201 {
202 "vkCreateDebugReportCallbackEXT",
203 ProcHook::INSTANCE,
204 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800205 reinterpret_cast<PFN_vkVoidFunction>(CreateDebugReportCallbackEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800206 nullptr,
207 },
208 {
209 "vkCreateDevice",
210 ProcHook::INSTANCE,
211 ProcHook::EXTENSION_CORE,
Chia-I Wu4901db72016-03-24 16:38:58 +0800212 reinterpret_cast<PFN_vkVoidFunction>(CreateDevice),
Chia-I Wueb7db122016-03-24 09:11:06 +0800213 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800214 },
215 {
216 "vkCreateInstance",
217 ProcHook::GLOBAL,
218 ProcHook::EXTENSION_CORE,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800219 reinterpret_cast<PFN_vkVoidFunction>(CreateInstance),
Chia-I Wueb7db122016-03-24 09:11:06 +0800220 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800221 },
222 {
223 "vkCreateSwapchainKHR",
224 ProcHook::DEVICE,
225 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800226 reinterpret_cast<PFN_vkVoidFunction>(CreateSwapchainKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800227 reinterpret_cast<PFN_vkVoidFunction>(checkedCreateSwapchainKHR),
228 },
229 {
230 "vkDebugReportMessageEXT",
231 ProcHook::INSTANCE,
232 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800233 reinterpret_cast<PFN_vkVoidFunction>(DebugReportMessageEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800234 nullptr,
235 },
236 {
237 "vkDestroyDebugReportCallbackEXT",
238 ProcHook::INSTANCE,
239 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800240 reinterpret_cast<PFN_vkVoidFunction>(DestroyDebugReportCallbackEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800241 nullptr,
242 },
243 {
244 "vkDestroyDevice",
245 ProcHook::DEVICE,
246 ProcHook::EXTENSION_CORE,
Chia-I Wu4901db72016-03-24 16:38:58 +0800247 reinterpret_cast<PFN_vkVoidFunction>(DestroyDevice),
Chia-I Wueb7db122016-03-24 09:11:06 +0800248 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800249 },
250 {
251 "vkDestroyInstance",
252 ProcHook::INSTANCE,
253 ProcHook::EXTENSION_CORE,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800254 reinterpret_cast<PFN_vkVoidFunction>(DestroyInstance),
Chia-I Wueb7db122016-03-24 09:11:06 +0800255 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800256 },
257 {
258 "vkDestroySurfaceKHR",
259 ProcHook::INSTANCE,
260 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800261 reinterpret_cast<PFN_vkVoidFunction>(DestroySurfaceKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800262 nullptr,
263 },
264 {
265 "vkDestroySwapchainKHR",
266 ProcHook::DEVICE,
267 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800268 reinterpret_cast<PFN_vkVoidFunction>(DestroySwapchainKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800269 reinterpret_cast<PFN_vkVoidFunction>(checkedDestroySwapchainKHR),
270 },
271 {
272 "vkEnumerateDeviceExtensionProperties",
273 ProcHook::INSTANCE,
274 ProcHook::EXTENSION_CORE,
Chia-I Wu01cf3052016-03-24 16:16:21 +0800275 reinterpret_cast<PFN_vkVoidFunction>(EnumerateDeviceExtensionProperties),
Chia-I Wueb7db122016-03-24 09:11:06 +0800276 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800277 },
278 {
279 "vkEnumerateInstanceExtensionProperties",
280 ProcHook::GLOBAL,
281 ProcHook::EXTENSION_CORE,
282 reinterpret_cast<PFN_vkVoidFunction>(EnumerateInstanceExtensionProperties),
283 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800284 },
285 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400286 "vkEnumeratePhysicalDeviceGroups",
287 ProcHook::INSTANCE,
288 ProcHook::EXTENSION_CORE,
289 reinterpret_cast<PFN_vkVoidFunction>(EnumeratePhysicalDeviceGroups),
290 nullptr,
291 },
292 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800293 "vkEnumeratePhysicalDevices",
294 ProcHook::INSTANCE,
295 ProcHook::EXTENSION_CORE,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800296 reinterpret_cast<PFN_vkVoidFunction>(EnumeratePhysicalDevices),
Chia-I Wueb7db122016-03-24 09:11:06 +0800297 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800298 },
299 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400300 "vkGetDeviceGroupPresentCapabilitiesKHR",
301 ProcHook::DEVICE,
302 ProcHook::KHR_swapchain,
303 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceGroupPresentCapabilitiesKHR),
304 reinterpret_cast<PFN_vkVoidFunction>(checkedGetDeviceGroupPresentCapabilitiesKHR),
305 },
306 {
307 "vkGetDeviceGroupSurfacePresentModesKHR",
308 ProcHook::DEVICE,
309 ProcHook::KHR_swapchain,
310 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceGroupSurfacePresentModesKHR),
311 reinterpret_cast<PFN_vkVoidFunction>(checkedGetDeviceGroupSurfacePresentModesKHR),
312 },
313 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800314 "vkGetDeviceProcAddr",
315 ProcHook::DEVICE,
316 ProcHook::EXTENSION_CORE,
317 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceProcAddr),
318 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800319 },
320 {
321 "vkGetDeviceQueue",
322 ProcHook::DEVICE,
323 ProcHook::EXTENSION_CORE,
Chia-I Wuba0be412016-03-24 16:24:40 +0800324 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceQueue),
Chia-I Wueb7db122016-03-24 09:11:06 +0800325 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800326 },
327 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400328 "vkGetDeviceQueue2",
329 ProcHook::DEVICE,
330 ProcHook::EXTENSION_CORE,
331 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceQueue2),
332 nullptr,
333 },
334 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800335 "vkGetInstanceProcAddr",
336 ProcHook::INSTANCE,
337 ProcHook::EXTENSION_CORE,
338 reinterpret_cast<PFN_vkVoidFunction>(GetInstanceProcAddr),
339 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800340 },
341 {
Ian Elliott4c8bb2a2016-12-29 11:07:26 -0700342 "vkGetPastPresentationTimingGOOGLE",
343 ProcHook::DEVICE,
344 ProcHook::GOOGLE_display_timing,
345 reinterpret_cast<PFN_vkVoidFunction>(GetPastPresentationTimingGOOGLE),
346 reinterpret_cast<PFN_vkVoidFunction>(checkedGetPastPresentationTimingGOOGLE),
347 },
348 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400349 "vkGetPhysicalDevicePresentRectanglesKHR",
350 ProcHook::INSTANCE,
351 ProcHook::KHR_swapchain,
352 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDevicePresentRectanglesKHR),
353 nullptr,
354 },
355 {
Chris Forbes2452cf72017-03-16 16:30:17 +1300356 "vkGetPhysicalDeviceSurfaceCapabilities2KHR",
357 ProcHook::INSTANCE,
358 ProcHook::KHR_get_surface_capabilities2,
359 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceCapabilities2KHR),
360 nullptr,
361 },
362 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800363 "vkGetPhysicalDeviceSurfaceCapabilitiesKHR",
364 ProcHook::INSTANCE,
365 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800366 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceCapabilitiesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800367 nullptr,
368 },
369 {
Chris Forbes2452cf72017-03-16 16:30:17 +1300370 "vkGetPhysicalDeviceSurfaceFormats2KHR",
371 ProcHook::INSTANCE,
372 ProcHook::KHR_get_surface_capabilities2,
373 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceFormats2KHR),
374 nullptr,
375 },
376 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800377 "vkGetPhysicalDeviceSurfaceFormatsKHR",
378 ProcHook::INSTANCE,
379 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800380 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceFormatsKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800381 nullptr,
382 },
383 {
384 "vkGetPhysicalDeviceSurfacePresentModesKHR",
385 ProcHook::INSTANCE,
386 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800387 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfacePresentModesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800388 nullptr,
389 },
390 {
391 "vkGetPhysicalDeviceSurfaceSupportKHR",
392 ProcHook::INSTANCE,
393 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800394 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceSupportKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800395 nullptr,
396 },
397 {
Ian Elliott4c8bb2a2016-12-29 11:07:26 -0700398 "vkGetRefreshCycleDurationGOOGLE",
399 ProcHook::DEVICE,
400 ProcHook::GOOGLE_display_timing,
401 reinterpret_cast<PFN_vkVoidFunction>(GetRefreshCycleDurationGOOGLE),
402 reinterpret_cast<PFN_vkVoidFunction>(checkedGetRefreshCycleDurationGOOGLE),
403 },
404 {
Chris Forbes8e4438b2016-12-07 16:26:49 +1300405 "vkGetSwapchainGrallocUsage2ANDROID",
406 ProcHook::DEVICE,
407 ProcHook::ANDROID_native_buffer,
408 nullptr,
409 nullptr,
410 },
411 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800412 "vkGetSwapchainGrallocUsageANDROID",
413 ProcHook::DEVICE,
414 ProcHook::ANDROID_native_buffer,
415 nullptr,
416 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800417 },
418 {
419 "vkGetSwapchainImagesKHR",
420 ProcHook::DEVICE,
421 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800422 reinterpret_cast<PFN_vkVoidFunction>(GetSwapchainImagesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800423 reinterpret_cast<PFN_vkVoidFunction>(checkedGetSwapchainImagesKHR),
424 },
425 {
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300426 "vkGetSwapchainStatusKHR",
427 ProcHook::DEVICE,
Chris Forbes1d5f68c2017-01-31 10:17:01 +1300428 ProcHook::KHR_shared_presentable_image,
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300429 reinterpret_cast<PFN_vkVoidFunction>(GetSwapchainStatusKHR),
430 reinterpret_cast<PFN_vkVoidFunction>(checkedGetSwapchainStatusKHR),
431 },
432 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800433 "vkQueuePresentKHR",
434 ProcHook::DEVICE,
435 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800436 reinterpret_cast<PFN_vkVoidFunction>(QueuePresentKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800437 reinterpret_cast<PFN_vkVoidFunction>(checkedQueuePresentKHR),
438 },
439 {
440 "vkQueueSignalReleaseImageANDROID",
441 ProcHook::DEVICE,
442 ProcHook::ANDROID_native_buffer,
443 nullptr,
444 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800445 },
Courtney Goeltzenleuchterd634c482017-01-05 15:55:31 -0700446 {
Yiwei Zhang899d1752019-09-23 16:05:35 -0700447 "vkQueueSubmit",
448 ProcHook::DEVICE,
449 ProcHook::EXTENSION_CORE,
450 reinterpret_cast<PFN_vkVoidFunction>(QueueSubmit),
451 nullptr,
452 },
453 {
Courtney Goeltzenleuchterd634c482017-01-05 15:55:31 -0700454 "vkSetHdrMetadataEXT",
455 ProcHook::DEVICE,
456 ProcHook::EXT_hdr_metadata,
457 reinterpret_cast<PFN_vkVoidFunction>(SetHdrMetadataEXT),
458 reinterpret_cast<PFN_vkVoidFunction>(checkedSetHdrMetadataEXT),
459 },
Chia-I Wueb7db122016-03-24 09:11:06 +0800460 // clang-format on
461};
462
Chris Forbese2d3ee12017-03-16 16:10:15 +1300463} // namespace
Chia-I Wueb7db122016-03-24 09:11:06 +0800464
465const ProcHook* GetProcHook(const char* name) {
466 const auto& begin = g_proc_hooks;
467 const auto& end =
468 g_proc_hooks + sizeof(g_proc_hooks) / sizeof(g_proc_hooks[0]);
469 const auto hook = std::lower_bound(
470 begin, end, name,
471 [](const ProcHook& e, const char* n) { return strcmp(e.name, n) < 0; });
472 return (hook < end && strcmp(hook->name, name) == 0) ? hook : nullptr;
473}
474
475ProcHook::Extension GetProcHookExtension(const char* name) {
476 // clang-format off
477 if (strcmp(name, "VK_ANDROID_native_buffer") == 0) return ProcHook::ANDROID_native_buffer;
478 if (strcmp(name, "VK_EXT_debug_report") == 0) return ProcHook::EXT_debug_report;
Courtney Goeltzenleuchterd634c482017-01-05 15:55:31 -0700479 if (strcmp(name, "VK_EXT_hdr_metadata") == 0) return ProcHook::EXT_hdr_metadata;
Courtney Goeltzenleuchtere278daf2017-02-02 16:54:57 -0700480 if (strcmp(name, "VK_EXT_swapchain_colorspace") == 0) return ProcHook::EXT_swapchain_colorspace;
Courtney Goeltzenleuchterd634c482017-01-05 15:55:31 -0700481 if (strcmp(name, "VK_GOOGLE_display_timing") == 0) return ProcHook::GOOGLE_display_timing;
Chia-I Wueb7db122016-03-24 09:11:06 +0800482 if (strcmp(name, "VK_KHR_android_surface") == 0) return ProcHook::KHR_android_surface;
Yiwei Zhangdc792f52019-10-10 16:29:42 -0700483 if (strcmp(name, "VK_KHR_get_surface_capabilities2") == 0) return ProcHook::KHR_get_surface_capabilities2;
Chris Forbes48853712017-01-12 14:09:33 +1300484 if (strcmp(name, "VK_KHR_incremental_present") == 0) return ProcHook::KHR_incremental_present;
Courtney Goeltzenleuchtere278daf2017-02-02 16:54:57 -0700485 if (strcmp(name, "VK_KHR_shared_presentable_image") == 0) return ProcHook::KHR_shared_presentable_image;
Chia-I Wueb7db122016-03-24 09:11:06 +0800486 if (strcmp(name, "VK_KHR_surface") == 0) return ProcHook::KHR_surface;
487 if (strcmp(name, "VK_KHR_swapchain") == 0) return ProcHook::KHR_swapchain;
Jesse Halla8d367a2018-01-18 15:40:46 -0800488 if (strcmp(name, "VK_ANDROID_external_memory_android_hardware_buffer") == 0) return ProcHook::ANDROID_external_memory_android_hardware_buffer;
Yiwei Zhang23143102019-04-10 18:24:05 -0700489 if (strcmp(name, "VK_KHR_bind_memory2") == 0) return ProcHook::KHR_bind_memory2;
Yiwei Zhangdc792f52019-10-10 16:29:42 -0700490 if (strcmp(name, "VK_KHR_get_physical_device_properties2") == 0) return ProcHook::KHR_get_physical_device_properties2;
Chia-I Wueb7db122016-03-24 09:11:06 +0800491 // clang-format on
492 return ProcHook::EXTENSION_UNKNOWN;
493}
494
Chia-I Wucc5e2762016-03-24 13:01:16 +0800495#define UNLIKELY(expr) __builtin_expect((expr), 0)
496
Chris Forbes5948b3e2016-12-23 13:49:53 +1300497#define INIT_PROC(required, obj, proc) \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800498 do { \
499 data.driver.proc = \
500 reinterpret_cast<PFN_vk##proc>(get_proc(obj, "vk" #proc)); \
Chris Forbes5948b3e2016-12-23 13:49:53 +1300501 if (UNLIKELY(required && !data.driver.proc)) { \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800502 ALOGE("missing " #obj " proc: vk" #proc); \
503 success = false; \
504 } \
505 } while (0)
506
Chris Forbes5948b3e2016-12-23 13:49:53 +1300507#define INIT_PROC_EXT(ext, required, obj, proc) \
508 do { \
509 if (extensions[ProcHook::ext]) \
510 INIT_PROC(required, obj, proc); \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800511 } while (0)
512
Chia-I Wucbe07ef2016-04-13 15:01:00 +0800513bool InitDriverTable(VkInstance instance,
514 PFN_vkGetInstanceProcAddr get_proc,
515 const std::bitset<ProcHook::EXTENSION_COUNT>& extensions) {
Chia-I Wucc5e2762016-03-24 13:01:16 +0800516 auto& data = GetData(instance);
517 bool success = true;
518
519 // clang-format off
Chris Forbes5948b3e2016-12-23 13:49:53 +1300520 INIT_PROC(true, instance, DestroyInstance);
521 INIT_PROC(true, instance, EnumeratePhysicalDevices);
522 INIT_PROC(true, instance, GetInstanceProcAddr);
Jesse Hall85bb0c52017-02-09 22:13:02 -0800523 INIT_PROC(true, instance, GetPhysicalDeviceProperties);
Chris Forbes5948b3e2016-12-23 13:49:53 +1300524 INIT_PROC(true, instance, CreateDevice);
525 INIT_PROC(true, instance, EnumerateDeviceExtensionProperties);
526 INIT_PROC_EXT(EXT_debug_report, true, instance, CreateDebugReportCallbackEXT);
527 INIT_PROC_EXT(EXT_debug_report, true, instance, DestroyDebugReportCallbackEXT);
528 INIT_PROC_EXT(EXT_debug_report, true, instance, DebugReportMessageEXT);
Adithya Srinivasan8dce9d72019-07-11 14:26:04 -0700529 INIT_PROC(false, instance, GetPhysicalDeviceProperties2);
Chris Forbes6aa30db2017-02-20 17:12:53 +1300530 INIT_PROC_EXT(KHR_get_physical_device_properties2, true, instance, GetPhysicalDeviceProperties2KHR);
Adithya Srinivasan8dce9d72019-07-11 14:26:04 -0700531 INIT_PROC(false, instance, EnumeratePhysicalDeviceGroups);
Chia-I Wucc5e2762016-03-24 13:01:16 +0800532 // clang-format on
533
534 return success;
535}
536
Chia-I Wucbe07ef2016-04-13 15:01:00 +0800537bool InitDriverTable(VkDevice dev,
538 PFN_vkGetDeviceProcAddr get_proc,
539 const std::bitset<ProcHook::EXTENSION_COUNT>& extensions) {
Chia-I Wucc5e2762016-03-24 13:01:16 +0800540 auto& data = GetData(dev);
541 bool success = true;
542
543 // clang-format off
Chris Forbes5948b3e2016-12-23 13:49:53 +1300544 INIT_PROC(true, dev, GetDeviceProcAddr);
545 INIT_PROC(true, dev, DestroyDevice);
546 INIT_PROC(true, dev, GetDeviceQueue);
Yiwei Zhang899d1752019-09-23 16:05:35 -0700547 INIT_PROC(true, dev, QueueSubmit);
Chris Forbes5948b3e2016-12-23 13:49:53 +1300548 INIT_PROC(true, dev, CreateImage);
549 INIT_PROC(true, dev, DestroyImage);
550 INIT_PROC(true, dev, AllocateCommandBuffers);
Yiwei Zhang23143102019-04-10 18:24:05 -0700551 INIT_PROC(false, dev, BindImageMemory2);
Adithya Srinivasan8dce9d72019-07-11 14:26:04 -0700552 INIT_PROC_EXT(KHR_bind_memory2, true, dev, BindImageMemory2KHR);
Ian Elliottcd8ad332017-10-13 09:21:12 -0600553 INIT_PROC(false, dev, GetDeviceQueue2);
Chris Forbesd8277912017-02-10 14:59:59 +1300554 INIT_PROC_EXT(ANDROID_native_buffer, false, dev, GetSwapchainGrallocUsageANDROID);
Yiwei Zhang4bc489b2019-09-23 15:17:22 -0700555 INIT_PROC_EXT(ANDROID_native_buffer, false, dev, GetSwapchainGrallocUsage2ANDROID);
Chris Forbes5948b3e2016-12-23 13:49:53 +1300556 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, AcquireImageANDROID);
557 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, QueueSignalReleaseImageANDROID);
Chia-I Wucc5e2762016-03-24 13:01:16 +0800558 // clang-format on
559
560 return success;
561}
562
Chia-I Wueb7db122016-03-24 09:11:06 +0800563} // namespace driver
564} // namespace vulkan