Coverage Report

Created: 2022-01-22 13:19

/Users/buildslave/jenkins/workspace/coverage/llvm-project/clang/include/clang/Basic/Cuda.h
Line
Count
Source (jump to first uncovered line)
1
//===--- Cuda.h - Utilities for compiling CUDA code  ------------*- C++ -*-===//
2
//
3
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4
// See https://llvm.org/LICENSE.txt for license information.
5
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6
//
7
//===----------------------------------------------------------------------===//
8
9
#ifndef LLVM_CLANG_BASIC_CUDA_H
10
#define LLVM_CLANG_BASIC_CUDA_H
11
12
namespace llvm {
13
class StringRef;
14
class Twine;
15
class VersionTuple;
16
} // namespace llvm
17
18
namespace clang {
19
20
enum class CudaVersion {
21
  UNKNOWN,
22
  CUDA_70,
23
  CUDA_75,
24
  CUDA_80,
25
  CUDA_90,
26
  CUDA_91,
27
  CUDA_92,
28
  CUDA_100,
29
  CUDA_101,
30
  CUDA_102,
31
  CUDA_110,
32
  CUDA_111,
33
  CUDA_112,
34
  CUDA_113,
35
  CUDA_114,
36
  CUDA_115,
37
  FULLY_SUPPORTED = CUDA_115,
38
  PARTIALLY_SUPPORTED =
39
      CUDA_115, // Partially supported. Proceed with a warning.
40
  NEW = 10000,  // Too new. Issue a warning, but allow using it.
41
};
42
const char *CudaVersionToString(CudaVersion V);
43
// Input is "Major.Minor"
44
CudaVersion CudaStringToVersion(const llvm::Twine &S);
45
46
enum class CudaArch {
47
  UNUSED,
48
  UNKNOWN,
49
  SM_20,
50
  SM_21,
51
  SM_30,
52
  SM_32,
53
  SM_35,
54
  SM_37,
55
  SM_50,
56
  SM_52,
57
  SM_53,
58
  SM_60,
59
  SM_61,
60
  SM_62,
61
  SM_70,
62
  SM_72,
63
  SM_75,
64
  SM_80,
65
  SM_86,
66
  GFX600,
67
  GFX601,
68
  GFX602,
69
  GFX700,
70
  GFX701,
71
  GFX702,
72
  GFX703,
73
  GFX704,
74
  GFX705,
75
  GFX801,
76
  GFX802,
77
  GFX803,
78
  GFX805,
79
  GFX810,
80
  GFX900,
81
  GFX902,
82
  GFX904,
83
  GFX906,
84
  GFX908,
85
  GFX909,
86
  GFX90a,
87
  GFX90c,
88
  GFX1010,
89
  GFX1011,
90
  GFX1012,
91
  GFX1013,
92
  GFX1030,
93
  GFX1031,
94
  GFX1032,
95
  GFX1033,
96
  GFX1034,
97
  GFX1035,
98
  Generic, // A processor model named 'generic' if the target backend defines a
99
           // public one.
100
  LAST,
101
};
102
103
27
static inline bool IsNVIDIAGpuArch(CudaArch A) {
104
27
  return A >= CudaArch::SM_20 && A < CudaArch::GFX600;
105
27
}
Unexecuted instantiation: Cuda.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Targets.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: NVPTX.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Driver.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Line
Count
Source
103
27
static inline bool IsNVIDIAGpuArch(CudaArch A) {
104
27
  return A >= CudaArch::SM_20 && A < CudaArch::GFX600;
105
27
}
Unexecuted instantiation: ToolChain.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Ananas.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: AMDGPU.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: AMDGPUOpenMP.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: AVR.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: BareMetal.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Clang.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: CloudABI.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: CommonArgs.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Contiki.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: CrossWindows.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Darwin.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: DragonFly.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: FreeBSD.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Fuchsia.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Gnu.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Haiku.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: HIPAMD.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Hexagon.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Hurd.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Linux.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: MipsLinux.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: MinGW.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Minix.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: MSP430.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: MSVC.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Myriad.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: NaCl.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: NetBSD.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: OpenBSD.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: PS4CPU.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: RISCVToolchain.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: Solaris.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: VEToolchain.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: WebAssembly.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: PPCLinux.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: PPCFreeBSD.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: SemaCUDA.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: CGCUDANV.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: CGOpenMPRuntimeGPU.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
Unexecuted instantiation: ClangOffloadBundler.cpp:clang::IsNVIDIAGpuArch(clang::CudaArch)
106
107
6
static inline bool IsAMDGpuArch(CudaArch A) {
108
  // Generic processor model is for testing only.
109
6
  return A >= CudaArch::GFX600 && 
A < CudaArch::Generic0
;
110
6
}
Cuda.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Line
Count
Source
107
6
static inline bool IsAMDGpuArch(CudaArch A) {
108
  // Generic processor model is for testing only.
109
6
  return A >= CudaArch::GFX600 && 
A < CudaArch::Generic0
;
110
6
}
Unexecuted instantiation: Targets.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: NVPTX.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Driver.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: ToolChain.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Ananas.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: AMDGPU.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: AMDGPUOpenMP.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: AVR.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: BareMetal.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Clang.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: CloudABI.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: CommonArgs.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Contiki.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: CrossWindows.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Darwin.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: DragonFly.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: FreeBSD.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Fuchsia.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Gnu.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Haiku.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: HIPAMD.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Hexagon.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Hurd.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Linux.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: MipsLinux.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: MinGW.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Minix.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: MSP430.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: MSVC.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Myriad.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: NaCl.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: NetBSD.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: OpenBSD.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: PS4CPU.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: RISCVToolchain.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: Solaris.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: VEToolchain.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: WebAssembly.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: PPCLinux.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: PPCFreeBSD.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: SemaCUDA.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: CGCUDANV.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: CGOpenMPRuntimeGPU.cpp:clang::IsAMDGpuArch(clang::CudaArch)
Unexecuted instantiation: ClangOffloadBundler.cpp:clang::IsAMDGpuArch(clang::CudaArch)
111
112
const char *CudaArchToString(CudaArch A);
113
const char *CudaArchToVirtualArchString(CudaArch A);
114
115
// The input should have the form "sm_20".
116
CudaArch StringToCudaArch(llvm::StringRef S);
117
118
/// Get the earliest CudaVersion that supports the given CudaArch.
119
CudaVersion MinVersionForCudaArch(CudaArch A);
120
121
/// Get the latest CudaVersion that supports the given CudaArch.
122
CudaVersion MaxVersionForCudaArch(CudaArch A);
123
124
//  Various SDK-dependent features that affect CUDA compilation
125
enum class CudaFeature {
126
  // CUDA-9.2+ uses a new API for launching kernels.
127
  CUDA_USES_NEW_LAUNCH,
128
  // CUDA-10.1+ needs explicit end of GPU binary registration.
129
  CUDA_USES_FATBIN_REGISTER_END,
130
};
131
132
CudaVersion ToCudaVersion(llvm::VersionTuple);
133
bool CudaFeatureEnabled(llvm::VersionTuple, CudaFeature);
134
bool CudaFeatureEnabled(CudaVersion, CudaFeature);
135
136
} // namespace clang
137
138
#endif