- //===--- Cuda.h - Utilities for compiling CUDA code  ------------*- C++ -*-===// 
- // 
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 
- // See https://llvm.org/LICENSE.txt for license information. 
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 
- // 
- //===----------------------------------------------------------------------===// 
-   
- #ifndef LLVM_CLANG_BASIC_CUDA_H 
- #define LLVM_CLANG_BASIC_CUDA_H 
-   
- namespace llvm { 
- class StringRef; 
- class Twine; 
- class VersionTuple; 
- } // namespace llvm 
-   
- namespace clang { 
-   
- enum class CudaVersion { 
-   UNKNOWN, 
-   CUDA_70, 
-   CUDA_75, 
-   CUDA_80, 
-   CUDA_90, 
-   CUDA_91, 
-   CUDA_92, 
-   CUDA_100, 
-   CUDA_101, 
-   CUDA_102, 
-   CUDA_110, 
-   CUDA_111, 
-   CUDA_112, 
-   CUDA_113, 
-   CUDA_114, 
-   CUDA_115, 
-   CUDA_116, 
-   CUDA_117, 
-   CUDA_118, 
-   FULLY_SUPPORTED = CUDA_115, 
-   PARTIALLY_SUPPORTED = 
-       CUDA_118, // Partially supported. Proceed with a warning. 
-   NEW = 10000,  // Too new. Issue a warning, but allow using it. 
- }; 
- const char *CudaVersionToString(CudaVersion V); 
- // Input is "Major.Minor" 
- CudaVersion CudaStringToVersion(const llvm::Twine &S); 
-   
- enum class CudaArch { 
-   UNUSED, 
-   UNKNOWN, 
-   SM_20, 
-   SM_21, 
-   SM_30, 
-   SM_32, 
-   SM_35, 
-   SM_37, 
-   SM_50, 
-   SM_52, 
-   SM_53, 
-   SM_60, 
-   SM_61, 
-   SM_62, 
-   SM_70, 
-   SM_72, 
-   SM_75, 
-   SM_80, 
-   SM_86, 
-   SM_87, 
-   SM_89, 
-   SM_90, 
-   GFX600, 
-   GFX601, 
-   GFX602, 
-   GFX700, 
-   GFX701, 
-   GFX702, 
-   GFX703, 
-   GFX704, 
-   GFX705, 
-   GFX801, 
-   GFX802, 
-   GFX803, 
-   GFX805, 
-   GFX810, 
-   GFX900, 
-   GFX902, 
-   GFX904, 
-   GFX906, 
-   GFX908, 
-   GFX909, 
-   GFX90a, 
-   GFX90c, 
-   GFX940, 
-   GFX1010, 
-   GFX1011, 
-   GFX1012, 
-   GFX1013, 
-   GFX1030, 
-   GFX1031, 
-   GFX1032, 
-   GFX1033, 
-   GFX1034, 
-   GFX1035, 
-   GFX1036, 
-   GFX1100, 
-   GFX1101, 
-   GFX1102, 
-   GFX1103, 
-   Generic, // A processor model named 'generic' if the target backend defines a 
-            // public one. 
-   LAST, 
-   
-   CudaDefault = CudaArch::SM_35, 
-   HIPDefault = CudaArch::GFX803, 
- }; 
-   
- static inline bool IsNVIDIAGpuArch(CudaArch A) { 
-   return A >= CudaArch::SM_20 && A < CudaArch::GFX600; 
- } 
-   
- static inline bool IsAMDGpuArch(CudaArch A) { 
-   // Generic processor model is for testing only. 
-   return A >= CudaArch::GFX600 && A < CudaArch::Generic; 
- } 
-   
- const char *CudaArchToString(CudaArch A); 
- const char *CudaArchToVirtualArchString(CudaArch A); 
-   
- // The input should have the form "sm_20". 
- CudaArch StringToCudaArch(llvm::StringRef S); 
-   
- /// Get the earliest CudaVersion that supports the given CudaArch. 
- CudaVersion MinVersionForCudaArch(CudaArch A); 
-   
- /// Get the latest CudaVersion that supports the given CudaArch. 
- CudaVersion MaxVersionForCudaArch(CudaArch A); 
-   
- //  Various SDK-dependent features that affect CUDA compilation 
- enum class CudaFeature { 
-   // CUDA-9.2+ uses a new API for launching kernels. 
-   CUDA_USES_NEW_LAUNCH, 
-   // CUDA-10.1+ needs explicit end of GPU binary registration. 
-   CUDA_USES_FATBIN_REGISTER_END, 
- }; 
-   
- CudaVersion ToCudaVersion(llvm::VersionTuple); 
- bool CudaFeatureEnabled(llvm::VersionTuple, CudaFeature); 
- bool CudaFeatureEnabled(CudaVersion, CudaFeature); 
-   
- } // namespace clang 
-   
- #endif 
-