diff options
Diffstat (limited to 'llvm/test/Assembler')
-rw-r--r-- | llvm/test/Assembler/auto_upgrade_nvvm_intrinsics.ll | 9 | ||||
-rw-r--r-- | llvm/test/Assembler/autoupgrade-lifetime-intrinsics.ll | 57 | ||||
-rw-r--r-- | llvm/test/Assembler/callee-type-metadata.ll | 21 | ||||
-rw-r--r-- | llvm/test/Assembler/difile-empty-source.ll | 12 |
4 files changed, 99 insertions, 0 deletions
diff --git a/llvm/test/Assembler/auto_upgrade_nvvm_intrinsics.ll b/llvm/test/Assembler/auto_upgrade_nvvm_intrinsics.ll index a17f11a..362586a 100644 --- a/llvm/test/Assembler/auto_upgrade_nvvm_intrinsics.ll +++ b/llvm/test/Assembler/auto_upgrade_nvvm_intrinsics.ll @@ -17,6 +17,8 @@ declare float @llvm.nvvm.fabs.f(float) declare float @llvm.nvvm.fabs.ftz.f(float) declare double @llvm.nvvm.fabs.d(double) +declare float @llvm.nvvm.tanh.approx.f32(float) + declare i16 @llvm.nvvm.max.s(i16, i16) declare i32 @llvm.nvvm.max.i(i32, i32) declare i64 @llvm.nvvm.max.ll(i64, i64) @@ -138,6 +140,13 @@ define void @fabs(float %a, double %b) { ret void } +; CHECK-LABEL: @tanh +define void @tanh(float %a) { +; CHECK: call afn float @llvm.tanh.f32(float %a) + %r1 = call float @llvm.nvvm.tanh.approx.f32(float %a) + ret void +} + ; CHECK-LABEL: @min_max define void @min_max(i16 %a1, i16 %a2, i32 %b1, i32 %b2, i64 %c1, i64 %c2) { ; CHECK: [[maxs:%[a-zA-Z0-9.]+]] = icmp sge i16 %a1, %a2 diff --git a/llvm/test/Assembler/autoupgrade-lifetime-intrinsics.ll b/llvm/test/Assembler/autoupgrade-lifetime-intrinsics.ll new file mode 100644 index 0000000..00ab934 --- /dev/null +++ b/llvm/test/Assembler/autoupgrade-lifetime-intrinsics.ll @@ -0,0 +1,57 @@ +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5 +; RUN: opt -S < %s | FileCheck %s + +define void @strip_bitcast() { +; CHECK-LABEL: define void @strip_bitcast() { +; CHECK-NEXT: [[A:%.*]] = alloca i8, align 1 +; CHECK-NEXT: [[B:%.*]] = bitcast ptr [[A]] to ptr +; CHECK-NEXT: call void @llvm.lifetime.start.p0(i64 1, ptr [[A]]) +; CHECK-NEXT: call void @llvm.lifetime.end.p0(i64 1, ptr [[A]]) +; CHECK-NEXT: ret void +; + %a = alloca i8 + %b = bitcast ptr %a to ptr + call void @llvm.lifetime.start.p0(i64 1, ptr %b) + call void @llvm.lifetime.end.p0(i64 1, ptr %b) + ret void +} + +define void @strip_addrspacecast() { +; CHECK-LABEL: define void @strip_addrspacecast() { +; CHECK-NEXT: [[A:%.*]] = alloca i8, align 1 +; CHECK-NEXT: [[B:%.*]] = addrspacecast ptr [[A]] to ptr addrspace(1) +; CHECK-NEXT: call void @llvm.lifetime.start.p0(i64 1, ptr [[A]]) +; CHECK-NEXT: call void @llvm.lifetime.end.p0(i64 1, ptr [[A]]) +; CHECK-NEXT: ret void +; + %a = alloca i8 + %b = addrspacecast ptr %a to ptr addrspace(1) + call void @llvm.lifetime.start.p1(i64 1, ptr addrspace(1) %b) + call void @llvm.lifetime.end.p1(i64 1, ptr addrspace(1) %b) + ret void +} + +define void @strip_gep() { +; CHECK-LABEL: define void @strip_gep() { +; CHECK-NEXT: [[A:%.*]] = alloca [2 x i8], align 1 +; CHECK-NEXT: [[B:%.*]] = getelementptr [2 x i8], ptr [[A]], i64 0, i64 0 +; CHECK-NEXT: call void @llvm.lifetime.start.p0(i64 1, ptr [[A]]) +; CHECK-NEXT: call void @llvm.lifetime.end.p0(i64 1, ptr [[A]]) +; CHECK-NEXT: ret void +; + %a = alloca [2 x i8] + %b = getelementptr [2 x i8], ptr %a, i64 0, i64 0 + call void @llvm.lifetime.start.p0(i64 1, ptr %b) + call void @llvm.lifetime.end.p0(i64 1, ptr %b) + ret void +} + +define void @remove_unanalyzable(ptr %p) { +; CHECK-LABEL: define void @remove_unanalyzable( +; CHECK-SAME: ptr [[P:%.*]]) { +; CHECK-NEXT: ret void +; + call void @llvm.lifetime.start.p0(i64 1, ptr %p) + call void @llvm.lifetime.end.p0(i64 1, ptr %p) + ret void +} diff --git a/llvm/test/Assembler/callee-type-metadata.ll b/llvm/test/Assembler/callee-type-metadata.ll new file mode 100644 index 0000000..9c3cfbe --- /dev/null +++ b/llvm/test/Assembler/callee-type-metadata.ll @@ -0,0 +1,21 @@ +;; Test if the callee_type metadata attached to indirect call sites adhere to the expected format. + +; RUN: llvm-as < %s | llvm-dis | FileCheck %s +define i32 @_Z13call_indirectPFicEc(ptr %func, i8 signext %x) !type !0 { +entry: + %func.addr = alloca ptr, align 8 + %x.addr = alloca i8, align 1 + store ptr %func, ptr %func.addr, align 8 + store i8 %x, ptr %x.addr, align 1 + %fptr = load ptr, ptr %func.addr, align 8 + %x_val = load i8, ptr %x.addr, align 1 + ; CHECK: %call = call i32 %fptr(i8 signext %x_val), !callee_type !1 + %call = call i32 %fptr(i8 signext %x_val), !callee_type !1 + ret i32 %call +} + +declare !type !2 i32 @_Z3barc(i8 signext) + +!0 = !{i64 0, !"_ZTSFiPvcE.generalized"} +!1 = !{!2} +!2 = !{i64 0, !"_ZTSFicE.generalized"} diff --git a/llvm/test/Assembler/difile-empty-source.ll b/llvm/test/Assembler/difile-empty-source.ll new file mode 100644 index 0000000..11587d8 --- /dev/null +++ b/llvm/test/Assembler/difile-empty-source.ll @@ -0,0 +1,12 @@ +; RUN: llvm-as < %s | llvm-dis | llvm-as | llvm-dis | FileCheck %s +; RUN: verify-uselistorder + +; CHECK: !DIFile({{.*}}, source: "") + +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!2, !3} + +!0 = distinct !DICompileUnit(language: DW_LANG_C11, file: !1, emissionKind: FullDebug) +!1 = !DIFile(filename: "-", directory: "/", checksumkind: CSK_MD5, checksum: "d41d8cd98f00b204e9800998ecf8427e", source: "") +!2 = !{i32 7, !"Dwarf Version", i32 5} +!3 = !{i32 2, !"Debug Info Version", i32 3} |