annotate clang/lib/Headers/__clang_hip_runtime_wrapper.h @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents
children 5f17cb93ff66
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 /*===---- __clang_hip_runtime_wrapper.h - HIP runtime support ---------------===
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 *
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 * See https://llvm.org/LICENSE.txt for license information.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 *
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 *===-----------------------------------------------------------------------===
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 */
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 /*
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 * WARNING: This header is intended to be directly -include'd by
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 * the compiler and is not supposed to be included by users.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 *
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 */
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 #ifndef __CLANG_HIP_RUNTIME_WRAPPER_H__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 #define __CLANG_HIP_RUNTIME_WRAPPER_H__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
18
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 #if __HIP__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 #if !defined(__HIPCC_RTC__)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 #include <cmath>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 #include <cstdlib>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 #include <stdlib.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 #else
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 typedef __SIZE_TYPE__ size_t;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 // Define macros which are needed to declare HIP device API's without standard
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 // C/C++ headers. This is for readability so that these API's can be written
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 // the same way as non-hipRTC use case. These macros need to be popped so that
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 // they do not pollute users' name space.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 #pragma push_macro("NULL")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 #pragma push_macro("uint32_t")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 #pragma push_macro("uint64_t")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 #pragma push_macro("CHAR_BIT")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 #pragma push_macro("INT_MAX")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 #define NULL (void *)0
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 #define uint32_t __UINT32_TYPE__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 #define uint64_t __UINT64_TYPE__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 #define CHAR_BIT __CHAR_BIT__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 #define INT_MAX __INTMAX_MAX__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 #endif // __HIPCC_RTC__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 #define __host__ __attribute__((host))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 #define __device__ __attribute__((device))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 #define __global__ __attribute__((global))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 #define __shared__ __attribute__((shared))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 #define __constant__ __attribute__((constant))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 #define __managed__ __attribute__((managed))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 #if !defined(__cplusplus) || __cplusplus < 201103L
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 #define nullptr NULL;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 #endif
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 #if __HIP_ENABLE_DEVICE_MALLOC__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 extern "C" __device__ void *__hip_malloc(size_t __size);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 extern "C" __device__ void *__hip_free(void *__ptr);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 static inline __device__ void *malloc(size_t __size) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 return __hip_malloc(__size);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 static inline __device__ void *free(void *__ptr) { return __hip_free(__ptr); }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 #else
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 static inline __device__ void *malloc(size_t __size) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 __builtin_trap();
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 return nullptr;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 static inline __device__ void *free(void *__ptr) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 __builtin_trap();
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 return nullptr;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 #endif
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 #include <__clang_hip_libdevice_declares.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 #include <__clang_hip_math.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 #if !_OPENMP || __HIP_ENABLE_CUDA_WRAPPER_FOR_OPENMP__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 #if defined(__HIPCC_RTC__)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 #include <__clang_hip_cmath.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 #else
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 #include <__clang_cuda_math_forward_declares.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 #include <__clang_hip_cmath.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
81 #include <__clang_cuda_complex_builtins.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 #include <algorithm>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 #include <complex>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84 #include <new>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 #endif // __HIPCC_RTC__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 #endif // !_OPENMP || __HIP_ENABLE_CUDA_WRAPPER_FOR_OPENMP__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
87
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 #define __CLANG_HIP_RUNTIME_WRAPPER_INCLUDED__ 1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 #if defined(__HIPCC_RTC__)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
90 #pragma pop_macro("NULL")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
91 #pragma pop_macro("uint32_t")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 #pragma pop_macro("uint64_t")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
93 #pragma pop_macro("CHAR_BIT")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
94 #pragma pop_macro("INT_MAX")
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
95 #endif // __HIPCC_RTC__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
96 #endif // __HIP__
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
97 #endif // __CLANG_HIP_RUNTIME_WRAPPER_H__