vk_platform.h
Go to the documentation of this file.
1 //
2 // File: vk_platform.h
3 //
4 /*
5 ** Copyright (c) 2014-2017 The Khronos Group Inc.
6 **
7 ** Licensed under the Apache License, Version 2.0 (the "License");
8 ** you may not use this file except in compliance with the License.
9 ** You may obtain a copy of the License at
10 **
11 ** http://www.apache.org/licenses/LICENSE-2.0
12 **
13 ** Unless required by applicable law or agreed to in writing, software
14 ** distributed under the License is distributed on an "AS IS" BASIS,
15 ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 ** See the License for the specific language governing permissions and
17 ** limitations under the License.
18 */
19 
20 
21 #ifndef VK_PLATFORM_H_
22 #define VK_PLATFORM_H_
23 
24 #ifdef __cplusplus
25 extern "C"
26 {
27 #endif // __cplusplus
28 
29 /*
30 ***************************************************************************************************
31 * Platform-specific directives and type declarations
32 ***************************************************************************************************
33 */
34 
35 /* Platform-specific calling convention macros.
36  *
37  * Platforms should define these so that Vulkan clients call Vulkan commands
38  * with the same calling conventions that the Vulkan implementation expects.
39  *
40  * VKAPI_ATTR - Placed before the return type in function declarations.
41  * Useful for C++11 and GCC/Clang-style function attribute syntax.
42  * VKAPI_CALL - Placed after the return type in function declarations.
43  * Useful for MSVC-style calling convention syntax.
44  * VKAPI_PTR - Placed between the '(' and '*' in function pointer types.
45  *
46  * Function declaration: VKAPI_ATTR void VKAPI_CALL vkCommand(void);
47  * Function pointer type: typedef void (VKAPI_PTR *PFN_vkCommand)(void);
48  */
49 #if defined(_WIN32)
50  // On Windows, Vulkan commands use the stdcall convention
51  #define VKAPI_ATTR
52  #define VKAPI_CALL __stdcall
53  #define VKAPI_PTR VKAPI_CALL
54 #elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH < 7
55  #error "Vulkan isn't supported for the 'armeabi' NDK ABI"
56 #elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH >= 7 && defined(__ARM_32BIT_STATE)
57  // On Android 32-bit ARM targets, Vulkan functions use the "hardfloat"
58  // calling convention, i.e. float parameters are passed in registers. This
59  // is true even if the rest of the application passes floats on the stack,
60  // as it does by default when compiling for the armeabi-v7a NDK ABI.
61  #define VKAPI_ATTR __attribute__((pcs("aapcs-vfp")))
62  #define VKAPI_CALL
63  #define VKAPI_PTR VKAPI_ATTR
64 #else
65  // On other platforms, use the default calling convention
66  #define VKAPI_ATTR
67  #define VKAPI_CALL
68  #define VKAPI_PTR
69 #endif
70 
71 #include <stddef.h>
72 
73 #if !defined(VK_NO_STDINT_H)
74  #if defined(_MSC_VER) && (_MSC_VER < 1600)
75  typedef signed __int8 int8_t;
76  typedef unsigned __int8 uint8_t;
77  typedef signed __int16 int16_t;
78  typedef unsigned __int16 uint16_t;
79  typedef signed __int32 int32_t;
80  typedef unsigned __int32 uint32_t;
81  typedef signed __int64 int64_t;
82  typedef unsigned __int64 uint64_t;
83  #else
84  #include <stdint.h>
85  #endif
86 #endif // !defined(VK_NO_STDINT_H)
87 
88 #ifdef __cplusplus
89 } // extern "C"
90 #endif // __cplusplus
91 
92 #endif
unsigned short uint16_t
Definition: stdint.h:79
unsigned char uint8_t
Definition: stdint.h:78
unsigned int uint32_t
Definition: stdint.h:80
signed short int16_t
Definition: stdint.h:76
unsigned __int64 uint64_t
Definition: stdint.h:90
signed char int8_t
Definition: stdint.h:75
signed __int64 int64_t
Definition: stdint.h:89
signed int int32_t
Definition: stdint.h:77


librealsense2
Author(s): Sergey Dorodnicov , Doron Hirshberg , Mark Horn , Reagan Lopez , Itay Carpis
autogenerated on Mon May 3 2021 02:50:14