Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
third-party
glfw
deps
vulkan
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
uint16_t
unsigned short uint16_t
Definition:
stdint.h:79
uint8_t
unsigned char uint8_t
Definition:
stdint.h:78
uint32_t
unsigned int uint32_t
Definition:
stdint.h:80
int16_t
signed short int16_t
Definition:
stdint.h:76
uint64_t
unsigned __int64 uint64_t
Definition:
stdint.h:90
int8_t
signed char int8_t
Definition:
stdint.h:75
stdint.h
int64_t
signed __int64 int64_t
Definition:
stdint.h:89
int32_t
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