From 7ed59dd114b121939d5aaca2947a102ed2174df8 Mon Sep 17 00:00:00 2001 From: Chris Forbes Date: Tue, 4 Oct 2016 10:08:31 +1300 Subject: layers: Be careful about casts. ptr -> uint64_t& isnt right on 32bit. Signed-off-by: Chris Forbes --- layers/object_tracker.cpp | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) (limited to 'layers/object_tracker.cpp') diff --git a/layers/object_tracker.cpp b/layers/object_tracker.cpp index 13e1502b..0a8f7a70 100644 --- a/layers/object_tracker.cpp +++ b/layers/object_tracker.cpp @@ -33,6 +33,7 @@ #include #include +#include #include "vk_layer_config.h" #include "vk_layer_data.h" @@ -245,7 +246,10 @@ static void CreateSwapchainImageObject(VkDevice dispatchable_object, VkImage swa template static void CreateObject(T1 dispatchable_object, T2 object, VkDebugReportObjectTypeEXT object_type, bool custom_allocator) { layer_data *instance_data = get_my_data_ptr(get_dispatch_key(dispatchable_object), layer_data_map); - auto object_handle = reinterpret_cast(object); + + auto object_handle = std::is_pointer::value + ? reinterpret_cast(object) + : reinterpret_cast(object); log_msg(instance_data->report_data, VK_DEBUG_REPORT_INFORMATION_BIT_EXT, object_type, object_handle, __LINE__, OBJTRACK_NONE, LayerName, "OBJ[0x%" PRIxLEAST64 "] : CREATE %s object 0x%" PRIxLEAST64, object_track_index++, @@ -264,7 +268,9 @@ template static void DestroyObject(T1 dispatchable_object, T2 object, VkDebugReportObjectTypeEXT object_type, bool custom_allocator) { layer_data *device_data = get_my_data_ptr(get_dispatch_key(dispatchable_object), layer_data_map); - uint64_t object_handle = reinterpret_cast(object); + auto object_handle = std::is_pointer::value + ? reinterpret_cast(object) + : reinterpret_cast(object); auto item = device_data->object_map[object_type].find(object_handle); if (item != device_data->object_map[object_type].end()) { @@ -305,7 +311,9 @@ static bool ValidateObject(T1 dispatchable_object, T2 object, VkDebugReportObjec if (null_allowed && (object == VK_NULL_HANDLE)) { return false; } - auto object_handle = reinterpret_cast(object); + auto object_handle = std::is_pointer::value + ? reinterpret_cast(object) + : reinterpret_cast(object); layer_data *device_data = get_my_data_ptr(get_dispatch_key(dispatchable_object), layer_data_map); if (device_data->object_map[object_type].find(object_handle) == device_data->object_map[object_type].end()) { // If object is an image, also look for it in the swapchain image map -- cgit v1.2.3