/* Copyright (c) 2015-2016 The Khronos Group Inc.
* Copyright (c) 2015-2016 Valve Corporation
* Copyright (c) 2015-2016 LunarG, Inc.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and/or associated documentation files (the "Materials"), to
* deal in the Materials without restriction, including without limitation the
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Materials, and to permit persons to whom the Materials
* are furnished to do so, subject to the following conditions:
*
* The above copyright notice(s) and this permission notice shall be included
* in all copies or substantial portions of the Materials.
*
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
*
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
* OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE MATERIALS OR THE
* USE OR OTHER DEALINGS IN THE MATERIALS
*
* Author: Mark Lobodzinski <mark@lunarg.com>
* Author: Courtney Goeltzenleuchter <courtney@LunarG.com>
*/
#pragma once
#include <stdbool.h>
#include <vector>
#include "vk_layer_logging.h"
#ifndef WIN32
#include <strings.h> /* for ffs() */
#else
#include <intrin.h> /* for __lzcnt() */
#endif
#ifdef __cplusplus
extern "C" {
#endif
#define VK_LAYER_API_VERSION (VK_VERSION_MAJOR(1) | VK_VERSION_MINOR(0) | VK_VERSION_PATCH(VK_HEADER_VERSION))
typedef enum VkFormatCompatibilityClass {
VK_FORMAT_COMPATIBILITY_CLASS_NONE_BIT = 0,
VK_FORMAT_COMPATIBILITY_CLASS_8_BIT = 1,
VK_FORMAT_COMPATIBILITY_CLASS_16_BIT = 2,
VK_FORMAT_COMPATIBILITY_CLASS_24_BIT = 3,
VK_FORMAT_COMPATIBILITY_CLASS_32_BIT = 4,
VK_FORMAT_COMPATIBILITY_CLASS_48_BIT = 5,
VK_FORMAT_COMPATIBILITY_CLASS_64_BIT = 6,
VK_FORMAT_COMPATIBILITY_CLASS_96_BIT = 7,
VK_FORMAT_COMPATIBILITY_CLASS_128_BIT = 8,
VK_FORMAT_COMPATIBILITY_CLASS_192_BIT = 9,
VK_FORMAT_COMPATIBILITY_CLASS_256_BIT = 10,
VK_FORMAT_COMPATIBILITY_CLASS_BC1_RGB_BIT = 11,
VK_FORMAT_COMPATIBILITY_CLASS_BC1_RGBA_BIT = 12,
VK_FORMAT_COMPATIBILITY_CLASS_BC2_BIT = 13,
VK_FORMAT_COMPATIBILITY_CLASS_BC3_BIT = 14,
VK_FORMAT_COMPATIBILITY_CLASS_BC4_BIT = 15,
VK_FORMAT_COMPATIBILITY_CLASS_BC5_BIT = 16,
VK_FORMAT_COMPATIBILITY_CLASS_BC6H_BIT = 17,
VK_FORMAT_COMPATIBILITY_CLASS_BC7_BIT = 18,
VK_FORMAT_COMPATIBILITY_CLASS_ETC2_RGB_BIT = 19,
VK_FORMAT_COMPATIBILITY_CLASS_ETC2_RGBA_BIT = 20,
VK_FORMAT_COMPATIBILITY_CLASS_ETC2_EAC_RGBA_BIT = 21,
VK_FORMAT_COMPATIBILITY_CLASS_EAC_R_BIT = 22,
VK_FORMAT_COMPATIBILITY_CLASS_EAC_RG_BIT = 23,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_4X4_BIT = 24,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_5X4_BIT = 25,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_5X5_BIT = 26,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_6X5_BIT = 27,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_6X6_BIT = 28,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_8X5_BIT = 29,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_8X6_BIT = 20,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_8X8_BIT = 31,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_10X5_BIT = 32,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_10X6_BIT = 33,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_10X8_BIT = 34,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_10X10_BIT = 35,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_12X10_BIT = 36,
VK_FORMAT_COMPATIBILITY_CLASS_ASTC_12X12_BIT = 37,
VK_FORMAT_COMPATIBILITY_CLASS_D16_BIT = 38,
VK_FORMAT_COMPATIBILITY_CLASS_D24_BIT = 39,
VK_FORMAT_COMPATIBILITY_CLASS_D32_BIT = 30,
VK_FORMAT_COMPATIBILITY_CLASS_S8_BIT = 41,
VK_FORMAT_COMPATIBILITY_CLASS_D16S8_BIT = 42,
VK_FORMAT_COMPATIBILITY_CLASS_D24S8_BIT = 43,
VK_FORMAT_COMPATIBILITY_CLASS_D32S8_BIT = 44,
VK_FORMAT_COMPATIBILITY_CLASS_MAX_ENUM = 45
} VkFormatCompatibilityClass;
typedef enum VkStringErrorFlagBits {
VK_STRING_ERROR_NONE = 0x00000000,
VK_STRING_ERROR_LENGTH = 0x00000001,
VK_STRING_ERROR_BAD_DATA = 0x00000002,
} VkStringErrorFlagBits;
typedef VkFlags VkStringErrorFlags;
void layer_debug_actions(debug_report_data* report_data, std::vector<VkDebugReportCallbackEXT> &logging_callback,
const VkAllocationCallbacks *pAllocator, const char* layer_identifier);
static inline bool vk_format_is_undef(VkFormat format) { return (format == VK_FORMAT_UNDEFINED); }
bool vk_format_is_depth_or_stencil(VkFormat format);
bool vk_format_is_depth_and_stencil(VkFormat format);
bool vk_format_is_depth_only(VkFormat format);
bool vk_format_is_stencil_only(VkFormat format);
static inline bool vk_format_is_color(VkFormat format) {
return !(vk_format_is_undef(format) || vk_format_is_depth_or_stencil(format));
}
bool vk_format_is_norm(VkFormat format);
bool vk_format_is_int(VkFormat format);
bool vk_format_is_sint(VkFormat format);
bool vk_format_is_uint(VkFormat format);
bool vk_format_is_float(VkFormat format);
bool vk_format_is_srgb(VkFormat format);
bool vk_format_is_compressed(VkFormat format);
size_t vk_format_get_size(VkFormat format);
unsigned int vk_format_get_channel_count(VkFormat format);
VkFormatCompatibilityClass vk_format_get_compatibility_class(VkFormat format);
VkDeviceSize vk_safe_modulo(VkDeviceSize dividend, VkDeviceSize divisor);
VkStringErrorFlags vk_string_validate(const int max_length, const char *char_array);
static inline int u_ffs(int val) {
#ifdef WIN32
unsigned long bit_pos = 0;
if (_BitScanForward(&bit_pos, val) != 0) {
bit_pos += 1;
}
return bit_pos;
#else
return ffs(val);
#endif
}
#ifdef __cplusplus
}
#endif