From 9508521d8aa9983d5127b90fbcc2fa6006a28f70 Mon Sep 17 00:00:00 2001 From: Jon Ashburn Date: Tue, 5 May 2015 14:22:52 -0600 Subject: layers: Add GetInstanceProcAddr() to all layers Loader will use this for constructing instance layer instance chains. Layer instance dispatch table is not yet added. --- layers/shader_checker.cpp | 31 ++++++++++++++++++++++++++++--- 1 file changed, 28 insertions(+), 3 deletions(-) (limited to 'layers/shader_checker.cpp') diff --git a/layers/shader_checker.cpp b/layers/shader_checker.cpp index a576314a..f36fee39 100644 --- a/layers/shader_checker.cpp +++ b/layers/shader_checker.cpp @@ -159,8 +159,7 @@ static VkLayerDispatchTable * initLayerTable(const VkBaseLayerObject *gpuw) return it->second; } - layer_initialize_dispatch_table(pTable, gpuw->pGPA, (VkPhysicalDevice) gpuw->nextObject); - pCurObj = (VkBaseLayerObject *)gpuw->baseObject; + layer_initialize_dispatch_table(pTable, (PFN_vkGetProcAddr) gpuw->pGPA, (VkPhysicalDevice) gpuw->nextObject); return pTable; } @@ -1011,6 +1010,7 @@ VK_LAYER_EXPORT void * VKAPI vkGetProcAddr(VkPhysicalDevice gpu, const char* pNa ADD_HOOK(vkGetProcAddr); ADD_HOOK(vkEnumerateLayers); + ADD_HOOK(vkGetGlobalExtensionInfo); ADD_HOOK(vkCreateDevice); ADD_HOOK(vkCreateShader); ADD_HOOK(vkCreateGraphicsPipeline); @@ -1021,5 +1021,30 @@ VK_LAYER_EXPORT void * VKAPI vkGetProcAddr(VkPhysicalDevice gpu, const char* pNa VkBaseLayerObject* gpuw = (VkBaseLayerObject *) gpu; if (gpuw->pGPA == NULL) return NULL; - return gpuw->pGPA((VkPhysicalDevice) gpuw->nextObject, pName); + return gpuw->pGPA((VkObject) gpuw->nextObject, pName); +} + +VK_LAYER_EXPORT void * VKAPI vkGetInstanceProcAddr(VkInstance inst, const char* pName) +{ + if (inst == NULL) + return NULL; + + //TODO initLayerTable((const VkBaseLayerObject *) inst); + + // TODO loader_platform_thread_once(&g_initOnce, initInstanceLayer); + +#define ADD_HOOK(fn) \ + if (!strncmp(#fn, pName, sizeof(#fn))) \ + return (void *) fn + + ADD_HOOK(vkGetProcAddr); + ADD_HOOK(vkGetInstanceProcAddr); + ADD_HOOK(vkEnumerateLayers); + ADD_HOOK(vkGetGlobalExtensionInfo); + ADD_HOOK(vkCreateDevice); + + VkBaseLayerObject* instw = (VkBaseLayerObject *) inst; + if (instw->pGPA == NULL) + return NULL; + return instw->pGPA((VkObject) instw->nextObject, pName); } -- cgit v1.2.3