blob: e27b3d17cacc29b23e5cb6d5a4ace15651427eef [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>
20#include <algorithm>
Mark Salyzyna5e161b2016-09-29 08:08:05 -070021#include <android/log.h>
Chia-I Wueb7db122016-03-24 09:11:06 +080022
23#include "driver.h"
Chia-I Wueb7db122016-03-24 09:11:06 +080024
25namespace vulkan {
26namespace driver {
27
28namespace {
29
30// clang-format off
31
Chia-I Wueb7db122016-03-24 09:11:06 +080032VKAPI_ATTR VkResult checkedCreateSwapchainKHR(VkDevice device, const VkSwapchainCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchain) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080033 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
34 return CreateSwapchainKHR(device, pCreateInfo, pAllocator, pSwapchain);
35 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080036 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkCreateSwapchainKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080037 return VK_SUCCESS;
38 }
Chia-I Wueb7db122016-03-24 09:11:06 +080039}
40
41VKAPI_ATTR void checkedDestroySwapchainKHR(VkDevice device, VkSwapchainKHR swapchain, const VkAllocationCallbacks* pAllocator) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080042 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
43 DestroySwapchainKHR(device, swapchain, pAllocator);
44 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080045 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkDestroySwapchainKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080046 }
Chia-I Wueb7db122016-03-24 09:11:06 +080047}
48
49VKAPI_ATTR VkResult checkedGetSwapchainImagesKHR(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pSwapchainImageCount, VkImage* pSwapchainImages) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080050 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
51 return GetSwapchainImagesKHR(device, swapchain, pSwapchainImageCount, pSwapchainImages);
52 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080053 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkGetSwapchainImagesKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080054 return VK_SUCCESS;
55 }
Chia-I Wueb7db122016-03-24 09:11:06 +080056}
57
58VKAPI_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 +080059 if (GetData(device).hook_extensions[ProcHook::KHR_swapchain]) {
60 return AcquireNextImageKHR(device, swapchain, timeout, semaphore, fence, pImageIndex);
61 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080062 Logger(device).Err(device, "VK_KHR_swapchain not enabled. vkAcquireNextImageKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080063 return VK_SUCCESS;
64 }
Chia-I Wueb7db122016-03-24 09:11:06 +080065}
66
67VKAPI_ATTR VkResult checkedQueuePresentKHR(VkQueue queue, const VkPresentInfoKHR* pPresentInfo) {
Chia-I Wu36cc00a2016-04-13 16:52:06 +080068 if (GetData(queue).hook_extensions[ProcHook::KHR_swapchain]) {
69 return QueuePresentKHR(queue, pPresentInfo);
70 } else {
Chia-I Wu5beb2ac2016-05-04 16:37:23 +080071 Logger(queue).Err(queue, "VK_KHR_swapchain not enabled. vkQueuePresentKHR not executed.");
Chia-I Wu36cc00a2016-04-13 16:52:06 +080072 return VK_SUCCESS;
73 }
Chia-I Wueb7db122016-03-24 09:11:06 +080074}
75
Ian Elliott4c8bb2a2016-12-29 11:07:26 -070076VKAPI_ATTR VkResult checkedGetRefreshCycleDurationGOOGLE(VkDevice device, VkSwapchainKHR swapchain, VkRefreshCycleDurationGOOGLE* pDisplayTimingProperties) {
77 if (GetData(device).hook_extensions[ProcHook::GOOGLE_display_timing]) {
78 return GetRefreshCycleDurationGOOGLE(device, swapchain, pDisplayTimingProperties);
79 } else {
80 Logger(device).Err(device, "VK_GOOGLE_display_timing not enabled. vkGetRefreshCycleDurationGOOGLE not executed.");
81 return VK_SUCCESS;
82 }
83}
84
85VKAPI_ATTR VkResult checkedGetPastPresentationTimingGOOGLE(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pPresentationTimingCount, VkPastPresentationTimingGOOGLE* pPresentationTimings) {
86 if (GetData(device).hook_extensions[ProcHook::GOOGLE_display_timing]) {
87 return GetPastPresentationTimingGOOGLE(device, swapchain, pPresentationTimingCount, pPresentationTimings);
88 } else {
89 Logger(device).Err(device, "VK_GOOGLE_display_timing not enabled. vkGetPastPresentationTimingGOOGLE not executed.");
90 return VK_SUCCESS;
91 }
92}
93
Chia-I Wueb7db122016-03-24 09:11:06 +080094// clang-format on
95
96const ProcHook g_proc_hooks[] = {
97 // clang-format off
98 {
99 "vkAcquireImageANDROID",
100 ProcHook::DEVICE,
101 ProcHook::ANDROID_native_buffer,
102 nullptr,
103 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800104 },
105 {
106 "vkAcquireNextImageKHR",
107 ProcHook::DEVICE,
108 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800109 reinterpret_cast<PFN_vkVoidFunction>(AcquireNextImageKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800110 reinterpret_cast<PFN_vkVoidFunction>(checkedAcquireNextImageKHR),
111 },
112 {
113 "vkAllocateCommandBuffers",
114 ProcHook::DEVICE,
115 ProcHook::EXTENSION_CORE,
Chia-I Wu6a58a8a2016-03-24 16:29:51 +0800116 reinterpret_cast<PFN_vkVoidFunction>(AllocateCommandBuffers),
Chia-I Wueb7db122016-03-24 09:11:06 +0800117 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800118 },
119 {
120 "vkCreateAndroidSurfaceKHR",
121 ProcHook::INSTANCE,
122 ProcHook::KHR_android_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800123 reinterpret_cast<PFN_vkVoidFunction>(CreateAndroidSurfaceKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800124 nullptr,
125 },
126 {
127 "vkCreateDebugReportCallbackEXT",
128 ProcHook::INSTANCE,
129 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800130 reinterpret_cast<PFN_vkVoidFunction>(CreateDebugReportCallbackEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800131 nullptr,
132 },
133 {
134 "vkCreateDevice",
135 ProcHook::INSTANCE,
136 ProcHook::EXTENSION_CORE,
Chia-I Wu4901db72016-03-24 16:38:58 +0800137 reinterpret_cast<PFN_vkVoidFunction>(CreateDevice),
Chia-I Wueb7db122016-03-24 09:11:06 +0800138 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800139 },
140 {
141 "vkCreateInstance",
142 ProcHook::GLOBAL,
143 ProcHook::EXTENSION_CORE,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800144 reinterpret_cast<PFN_vkVoidFunction>(CreateInstance),
Chia-I Wueb7db122016-03-24 09:11:06 +0800145 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800146 },
147 {
148 "vkCreateSwapchainKHR",
149 ProcHook::DEVICE,
150 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800151 reinterpret_cast<PFN_vkVoidFunction>(CreateSwapchainKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800152 reinterpret_cast<PFN_vkVoidFunction>(checkedCreateSwapchainKHR),
153 },
154 {
155 "vkDebugReportMessageEXT",
156 ProcHook::INSTANCE,
157 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800158 reinterpret_cast<PFN_vkVoidFunction>(DebugReportMessageEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800159 nullptr,
160 },
161 {
162 "vkDestroyDebugReportCallbackEXT",
163 ProcHook::INSTANCE,
164 ProcHook::EXT_debug_report,
Chia-I Wu62262232016-03-26 07:06:44 +0800165 reinterpret_cast<PFN_vkVoidFunction>(DestroyDebugReportCallbackEXT),
Chia-I Wueb7db122016-03-24 09:11:06 +0800166 nullptr,
167 },
168 {
169 "vkDestroyDevice",
170 ProcHook::DEVICE,
171 ProcHook::EXTENSION_CORE,
Chia-I Wu4901db72016-03-24 16:38:58 +0800172 reinterpret_cast<PFN_vkVoidFunction>(DestroyDevice),
Chia-I Wueb7db122016-03-24 09:11:06 +0800173 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800174 },
175 {
176 "vkDestroyInstance",
177 ProcHook::INSTANCE,
178 ProcHook::EXTENSION_CORE,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800179 reinterpret_cast<PFN_vkVoidFunction>(DestroyInstance),
Chia-I Wueb7db122016-03-24 09:11:06 +0800180 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800181 },
182 {
183 "vkDestroySurfaceKHR",
184 ProcHook::INSTANCE,
185 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800186 reinterpret_cast<PFN_vkVoidFunction>(DestroySurfaceKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800187 nullptr,
188 },
189 {
190 "vkDestroySwapchainKHR",
191 ProcHook::DEVICE,
192 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800193 reinterpret_cast<PFN_vkVoidFunction>(DestroySwapchainKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800194 reinterpret_cast<PFN_vkVoidFunction>(checkedDestroySwapchainKHR),
195 },
196 {
197 "vkEnumerateDeviceExtensionProperties",
198 ProcHook::INSTANCE,
199 ProcHook::EXTENSION_CORE,
Chia-I Wu01cf3052016-03-24 16:16:21 +0800200 reinterpret_cast<PFN_vkVoidFunction>(EnumerateDeviceExtensionProperties),
Chia-I Wueb7db122016-03-24 09:11:06 +0800201 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800202 },
203 {
204 "vkEnumerateInstanceExtensionProperties",
205 ProcHook::GLOBAL,
206 ProcHook::EXTENSION_CORE,
207 reinterpret_cast<PFN_vkVoidFunction>(EnumerateInstanceExtensionProperties),
208 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800209 },
210 {
211 "vkEnumeratePhysicalDevices",
212 ProcHook::INSTANCE,
213 ProcHook::EXTENSION_CORE,
Chia-I Wuff4a6c72016-03-24 16:05:56 +0800214 reinterpret_cast<PFN_vkVoidFunction>(EnumeratePhysicalDevices),
Chia-I Wueb7db122016-03-24 09:11:06 +0800215 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800216 },
217 {
218 "vkGetDeviceProcAddr",
219 ProcHook::DEVICE,
220 ProcHook::EXTENSION_CORE,
221 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceProcAddr),
222 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800223 },
224 {
225 "vkGetDeviceQueue",
226 ProcHook::DEVICE,
227 ProcHook::EXTENSION_CORE,
Chia-I Wuba0be412016-03-24 16:24:40 +0800228 reinterpret_cast<PFN_vkVoidFunction>(GetDeviceQueue),
Chia-I Wueb7db122016-03-24 09:11:06 +0800229 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800230 },
231 {
232 "vkGetInstanceProcAddr",
233 ProcHook::INSTANCE,
234 ProcHook::EXTENSION_CORE,
235 reinterpret_cast<PFN_vkVoidFunction>(GetInstanceProcAddr),
236 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800237 },
238 {
Ian Elliott4c8bb2a2016-12-29 11:07:26 -0700239 "vkGetPastPresentationTimingGOOGLE",
240 ProcHook::DEVICE,
241 ProcHook::GOOGLE_display_timing,
242 reinterpret_cast<PFN_vkVoidFunction>(GetPastPresentationTimingGOOGLE),
243 reinterpret_cast<PFN_vkVoidFunction>(checkedGetPastPresentationTimingGOOGLE),
244 },
245 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800246 "vkGetPhysicalDeviceSurfaceCapabilitiesKHR",
247 ProcHook::INSTANCE,
248 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800249 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceCapabilitiesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800250 nullptr,
251 },
252 {
253 "vkGetPhysicalDeviceSurfaceFormatsKHR",
254 ProcHook::INSTANCE,
255 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800256 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceFormatsKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800257 nullptr,
258 },
259 {
260 "vkGetPhysicalDeviceSurfacePresentModesKHR",
261 ProcHook::INSTANCE,
262 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800263 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfacePresentModesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800264 nullptr,
265 },
266 {
267 "vkGetPhysicalDeviceSurfaceSupportKHR",
268 ProcHook::INSTANCE,
269 ProcHook::KHR_surface,
Chia-I Wu62262232016-03-26 07:06:44 +0800270 reinterpret_cast<PFN_vkVoidFunction>(GetPhysicalDeviceSurfaceSupportKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800271 nullptr,
272 },
273 {
Ian Elliott4c8bb2a2016-12-29 11:07:26 -0700274 "vkGetRefreshCycleDurationGOOGLE",
275 ProcHook::DEVICE,
276 ProcHook::GOOGLE_display_timing,
277 reinterpret_cast<PFN_vkVoidFunction>(GetRefreshCycleDurationGOOGLE),
278 reinterpret_cast<PFN_vkVoidFunction>(checkedGetRefreshCycleDurationGOOGLE),
279 },
280 {
Chris Forbes8e4438b2016-12-07 16:26:49 +1300281 "vkGetSwapchainGrallocUsage2ANDROID",
282 ProcHook::DEVICE,
283 ProcHook::ANDROID_native_buffer,
284 nullptr,
285 nullptr,
286 },
287 {
Chia-I Wueb7db122016-03-24 09:11:06 +0800288 "vkGetSwapchainGrallocUsageANDROID",
289 ProcHook::DEVICE,
290 ProcHook::ANDROID_native_buffer,
291 nullptr,
292 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800293 },
294 {
295 "vkGetSwapchainImagesKHR",
296 ProcHook::DEVICE,
297 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800298 reinterpret_cast<PFN_vkVoidFunction>(GetSwapchainImagesKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800299 reinterpret_cast<PFN_vkVoidFunction>(checkedGetSwapchainImagesKHR),
300 },
301 {
302 "vkQueuePresentKHR",
303 ProcHook::DEVICE,
304 ProcHook::KHR_swapchain,
Chia-I Wu62262232016-03-26 07:06:44 +0800305 reinterpret_cast<PFN_vkVoidFunction>(QueuePresentKHR),
Chia-I Wueb7db122016-03-24 09:11:06 +0800306 reinterpret_cast<PFN_vkVoidFunction>(checkedQueuePresentKHR),
307 },
308 {
309 "vkQueueSignalReleaseImageANDROID",
310 ProcHook::DEVICE,
311 ProcHook::ANDROID_native_buffer,
312 nullptr,
313 nullptr,
Chia-I Wueb7db122016-03-24 09:11:06 +0800314 },
315 // clang-format on
316};
317
318} // anonymous
319
320const ProcHook* GetProcHook(const char* name) {
321 const auto& begin = g_proc_hooks;
322 const auto& end =
323 g_proc_hooks + sizeof(g_proc_hooks) / sizeof(g_proc_hooks[0]);
324 const auto hook = std::lower_bound(
325 begin, end, name,
326 [](const ProcHook& e, const char* n) { return strcmp(e.name, n) < 0; });
327 return (hook < end && strcmp(hook->name, name) == 0) ? hook : nullptr;
328}
329
330ProcHook::Extension GetProcHookExtension(const char* name) {
331 // clang-format off
332 if (strcmp(name, "VK_ANDROID_native_buffer") == 0) return ProcHook::ANDROID_native_buffer;
333 if (strcmp(name, "VK_EXT_debug_report") == 0) return ProcHook::EXT_debug_report;
334 if (strcmp(name, "VK_KHR_android_surface") == 0) return ProcHook::KHR_android_surface;
335 if (strcmp(name, "VK_KHR_surface") == 0) return ProcHook::KHR_surface;
336 if (strcmp(name, "VK_KHR_swapchain") == 0) return ProcHook::KHR_swapchain;
Ian Elliott4c8bb2a2016-12-29 11:07:26 -0700337 if (strcmp(name, "VK_GOOGLE_display_timing") == 0) return ProcHook::GOOGLE_display_timing;
Chia-I Wueb7db122016-03-24 09:11:06 +0800338 // clang-format on
339 return ProcHook::EXTENSION_UNKNOWN;
340}
341
Chia-I Wucc5e2762016-03-24 13:01:16 +0800342#define UNLIKELY(expr) __builtin_expect((expr), 0)
343
Chris Forbes5948b3e2016-12-23 13:49:53 +1300344#define INIT_PROC(required, obj, proc) \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800345 do { \
346 data.driver.proc = \
347 reinterpret_cast<PFN_vk##proc>(get_proc(obj, "vk" #proc)); \
Chris Forbes5948b3e2016-12-23 13:49:53 +1300348 if (UNLIKELY(required && !data.driver.proc)) { \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800349 ALOGE("missing " #obj " proc: vk" #proc); \
350 success = false; \
351 } \
352 } while (0)
353
Chris Forbes5948b3e2016-12-23 13:49:53 +1300354#define INIT_PROC_EXT(ext, required, obj, proc) \
355 do { \
356 if (extensions[ProcHook::ext]) \
357 INIT_PROC(required, obj, proc); \
Chia-I Wucc5e2762016-03-24 13:01:16 +0800358 } while (0)
359
Chia-I Wucbe07ef2016-04-13 15:01:00 +0800360bool InitDriverTable(VkInstance instance,
361 PFN_vkGetInstanceProcAddr get_proc,
362 const std::bitset<ProcHook::EXTENSION_COUNT>& extensions) {
Chia-I Wucc5e2762016-03-24 13:01:16 +0800363 auto& data = GetData(instance);
364 bool success = true;
365
366 // clang-format off
Chris Forbes5948b3e2016-12-23 13:49:53 +1300367 INIT_PROC(true, instance, DestroyInstance);
368 INIT_PROC(true, instance, EnumeratePhysicalDevices);
369 INIT_PROC(true, instance, GetInstanceProcAddr);
370 INIT_PROC(true, instance, CreateDevice);
371 INIT_PROC(true, instance, EnumerateDeviceExtensionProperties);
372 INIT_PROC_EXT(EXT_debug_report, true, instance, CreateDebugReportCallbackEXT);
373 INIT_PROC_EXT(EXT_debug_report, true, instance, DestroyDebugReportCallbackEXT);
374 INIT_PROC_EXT(EXT_debug_report, true, instance, DebugReportMessageEXT);
Chia-I Wucc5e2762016-03-24 13:01:16 +0800375 // clang-format on
376
377 return success;
378}
379
Chia-I Wucbe07ef2016-04-13 15:01:00 +0800380bool InitDriverTable(VkDevice dev,
381 PFN_vkGetDeviceProcAddr get_proc,
382 const std::bitset<ProcHook::EXTENSION_COUNT>& extensions) {
Chia-I Wucc5e2762016-03-24 13:01:16 +0800383 auto& data = GetData(dev);
384 bool success = true;
385
386 // clang-format off
Chris Forbes5948b3e2016-12-23 13:49:53 +1300387 INIT_PROC(true, dev, GetDeviceProcAddr);
388 INIT_PROC(true, dev, DestroyDevice);
389 INIT_PROC(true, dev, GetDeviceQueue);
390 INIT_PROC(true, dev, CreateImage);
391 INIT_PROC(true, dev, DestroyImage);
392 INIT_PROC(true, dev, AllocateCommandBuffers);
393 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, GetSwapchainGrallocUsageANDROID);
394 INIT_PROC_EXT(ANDROID_native_buffer, false, dev, GetSwapchainGrallocUsage2ANDROID);
395 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, AcquireImageANDROID);
396 INIT_PROC_EXT(ANDROID_native_buffer, true, dev, QueueSignalReleaseImageANDROID);
Chia-I Wucc5e2762016-03-24 13:01:16 +0800397 // clang-format on
398
399 return success;
400}
401
Chia-I Wueb7db122016-03-24 09:11:06 +0800402} // namespace driver
403} // namespace vulkan
404
405// clang-format on