blob: aa31735eefe6b56dc836a81aad1ffa493ebd1368 [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
19#include <string.h>
Mark Salyzyna5e161b2016-09-29 08:08:05 -070020
Chia-I Wueb7db122016-03-24 09:11:06 +080021#include <algorithm>
Mark Salyzyna5e161b2016-09-29 08:08:05 -070022
Mark Salyzyn7823e122016-09-29 08:08:05 -070023#include <log/log.h>
Chia-I Wueb7db122016-03-24 09:11:06 +080024
25#include "driver.h"
Chia-I Wueb7db122016-03-24 09:11:06 +080026
27namespace vulkan {
28namespace driver {
29
30namespace {
31
32// clang-format off
33
Yiwei Zhangec6c5052019-10-17 15:53:00 -070034VKAPI_ATTR VkResult checkedBindImageMemory2(VkDevice device, uint32_t bindInfoCount, const VkBindImageMemoryInfo* pBindInfos) {
35 if (GetData(device).hook_extensions[ProcHook::EXTENSION_CORE_1_1]) {
36 return BindImageMemory2(device, bindInfoCount, pBindInfos);
37 } else {
38 Logger(device).Err(device, "VK_VERSION_1_0 not enabled. vkBindImageMemory2 not executed.");
39 return VK_SUCCESS;
40 }
41}
42
43VKAPI_ATTR void checkedGetDeviceQueue2(VkDevice device, const VkDeviceQueueInfo2* pQueueInfo, VkQueue* pQueue) {
44 if (GetData(device).hook_extensions[ProcHook::EXTENSION_CORE_1_1]) {
45 GetDeviceQueue2(device, pQueueInfo, pQueue);
46 } else {
47 Logger(device).Err(device, "VK_VERSION_1_0 not enabled. vkGetDeviceQueue2 not executed.");
48 }
49}
50
Chia-I Wueb7db122016-03-24 09:11:06 +080051VKAPI_ATTR VkResult checkedCreateSwapchainKHR(VkDevice device, const VkSwapchainCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchain) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080052 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
53 return CreateSwapchainKHR(device, pCreateInfo, pAllocator, pSwapchain);
54 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080055 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkCreateSwapchainKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080056 return VK_SUCCESS;
57 }
Chia-I Wueb7db122016-03-24 09:11:06 +080058}
59
60VKAPI_ATTR void checkedDestroySwapchainKHR(VkDevice device, VkSwapchainKHR swapchain, const VkAllocationCallbacks* pAllocator) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080061 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
62 DestroySwapchainKHR(device, swapchain, pAllocator);
63 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080064 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkDestroySwapchainKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080065 }
Chia-I Wueb7db122016-03-24 09:11:06 +080066}
67
68VKAPI_ATTR VkResult checkedGetSwapchainImagesKHR(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pSwapchainImageCount, VkImage* pSwapchainImages) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080069 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
70 return GetSwapchainImagesKHR(device, swapchain, pSwapchainImageCount, pSwapchainImages);
71 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080072 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkGetSwapchainImagesKHR 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
77VKAPI_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 +080078 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
79 return AcquireNextImageKHR(device, swapchain, timeout, semaphore, fence, pImageIndex);
80 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080081 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkAcquireNextImageKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080082 return VK_SUCCESS;
83 }
Chia-I Wueb7db122016-03-24 09:11:06 +080084}
85
86VKAPI_ATTR VkResult checkedQueuePresentKHR(VkQueue queue, const VkPresentInfoKHR* pPresentInfo) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080087 if (GetData(queue).hook_extensions[ProcHook::KHR_swapchain]) {
88 return QueuePresentKHR(queue, pPresentInfo);
89 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080090 Logger(queue).Err(queue, "VK_KHR_swapchain not enabled. vkQueuePresentKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080091 return VK_SUCCESS;
92 }
Chia-I Wueb7db122016-03-24 09:11:06 +080093}
94
Daniel Kochf25f5bb2017-10-05 00:26:58 -040095VKAPI_ATTR VkResult checkedGetDeviceGroupPresentCapabilitiesKHR(VkDevice device, VkDeviceGroupPresentCapabilitiesKHR* pDeviceGroupPresentCapabilities) {
96 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
97 return GetDeviceGroupPresentCapabilitiesKHR(device, pDeviceGroupPresentCapabilities);
98 } else {
99 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkGetDeviceGroupPresentCapabilitiesKHR not executed.");
100 return VK_SUCCESS;
101 }
102}
103
104VKAPI_ATTR VkResult checkedGetDeviceGroupSurfacePresentModesKHR(VkDevice device, VkSurfaceKHR surface, VkDeviceGroupPresentModeFlagsKHR* pModes) {
105 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
106 return GetDeviceGroupSurfacePresentModesKHR(device, surface, pModes);
107 } else {
108 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkGetDeviceGroupSurfacePresentModesKHR not executed.");
109 return VK_SUCCESS;
110 }
111}
112
113VKAPI_ATTR VkResult checkedAcquireNextImage2KHR(VkDevice device, const VkAcquireNextImageInfoKHR* pAcquireInfo, uint32_t* pImageIndex) {
114 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
115 return AcquireNextImage2KHR(device, pAcquireInfo, pImageIndex);
116 } else {
117 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkAcquireNextImage2KHR not executed.");
118 return VK_SUCCESS;
119 }
120}
121
Ian Elliott4c8bb2a2016-12-29 11:07:26 -0700122VKAPI_ATTR VkResult checkedGetRefreshCycleDurationGOOGLE(VkDevice device, VkSwapchainKHR swapchain, VkRefreshCycleDurationGOOGLE* pDisplayTimingProperties) {
123 if (GetData(device).hook_extensions[ProcHook::GOOGLE_display_timing]) {
124 return GetRefreshCycleDurationGOOGLE(device, swapchain, pDisplayTimingProperties);
125 } else {
126 Logger(device).Err(device, "VK_GOOGLE_display_timing not enabled. vkGetRefreshCycleDurationGOOGLE not executed.");
127 return VK_SUCCESS;
128 }
129}
130
131VKAPI_ATTR VkResult checkedGetPastPresentationTimingGOOGLE(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pPresentationTimingCount, VkPastPresentationTimingGOOGLE* pPresentationTimings) {
132 if (GetData(device).hook_extensions[ProcHook::GOOGLE_display_timing]) {
133 return GetPastPresentationTimingGOOGLE(device, swapchain, pPresentationTimingCount, pPresentationTimings);
134 } else {
135 Logger(device).Err(device, "VK_GOOGLE_display_timing not enabled. vkGetPastPresentationTimingGOOGLE not executed.");
136 return VK_SUCCESS;
137 }
138}
139
Jesse Hall889cd9a2017-02-25 22:12:23 -0800140VKAPI_ATTR void checkedSetHdrMetadataEXT(VkDevice device, uint32_t swapchainCount, const VkSwapchainKHR* pSwapchains, const VkHdrMetadataEXT* pMetadata) {
141 if (GetData(device).hook_extensions[ProcHook::EXT_hdr_metadata]) {
142 SetHdrMetadataEXT(device, swapchainCount, pSwapchains, pMetadata);
143 } else {
144 Logger(device).Err(device, "VK_EXT_hdr_metadata not enabled. vkSetHdrMetadataEXT not executed.");
145 }
146}
147
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300148VKAPI_ATTR VkResult checkedGetSwapchainStatusKHR(VkDevice device, VkSwapchainKHR swapchain) {
Chris Forbes1d5f68c2017-01-31 10:17:01 +1300149 if (GetData(device).hook_extensions[ProcHook::KHR_shared_presentable_image]) {
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300150 return GetSwapchainStatusKHR(device, swapchain);
151 } else {
Chris Forbes1d5f68c2017-01-31 10:17:01 +1300152 Logger(device).Err(device, "VK_KHR_shared_presentable_image not enabled. vkGetSwapchainStatusKHR not executed.");
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300153 return VK_SUCCESS;
154 }
155}
156
Yiwei Zhang23143102019-04-10 18:24:05 -0700157VKAPI_ATTR VkResult checkedBindImageMemory2KHR(VkDevice device, uint32_t bindInfoCount, const VkBindImageMemoryInfoKHR* pBindInfos) {
158 if (GetData(device).hook_extensions[ProcHook::KHR_bind_memory2]) {
159 return BindImageMemory2KHR(device, bindInfoCount, pBindInfos);
160 } else {
161 Logger(device).Err(device, "VK_KHR_bind_memory2 not enabled. vkBindImageMemory2KHR not executed.");
162 return VK_SUCCESS;
163 }
164}
165
Chia-I Wueb7db122016-03-24 09:11:06 +0800166// clang-format on
167
168const ProcHook g_proc_hooks[] = {
169 // clang-format off
170 {
171 "vkAcquireImageANDROID",
172 ProcHook::DEVICE,
173 ProcHook::ANDROID_native_buffer,
174 nullptr,
175 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800176 },
177 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400178 "vkAcquireNextImage2KHR",
179 ProcHook::DEVICE,
180 ProcHook::KHR_swapchain,
181 reinterpret_cast<PFN_vkVoidFunction>(AcquireNextImage2KHR),
182 reinterpret_cast<PFN_vkVoidFunction>(checkedAcquireNextImage2KHR),
183 },
184 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800185 "vkAcquireNextImageKHR",
186 ProcHook::DEVICE,
187 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800188 reinterpret_cast<PFN_vkVoidFunction>(AcquireNextImageKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800189 reinterpret_cast<PFN_vkVoidFunction>(checkedAcquireNextImageKHR),
190 },
191 {
192 "vkAllocateCommandBuffers",
193 ProcHook::DEVICE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700194 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wu6a58a8a2016-03-24 16:29:51 +0800195 reinterpret_cast<PFN_vkVoidFunction>(AllocateCommandBuffers),
Chia-I Wueb7db122016-03-24 09:11:06 +0800196 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800197 },
198 {
Yiwei Zhang23143102019-04-10 18:24:05 -0700199 "vkBindImageMemory2",
200 ProcHook::DEVICE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700201 ProcHook::EXTENSION_CORE_1_1,
Yiwei Zhang23143102019-04-10 18:24:05 -0700202 reinterpret_cast<PFN_vkVoidFunction>(BindImageMemory2),
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700203 reinterpret_cast<PFN_vkVoidFunction>(checkedBindImageMemory2),
Yiwei Zhang23143102019-04-10 18:24:05 -0700204 },
205 {
206 "vkBindImageMemory2KHR",
207 ProcHook::DEVICE,
208 ProcHook::KHR_bind_memory2,
209 reinterpret_cast<PFN_vkVoidFunction>(BindImageMemory2KHR),
210 reinterpret_cast<PFN_vkVoidFunction>(checkedBindImageMemory2KHR),
211 },
212 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800213 "vkCreateAndroidSurfaceKHR",
214 ProcHook::INSTANCE,
215 ProcHook::KHR_android_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800216 reinterpret_cast<PFN_vkVoidFunction>(CreateAndroidSurfaceKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800217 nullptr,
218 },
219 {
220 "vkCreateDebugReportCallbackEXT",
221 ProcHook::INSTANCE,
222 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800223 reinterpret_cast<PFN_vkVoidFunction>(CreateDebugReportCallbackEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800224 nullptr,
225 },
226 {
227 "vkCreateDevice",
228 ProcHook::INSTANCE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700229 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wu4901db72016-03-24 16:38:58 +0800230 reinterpret_cast<PFN_vkVoidFunction>(CreateDevice),
Chia-I Wueb7db122016-03-24 09:11:06 +0800231 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800232 },
233 {
234 "vkCreateInstance",
235 ProcHook::GLOBAL,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700236 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800237 reinterpret_cast<PFN_vkVoidFunction>(CreateInstance),
Chia-I Wueb7db122016-03-24 09:11:06 +0800238 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800239 },
240 {
241 "vkCreateSwapchainKHR",
242 ProcHook::DEVICE,
243 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800244 reinterpret_cast<PFN_vkVoidFunction>(CreateSwapchainKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800245 reinterpret_cast<PFN_vkVoidFunction>(checkedCreateSwapchainKHR),
246 },
247 {
248 "vkDebugReportMessageEXT",
249 ProcHook::INSTANCE,
250 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800251 reinterpret_cast<PFN_vkVoidFunction>(DebugReportMessageEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800252 nullptr,
253 },
254 {
255 "vkDestroyDebugReportCallbackEXT",
256 ProcHook::INSTANCE,
257 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800258 reinterpret_cast<PFN_vkVoidFunction>(DestroyDebugReportCallbackEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800259 nullptr,
260 },
261 {
262 "vkDestroyDevice",
263 ProcHook::DEVICE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700264 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wu4901db72016-03-24 16:38:58 +0800265 reinterpret_cast<PFN_vkVoidFunction>(DestroyDevice),
Chia-I Wueb7db122016-03-24 09:11:06 +0800266 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800267 },
268 {
269 "vkDestroyInstance",
270 ProcHook::INSTANCE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700271 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800272 reinterpret_cast<PFN_vkVoidFunction>(DestroyInstance),
Chia-I Wueb7db122016-03-24 09:11:06 +0800273 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800274 },
275 {
276 "vkDestroySurfaceKHR",
277 ProcHook::INSTANCE,
278 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800279 reinterpret_cast<PFN_vkVoidFunction>(DestroySurfaceKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800280 nullptr,
281 },
282 {
283 "vkDestroySwapchainKHR",
284 ProcHook::DEVICE,
285 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800286 reinterpret_cast<PFN_vkVoidFunction>(DestroySwapchainKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800287 reinterpret_cast<PFN_vkVoidFunction>(checkedDestroySwapchainKHR),
288 },
289 {
290 "vkEnumerateDeviceExtensionProperties",
291 ProcHook::INSTANCE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700292 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wu01cf3052016-03-24 16:16:21 +0800293 reinterpret_cast<PFN_vkVoidFunction>(EnumerateDeviceExtensionProperties),
Chia-I Wueb7db122016-03-24 09:11:06 +0800294 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800295 },
296 {
297 "vkEnumerateInstanceExtensionProperties",
298 ProcHook::GLOBAL,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700299 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wueb7db122016-03-24 09:11:06 +0800300 reinterpret_cast<PFN_vkVoidFunction>(EnumerateInstanceExtensionProperties),
301 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800302 },
303 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400304 "vkEnumeratePhysicalDeviceGroups",
305 ProcHook::INSTANCE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700306 ProcHook::EXTENSION_CORE_1_1,
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400307 reinterpret_cast<PFN_vkVoidFunction>(EnumeratePhysicalDeviceGroups),
308 nullptr,
309 },
310 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800311 "vkEnumeratePhysicalDevices",
312 ProcHook::INSTANCE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700313 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800314 reinterpret_cast<PFN_vkVoidFunction>(EnumeratePhysicalDevices),
Chia-I Wueb7db122016-03-24 09:11:06 +0800315 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800316 },
317 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400318 "vkGetDeviceGroupPresentCapabilitiesKHR",
319 ProcHook::DEVICE,
320 ProcHook::KHR_swapchain,
321 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceGroupPresentCapabilitiesKHR),
322 reinterpret_cast<PFN_vkVoidFunction>(checkedGetDeviceGroupPresentCapabilitiesKHR),
323 },
324 {
325 "vkGetDeviceGroupSurfacePresentModesKHR",
326 ProcHook::DEVICE,
327 ProcHook::KHR_swapchain,
328 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceGroupSurfacePresentModesKHR),
329 reinterpret_cast<PFN_vkVoidFunction>(checkedGetDeviceGroupSurfacePresentModesKHR),
330 },
331 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800332 "vkGetDeviceProcAddr",
333 ProcHook::DEVICE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700334 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wueb7db122016-03-24 09:11:06 +0800335 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceProcAddr),
336 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800337 },
338 {
339 "vkGetDeviceQueue",
340 ProcHook::DEVICE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700341 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wuba0be412016-03-24 16:24:40 +0800342 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceQueue),
Chia-I Wueb7db122016-03-24 09:11:06 +0800343 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800344 },
345 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400346 "vkGetDeviceQueue2",
347 ProcHook::DEVICE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700348 ProcHook::EXTENSION_CORE_1_1,
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400349 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceQueue2),
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700350 reinterpret_cast<PFN_vkVoidFunction>(checkedGetDeviceQueue2),
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400351 },
352 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800353 "vkGetInstanceProcAddr",
354 ProcHook::INSTANCE,
Yiwei Zhangec6c5052019-10-17 15:53:00 -0700355 ProcHook::EXTENSION_CORE_1_0,
Chia-I Wueb7db122016-03-24 09:11:06 +0800356 reinterpret_cast<PFN_vkVoidFunction>(GetInstanceProcAddr),
357 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800358 },
359 {
Ian Elliott4c8bb2a2016-12-29 11:07:26 -0700360 "vkGetPastPresentationTimingGOOGLE",
361 ProcHook::DEVICE,
362 ProcHook::GOOGLE_display_timing,
363 reinterpret_cast<PFN_vkVoidFunction>(GetPastPresentationTimingGOOGLE),
364 reinterpret_cast<PFN_vkVoidFunction>(checkedGetPastPresentationTimingGOOGLE),
365 },
366 {
Daniel Kochf25f5bb2017-10-05 00:26:58 -0400367 "vkGetPhysicalDevicePresentRectanglesKHR",
368 ProcHook::INSTANCE,
369 ProcHook::KHR_swapchain,
370 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDevicePresentRectanglesKHR),
371 nullptr,
372 },
373 {
Chris Forbes2452cf72017-03-16 16:30:17 +1300374 "vkGetPhysicalDeviceSurfaceCapabilities2KHR",
375 ProcHook::INSTANCE,
376 ProcHook::KHR_get_surface_capabilities2,
377 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceCapabilities2KHR),
378 nullptr,
379 },
380 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800381 "vkGetPhysicalDeviceSurfaceCapabilitiesKHR",
382 ProcHook::INSTANCE,
383 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800384 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceCapabilitiesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800385 nullptr,
386 },
387 {
Chris Forbes2452cf72017-03-16 16:30:17 +1300388 "vkGetPhysicalDeviceSurfaceFormats2KHR",
389 ProcHook::INSTANCE,
390 ProcHook::KHR_get_surface_capabilities2,
391 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceFormats2KHR),
392 nullptr,
393 },
394 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800395 "vkGetPhysicalDeviceSurfaceFormatsKHR",
396 ProcHook::INSTANCE,
397 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800398 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceFormatsKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800399 nullptr,
400 },
401 {
402 "vkGetPhysicalDeviceSurfacePresentModesKHR",
403 ProcHook::INSTANCE,
404 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800405 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfacePresentModesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800406 nullptr,
407 },
408 {
409 "vkGetPhysicalDeviceSurfaceSupportKHR",
410 ProcHook::INSTANCE,
411 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800412 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceSupportKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800413 nullptr,
414 },
415 {
Ian Elliott4c8bb2a2016-12-29 11:07:26 -0700416 "vkGetRefreshCycleDurationGOOGLE",
417 ProcHook::DEVICE,
418 ProcHook::GOOGLE_display_timing,
419 reinterpret_cast<PFN_vkVoidFunction>(GetRefreshCycleDurationGOOGLE),
420 reinterpret_cast<PFN_vkVoidFunction>(checkedGetRefreshCycleDurationGOOGLE),
421 },
422 {
Chris Forbes8e4438b2016-12-07 16:26:49 +1300423 "vkGetSwapchainGrallocUsage2ANDROID",
424 ProcHook::DEVICE,
425 ProcHook::ANDROID_native_buffer,
426 nullptr,
427 nullptr,
428 },
429 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800430 "vkGetSwapchainGrallocUsageANDROID",
431 ProcHook::DEVICE,
432 ProcHook::ANDROID_native_buffer,
433 nullptr,
434 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800435 },
436 {
437 "vkGetSwapchainImagesKHR",
438 ProcHook::DEVICE,
439 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800440 reinterpret_cast<PFN_vkVoidFunction>(GetSwapchainImagesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800441 reinterpret_cast<PFN_vkVoidFunction>(checkedGetSwapchainImagesKHR),
442 },
443 {
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300444 "vkGetSwapchainStatusKHR",
445 ProcHook::DEVICE,
Chris Forbes1d5f68c2017-01-31 10:17:01 +1300446 ProcHook::KHR_shared_presentable_image,
Chris Forbes0f2ac2e2017-01-18 13:33:53 +1300447 reinterpret_cast<PFN_vkVoidFunction>(GetSwapchainStatusKHR),
448 reinterpret_cast<PFN_vkVoidFunction>(checkedGetSwapchainStatusKHR),
449 },
450 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800451 "vkQueuePresentKHR",
452 ProcHook::DEVICE,
453 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800454 reinterpret_cast<PFN_vkVoidFunction>(QueuePresentKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800455 reinterpret_cast<PFN_vkVoidFunction>(checkedQueuePresentKHR),
456 },
457 {
458 "vkQueueSignalReleaseImageANDROID",
459 ProcHook::DEVICE,
460 ProcHook::ANDROID_native_buffer,
461 nullptr,
462 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800463 },
Courtney Goeltzenleuchterd634c482017-01-05 15:55:31 -0700464 {
465 "vkSetHdrMetadataEXT",
466 ProcHook::DEVICE,
467 ProcHook::EXT_hdr_metadata,
468 reinterpret_cast<PFN_vkVoidFunction>(SetHdrMetadataEXT),
469 reinterpret_cast<PFN_vkVoidFunction>(checkedSetHdrMetadataEXT),
470 },
Chia-I Wueb7db122016-03-24 09:11:06 +0800471 // clang-format on
472};
473
Chris Forbese2d3ee12017-03-16 16:10:15 +1300474} // namespace
Chia-I Wueb7db122016-03-24 09:11:06 +0800475
476const ProcHook* GetProcHook(const char* name) {
477 const auto& begin = g_proc_hooks;
478 const auto& end =
479 g_proc_hooks + sizeof(g_proc_hooks) / sizeof(g_proc_hooks[0]);
480 const auto hook = std::lower_bound(
481 begin, end, name,
482 [](const ProcHook& e, const char* n) { return strcmp(e.name, n) < 0; });
483 return (hook < end && strcmp(hook->name, name) == 0) ? hook : nullptr;
484}
485
486ProcHook::Extension GetProcHookExtension(const char* name) {
487 // clang-format off
488 if (strcmp(name, "VK_ANDROID_native_buffer") == 0) return ProcHook::ANDROID_native_buffer;
489 if (strcmp(name, "VK_EXT_debug_report") == 0) return ProcHook::EXT_debug_report;
Courtney Goeltzenleuchterd634c482017-01-05 15:55:31 -0700490 if (strcmp(name, "VK_EXT_hdr_metadata") == 0) return ProcHook::EXT_hdr_metadata;
Courtney Goeltzenleuchtere278daf2017-02-02 16:54:57 -0700491 if (strcmp(name, "VK_EXT_swapchain_colorspace") == 0) return ProcHook::EXT_swapchain_colorspace;
Courtney Goeltzenleuchterd634c482017-01-05 15:55:31 -0700492 if (strcmp(name, "VK_GOOGLE_display_timing") == 0) return ProcHook::GOOGLE_display_timing;
Chia-I Wueb7db122016-03-24 09:11:06 +0800493 if (strcmp(name, "VK_KHR_android_surface") == 0) return ProcHook::KHR_android_surface;
Chris Forbes48853712017-01-12 14:09:33 +1300494 if (strcmp(name, "VK_KHR_incremental_present") == 0) return ProcHook::KHR_incremental_present;
Courtney Goeltzenleuchtere278daf2017-02-02 16:54:57 -0700495 if (strcmp(name, "VK_KHR_shared_presentable_image") == 0) return ProcHook::KHR_shared_presentable_image;
Chia-I Wueb7db122016-03-24 09:11:06 +0800496 if (strcmp(name, "VK_KHR_surface") == 0) return ProcHook::KHR_surface;
497 if (strcmp(name, "VK_KHR_swapchain") == 0) return ProcHook::KHR_swapchain;
Chris Forbes2452cf72017-03-16 16:30:17 +1300498 if (strcmp(name, "VK_KHR_get_surface_capabilities2") == 0) return ProcHook::KHR_get_surface_capabilities2;
Chris Forbes6aa30db2017-02-20 17:12:53 +1300499 if (strcmp(name, "VK_KHR_get_physical_device_properties2") == 0) return ProcHook::KHR_get_physical_device_properties2;
Jesse Halla8d367a2018-01-18 15:40:46 -0800500 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 -0700501 if (strcmp(name, "VK_KHR_bind_memory2") == 0) return ProcHook::KHR_bind_memory2;
Chia-I Wueb7db122016-03-24 09:11:06 +0800502 // clang-format on
503 return ProcHook::EXTENSION_UNKNOWN;
504}
505
Chia-I Wucc5e2762016-03-24 13:01:16 +0800506#define UNLIKELY(expr) __builtin_expect((expr), 0)
507
Chris Forbes5948b3e2016-12-23 13:49:53 +1300508#define INIT_PROC(required, obj, proc) \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800509 do { \
510 data.driver.proc = \
511 reinterpret_cast<PFN_vk##proc>(get_proc(obj, "vk" #proc)); \
Chris Forbes5948b3e2016-12-23 13:49:53 +1300512 if (UNLIKELY(required && !data.driver.proc)) { \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800513 ALOGE("missing " #obj " proc: vk" #proc); \
514 success = false; \
515 } \
516 } while (0)
517
Chris Forbes5948b3e2016-12-23 13:49:53 +1300518#define INIT_PROC_EXT(ext, required, obj, proc) \
519 do { \
520 if (extensions[ProcHook::ext]) \
521 INIT_PROC(required, obj, proc); \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800522 } while (0)
523
Chia-I Wucbe07ef2016-04-13 15:01:00 +0800524bool InitDriverTable(VkInstance instance,
525 PFN_vkGetInstanceProcAddr get_proc,
526 const std::bitset<ProcHook::EXTENSION_COUNT>& extensions) {
Chia-I Wucc5e2762016-03-24 13:01:16 +0800527 auto& data = GetData(instance);
528 bool success = true;
529
530 // clang-format off
Chris Forbes5948b3e2016-12-23 13:49:53 +1300531 INIT_PROC(true, instance, DestroyInstance);
532 INIT_PROC(true, instance, EnumeratePhysicalDevices);
533 INIT_PROC(true, instance, GetInstanceProcAddr);
Jesse Hall85bb0c52017-02-09 22:13:02 -0800534 INIT_PROC(true, instance, GetPhysicalDeviceProperties);
Chris Forbes5948b3e2016-12-23 13:49:53 +1300535 INIT_PROC(true, instance, CreateDevice);
536 INIT_PROC(true, instance, EnumerateDeviceExtensionProperties);
Ian Elliottcd8ad332017-10-13 09:21:12 -0600537 INIT_PROC(false, instance, EnumeratePhysicalDeviceGroups);
Yiwei Zhang922b1e32018-03-13 17:12:11 -0700538 INIT_PROC(false, instance, GetPhysicalDeviceProperties2);
Chris Forbes5948b3e2016-12-23 13:49:53 +1300539 INIT_PROC_EXT(EXT_debug_report, true, instance, CreateDebugReportCallbackEXT);
540 INIT_PROC_EXT(EXT_debug_report, true, instance, DestroyDebugReportCallbackEXT);
541 INIT_PROC_EXT(EXT_debug_report, true, instance, DebugReportMessageEXT);
Chris Forbes6aa30db2017-02-20 17:12:53 +1300542 INIT_PROC_EXT(KHR_get_physical_device_properties2, true, instance, GetPhysicalDeviceProperties2KHR);
Chia-I Wucc5e2762016-03-24 13:01:16 +0800543 // clang-format on
544
545 return success;
546}
547
Chia-I Wucbe07ef2016-04-13 15:01:00 +0800548bool InitDriverTable(VkDevice dev,
549 PFN_vkGetDeviceProcAddr get_proc,
550 const std::bitset<ProcHook::EXTENSION_COUNT>& extensions) {
Chia-I Wucc5e2762016-03-24 13:01:16 +0800551 auto& data = GetData(dev);
552 bool success = true;
553
554 // clang-format off
Chris Forbes5948b3e2016-12-23 13:49:53 +1300555 INIT_PROC(true, dev, GetDeviceProcAddr);
556 INIT_PROC(true, dev, DestroyDevice);
557 INIT_PROC(true, dev, GetDeviceQueue);
558 INIT_PROC(true, dev, CreateImage);
559 INIT_PROC(true, dev, DestroyImage);
560 INIT_PROC(true, dev, AllocateCommandBuffers);
Yiwei Zhang23143102019-04-10 18:24:05 -0700561 INIT_PROC(false, dev, BindImageMemory2);
Ian Elliottcd8ad332017-10-13 09:21:12 -0600562 INIT_PROC(false, dev, GetDeviceQueue2);
Chris Forbesd8277912017-02-10 14:59:59 +1300563 INIT_PROC_EXT(ANDROID_native_buffer, false, dev, GetSwapchainGrallocUsageANDROID);
Chris Forbes5948b3e2016-12-23 13:49:53 +1300564 INIT_PROC_EXT(ANDROID_native_buffer, false, dev, GetSwapchainGrallocUsage2ANDROID);
565 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, AcquireImageANDROID);
566 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, QueueSignalReleaseImageANDROID);
Yiwei Zhang23143102019-04-10 18:24:05 -0700567 INIT_PROC_EXT(KHR_bind_memory2, true, dev, BindImageMemory2KHR);
Chia-I Wucc5e2762016-03-24 13:01:16 +0800568 // clang-format on
569
570 return success;
571}
572
Chia-I Wueb7db122016-03-24 09:11:06 +0800573} // namespace driver
574} // namespace vulkan
575
576// clang-format on