blob: 1312a6216689fb39b9420e907e5e52e51c3bc330 [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
23#include <android/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
Chia-I Wueb7db122016-03-24 09:11:06 +080034VKAPI_ATTR VkResult checkedCreateSwapchainKHR(VkDevice device, const VkSwapchainCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchain) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080035 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
36 return CreateSwapchainKHR(device, pCreateInfo, pAllocator, pSwapchain);
37 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080038 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkCreateSwapchainKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080039 return VK_SUCCESS;
40 }
Chia-I Wueb7db122016-03-24 09:11:06 +080041}
42
43VKAPI_ATTR void checkedDestroySwapchainKHR(VkDevice device, VkSwapchainKHR swapchain, const VkAllocationCallbacks* pAllocator) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080044 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
45 DestroySwapchainKHR(device, swapchain, pAllocator);
46 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080047 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkDestroySwapchainKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080048 }
Chia-I Wueb7db122016-03-24 09:11:06 +080049}
50
51VKAPI_ATTR VkResult checkedGetSwapchainImagesKHR(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pSwapchainImageCount, VkImage* pSwapchainImages) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080052 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
53 return GetSwapchainImagesKHR(device, swapchain, pSwapchainImageCount, pSwapchainImages);
54 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080055 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkGetSwapchainImagesKHR 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 VkResult checkedAcquireNextImageKHR(VkDevice device, VkSwapchainKHR swapchain, uint64_t timeout, VkSemaphore semaphore, VkFence fence, uint32_t* pImageIndex) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080061 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
62 return AcquireNextImageKHR(device, swapchain, timeout, semaphore, fence, pImageIndex);
63 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080064 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkAcquireNextImageKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080065 return VK_SUCCESS;
66 }
Chia-I Wueb7db122016-03-24 09:11:06 +080067}
68
69VKAPI_ATTR VkResult checkedQueuePresentKHR(VkQueue queue, const VkPresentInfoKHR* pPresentInfo) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080070 if (GetData(queue).hook_extensions[ProcHook::KHR_swapchain]) {
71 return QueuePresentKHR(queue, pPresentInfo);
72 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080073 Logger(queue).Err(queue, "VK_KHR_swapchain not enabled. vkQueuePresentKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080074 return VK_SUCCESS;
75 }
Chia-I Wueb7db122016-03-24 09:11:06 +080076}
77
78// clang-format on
79
80const ProcHook g_proc_hooks[] = {
81 // clang-format off
82 {
83 "vkAcquireImageANDROID",
84 ProcHook::DEVICE,
85 ProcHook::ANDROID_native_buffer,
86 nullptr,
87 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +080088 },
89 {
90 "vkAcquireNextImageKHR",
91 ProcHook::DEVICE,
92 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +080093 reinterpret_cast<PFN_vkVoidFunction>(AcquireNextImageKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +080094 reinterpret_cast<PFN_vkVoidFunction>(checkedAcquireNextImageKHR),
95 },
96 {
97 "vkAllocateCommandBuffers",
98 ProcHook::DEVICE,
99 ProcHook::EXTENSION_CORE,
Chia-I Wu6a58a8a2016-03-24 16:29:51 +0800100 reinterpret_cast<PFN_vkVoidFunction>(AllocateCommandBuffers),
Chia-I Wueb7db122016-03-24 09:11:06 +0800101 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800102 },
103 {
104 "vkCreateAndroidSurfaceKHR",
105 ProcHook::INSTANCE,
106 ProcHook::KHR_android_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800107 reinterpret_cast<PFN_vkVoidFunction>(CreateAndroidSurfaceKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800108 nullptr,
109 },
110 {
111 "vkCreateDebugReportCallbackEXT",
112 ProcHook::INSTANCE,
113 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800114 reinterpret_cast<PFN_vkVoidFunction>(CreateDebugReportCallbackEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800115 nullptr,
116 },
117 {
118 "vkCreateDevice",
119 ProcHook::INSTANCE,
120 ProcHook::EXTENSION_CORE,
Chia-I Wu4901db72016-03-24 16:38:58 +0800121 reinterpret_cast<PFN_vkVoidFunction>(CreateDevice),
Chia-I Wueb7db122016-03-24 09:11:06 +0800122 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800123 },
124 {
125 "vkCreateInstance",
126 ProcHook::GLOBAL,
127 ProcHook::EXTENSION_CORE,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800128 reinterpret_cast<PFN_vkVoidFunction>(CreateInstance),
Chia-I Wueb7db122016-03-24 09:11:06 +0800129 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800130 },
131 {
132 "vkCreateSwapchainKHR",
133 ProcHook::DEVICE,
134 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800135 reinterpret_cast<PFN_vkVoidFunction>(CreateSwapchainKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800136 reinterpret_cast<PFN_vkVoidFunction>(checkedCreateSwapchainKHR),
137 },
138 {
139 "vkDebugReportMessageEXT",
140 ProcHook::INSTANCE,
141 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800142 reinterpret_cast<PFN_vkVoidFunction>(DebugReportMessageEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800143 nullptr,
144 },
145 {
146 "vkDestroyDebugReportCallbackEXT",
147 ProcHook::INSTANCE,
148 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800149 reinterpret_cast<PFN_vkVoidFunction>(DestroyDebugReportCallbackEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800150 nullptr,
151 },
152 {
153 "vkDestroyDevice",
154 ProcHook::DEVICE,
155 ProcHook::EXTENSION_CORE,
Chia-I Wu4901db72016-03-24 16:38:58 +0800156 reinterpret_cast<PFN_vkVoidFunction>(DestroyDevice),
Chia-I Wueb7db122016-03-24 09:11:06 +0800157 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800158 },
159 {
160 "vkDestroyInstance",
161 ProcHook::INSTANCE,
162 ProcHook::EXTENSION_CORE,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800163 reinterpret_cast<PFN_vkVoidFunction>(DestroyInstance),
Chia-I Wueb7db122016-03-24 09:11:06 +0800164 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800165 },
166 {
167 "vkDestroySurfaceKHR",
168 ProcHook::INSTANCE,
169 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800170 reinterpret_cast<PFN_vkVoidFunction>(DestroySurfaceKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800171 nullptr,
172 },
173 {
174 "vkDestroySwapchainKHR",
175 ProcHook::DEVICE,
176 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800177 reinterpret_cast<PFN_vkVoidFunction>(DestroySwapchainKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800178 reinterpret_cast<PFN_vkVoidFunction>(checkedDestroySwapchainKHR),
179 },
180 {
181 "vkEnumerateDeviceExtensionProperties",
182 ProcHook::INSTANCE,
183 ProcHook::EXTENSION_CORE,
Chia-I Wu01cf3052016-03-24 16:16:21 +0800184 reinterpret_cast<PFN_vkVoidFunction>(EnumerateDeviceExtensionProperties),
Chia-I Wueb7db122016-03-24 09:11:06 +0800185 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800186 },
187 {
188 "vkEnumerateInstanceExtensionProperties",
189 ProcHook::GLOBAL,
190 ProcHook::EXTENSION_CORE,
191 reinterpret_cast<PFN_vkVoidFunction>(EnumerateInstanceExtensionProperties),
192 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800193 },
194 {
195 "vkEnumeratePhysicalDevices",
196 ProcHook::INSTANCE,
197 ProcHook::EXTENSION_CORE,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800198 reinterpret_cast<PFN_vkVoidFunction>(EnumeratePhysicalDevices),
Chia-I Wueb7db122016-03-24 09:11:06 +0800199 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800200 },
201 {
202 "vkGetDeviceProcAddr",
203 ProcHook::DEVICE,
204 ProcHook::EXTENSION_CORE,
205 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceProcAddr),
206 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800207 },
208 {
209 "vkGetDeviceQueue",
210 ProcHook::DEVICE,
211 ProcHook::EXTENSION_CORE,
Chia-I Wuba0be412016-03-24 16:24:40 +0800212 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceQueue),
Chia-I Wueb7db122016-03-24 09:11:06 +0800213 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800214 },
215 {
216 "vkGetInstanceProcAddr",
217 ProcHook::INSTANCE,
218 ProcHook::EXTENSION_CORE,
219 reinterpret_cast<PFN_vkVoidFunction>(GetInstanceProcAddr),
220 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800221 },
222 {
223 "vkGetPhysicalDeviceSurfaceCapabilitiesKHR",
224 ProcHook::INSTANCE,
225 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800226 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceCapabilitiesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800227 nullptr,
228 },
229 {
230 "vkGetPhysicalDeviceSurfaceFormatsKHR",
231 ProcHook::INSTANCE,
232 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800233 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceFormatsKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800234 nullptr,
235 },
236 {
237 "vkGetPhysicalDeviceSurfacePresentModesKHR",
238 ProcHook::INSTANCE,
239 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800240 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfacePresentModesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800241 nullptr,
242 },
243 {
244 "vkGetPhysicalDeviceSurfaceSupportKHR",
245 ProcHook::INSTANCE,
246 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800247 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceSupportKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800248 nullptr,
249 },
250 {
Chris Forbes8e4438b2016-12-07 16:26:49 +1300251 "vkGetSwapchainGrallocUsage2ANDROID",
252 ProcHook::DEVICE,
253 ProcHook::ANDROID_native_buffer,
254 nullptr,
255 nullptr,
256 },
257 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800258 "vkGetSwapchainGrallocUsageANDROID",
259 ProcHook::DEVICE,
260 ProcHook::ANDROID_native_buffer,
261 nullptr,
262 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800263 },
264 {
265 "vkGetSwapchainImagesKHR",
266 ProcHook::DEVICE,
267 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800268 reinterpret_cast<PFN_vkVoidFunction>(GetSwapchainImagesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800269 reinterpret_cast<PFN_vkVoidFunction>(checkedGetSwapchainImagesKHR),
270 },
271 {
272 "vkQueuePresentKHR",
273 ProcHook::DEVICE,
274 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800275 reinterpret_cast<PFN_vkVoidFunction>(QueuePresentKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800276 reinterpret_cast<PFN_vkVoidFunction>(checkedQueuePresentKHR),
277 },
278 {
279 "vkQueueSignalReleaseImageANDROID",
280 ProcHook::DEVICE,
281 ProcHook::ANDROID_native_buffer,
282 nullptr,
283 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800284 },
285 // clang-format on
286};
287
288} // anonymous
289
290const ProcHook* GetProcHook(const char* name) {
291 const auto& begin = g_proc_hooks;
292 const auto& end =
293 g_proc_hooks + sizeof(g_proc_hooks) / sizeof(g_proc_hooks[0]);
294 const auto hook = std::lower_bound(
295 begin, end, name,
296 [](const ProcHook& e, const char* n) { return strcmp(e.name, n) < 0; });
297 return (hook < end && strcmp(hook->name, name) == 0) ? hook : nullptr;
298}
299
300ProcHook::Extension GetProcHookExtension(const char* name) {
301 // clang-format off
302 if (strcmp(name, "VK_ANDROID_native_buffer") == 0) return ProcHook::ANDROID_native_buffer;
303 if (strcmp(name, "VK_EXT_debug_report") == 0) return ProcHook::EXT_debug_report;
304 if (strcmp(name, "VK_KHR_android_surface") == 0) return ProcHook::KHR_android_surface;
305 if (strcmp(name, "VK_KHR_surface") == 0) return ProcHook::KHR_surface;
306 if (strcmp(name, "VK_KHR_swapchain") == 0) return ProcHook::KHR_swapchain;
307 // clang-format on
308 return ProcHook::EXTENSION_UNKNOWN;
309}
310
Chia-I Wucc5e2762016-03-24 13:01:16 +0800311#define UNLIKELY(expr) __builtin_expect((expr), 0)
312
Chris Forbes5948b3e2016-12-23 13:49:53 +1300313#define INIT_PROC(required, obj, proc) \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800314 do { \
315 data.driver.proc = \
316 reinterpret_cast<PFN_vk##proc>(get_proc(obj, "vk" #proc)); \
Chris Forbes5948b3e2016-12-23 13:49:53 +1300317 if (UNLIKELY(required && !data.driver.proc)) { \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800318 ALOGE("missing " #obj " proc: vk" #proc); \
319 success = false; \
320 } \
321 } while (0)
322
Chris Forbes5948b3e2016-12-23 13:49:53 +1300323#define INIT_PROC_EXT(ext, required, obj, proc) \
324 do { \
325 if (extensions[ProcHook::ext]) \
326 INIT_PROC(required, obj, proc); \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800327 } while (0)
328
Chia-I Wucbe07ef2016-04-13 15:01:00 +0800329bool InitDriverTable(VkInstance instance,
330 PFN_vkGetInstanceProcAddr get_proc,
331 const std::bitset<ProcHook::EXTENSION_COUNT>& extensions) {
Chia-I Wucc5e2762016-03-24 13:01:16 +0800332 auto& data = GetData(instance);
333 bool success = true;
334
335 // clang-format off
Chris Forbes5948b3e2016-12-23 13:49:53 +1300336 INIT_PROC(true, instance, DestroyInstance);
337 INIT_PROC(true, instance, EnumeratePhysicalDevices);
338 INIT_PROC(true, instance, GetInstanceProcAddr);
339 INIT_PROC(true, instance, CreateDevice);
340 INIT_PROC(true, instance, EnumerateDeviceExtensionProperties);
341 INIT_PROC_EXT(EXT_debug_report, true, instance, CreateDebugReportCallbackEXT);
342 INIT_PROC_EXT(EXT_debug_report, true, instance, DestroyDebugReportCallbackEXT);
343 INIT_PROC_EXT(EXT_debug_report, true, instance, DebugReportMessageEXT);
Chia-I Wucc5e2762016-03-24 13:01:16 +0800344 // clang-format on
345
346 return success;
347}
348
Chia-I Wucbe07ef2016-04-13 15:01:00 +0800349bool InitDriverTable(VkDevice dev,
350 PFN_vkGetDeviceProcAddr get_proc,
351 const std::bitset<ProcHook::EXTENSION_COUNT>& extensions) {
Chia-I Wucc5e2762016-03-24 13:01:16 +0800352 auto& data = GetData(dev);
353 bool success = true;
354
355 // clang-format off
Chris Forbes5948b3e2016-12-23 13:49:53 +1300356 INIT_PROC(true, dev, GetDeviceProcAddr);
357 INIT_PROC(true, dev, DestroyDevice);
358 INIT_PROC(true, dev, GetDeviceQueue);
359 INIT_PROC(true, dev, CreateImage);
360 INIT_PROC(true, dev, DestroyImage);
361 INIT_PROC(true, dev, AllocateCommandBuffers);
362 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, GetSwapchainGrallocUsageANDROID);
363 INIT_PROC_EXT(ANDROID_native_buffer, false, dev, GetSwapchainGrallocUsage2ANDROID);
364 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, AcquireImageANDROID);
365 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, QueueSignalReleaseImageANDROID);
Chia-I Wucc5e2762016-03-24 13:01:16 +0800366 // clang-format on
367
368 return success;
369}
370
Chia-I Wueb7db122016-03-24 09:11:06 +0800371} // namespace driver
372} // namespace vulkan
373
374// clang-format on