[libc] Switch to using the generic `<gpuintrin.h>` implementations (#121810)
[llvm-project.git] / llvm / test / CodeGen / NVPTX / nvvm-reflect-arch.ll
blobac5875c6ab1043ab7b26615ec27b24e11a62b84f
1 ; Libdevice in recent CUDA versions relies on __CUDA_ARCH reflecting GPU type.
2 ; Verify that __nvvm_reflect() is replaced with an appropriate value.
4 ; RUN: opt %s -S -passes='default<O2>' -mtriple=nvptx64 -mcpu=sm_20 \
5 ; RUN:   | FileCheck %s --check-prefixes=COMMON,SM20
6 ; RUN: opt %s -S -passes='default<O2>' -mtriple=nvptx64 -mcpu=sm_35 \
7 ; RUN:   | FileCheck %s --check-prefixes=COMMON,SM35
9 @"$str" = private addrspace(1) constant [12 x i8] c"__CUDA_ARCH\00"
11 declare i32 @__nvvm_reflect(ptr)
13 ; COMMON-LABEL: @foo
14 define i32 @foo(float %a, float %b) {
15 ; COMMON-NOT: call i32 @__nvvm_reflect
16   %reflect = call i32 @__nvvm_reflect(ptr addrspacecast (ptr addrspace(1) @"$str" to ptr))
17 ; SM20: ret i32 200  
18 ; SM35: ret i32 350  
19   ret i32 %reflect