summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/DebugIR/function.ll
diff options
context:
space:
mode:
authorDaniel Malea <daniel.malea@intel.com>2013-06-28 20:37:20 +0000
committerDaniel Malea <daniel.malea@intel.com>2013-06-28 20:37:20 +0000
commit4146b0404eab2a98023276bc377a947f1c44efc0 (patch)
treea5b19d64822433d8b2a73b20e86dd3ff00095929 /llvm/test/Transforms/DebugIR/function.ll
parent3f75953d82307f0406d7be3e78e6ebc1f1273995 (diff)
downloadbcm5719-llvm-4146b0404eab2a98023276bc377a947f1c44efc0.tar.gz
bcm5719-llvm-4146b0404eab2a98023276bc377a947f1c44efc0.zip
Adding tests for DebugIR pass
- lit tests verify that each line of input LLVM IR gets a !dbg node and a corresponding entry of metadata that contains the line number - unit tests verify that DebugIR works as advertised in the interface - refactored some useful IR generation functionality from the MCJIT unit tests so it can be reused llvm-svn: 185212
Diffstat (limited to 'llvm/test/Transforms/DebugIR/function.ll')
-rw-r--r--llvm/test/Transforms/DebugIR/function.ll51
1 files changed, 51 insertions, 0 deletions
diff --git a/llvm/test/Transforms/DebugIR/function.ll b/llvm/test/Transforms/DebugIR/function.ll
new file mode 100644
index 00000000000..dba073de37e
--- /dev/null
+++ b/llvm/test/Transforms/DebugIR/function.ll
@@ -0,0 +1,51 @@
+; ModuleID = 'function.c'
+target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
+target triple = "x86_64-pc-linux-gnu"
+
+; Function Attrs: nounwind uwtable
+define void @blah(i32* %i) #0 {
+ %1 = alloca i32*, align 8 ; CHECK: !dbg
+ store i32* %i, i32** %1, align 8 ; CHECK-NEXT: !dbg
+ %2 = load i32** %1, align 8 ; CHECK-NEXT: !dbg
+ %3 = load i32* %2, align 4 ; CHECK-NEXT: !dbg
+ %4 = add nsw i32 %3, 1 ; CHECK-NEXT: !dbg
+ store i32 %4, i32* %2, align 4 ; CHECK-NEXT: !dbg
+ ret void ; CHECK-NEXT: !dbg
+}
+
+; Function Attrs: nounwind uwtable
+define i32 @main(i32 %argc, i8** %argv) #0 {
+ %1 = alloca i32, align 4 ; CHECK: !dbg
+ %2 = alloca i32, align 4 ; CHECK-NEXT: !dbg
+ %3 = alloca i8**, align 8 ; CHECK-NEXT: !dbg
+ %i = alloca i32, align 4 ; CHECK-NEXT: !dbg
+ store i32 0, i32* %1 ; CHECK-NEXT: !dbg
+ store i32 %argc, i32* %2, align 4 ; CHECK-NEXT: !dbg
+ store i8** %argv, i8*** %3, align 8 ; CHECK-NEXT: !dbg
+ store i32 7, i32* %i, align 4 ; CHECK-NEXT: !dbg
+ call void @blah(i32* %i) ; CHECK-NEXT: !dbg
+ %4 = load i32* %i, align 4 ; CHECK-NEXT: !dbg
+ ret i32 %4 ; CHECK-NEXT: !dbg
+}
+
+attributes #0 = { nounwind uwtable "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf"="true" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "unsafe-fp-math"="false" "use-soft-float"="false" }
+; CHECK: = metadata !{i32 8,
+; CHECK-NEXT: = metadata !{i32 9,
+; CHECK-NEXT: = metadata !{i32 10,
+; CHECK-NEXT: = metadata !{i32 11,
+; CHECK-NEXT: = metadata !{i32 12,
+; CHECK-NEXT: = metadata !{i32 13,
+
+; CHECK-NEXT: = metadata !{i32 18,
+; CHECK-NEXT: = metadata !{i32 19,
+; CHECK-NEXT: = metadata !{i32 20,
+; CHECK-NEXT: = metadata !{i32 21,
+; CHECK-NEXT: = metadata !{i32 22,
+; CHECK-NEXT: = metadata !{i32 23,
+; CHECK-NEXT: = metadata !{i32 24,
+; CHECK-NEXT: = metadata !{i32 25,
+; CHECK-NEXT: = metadata !{i32 26,
+; CHECK-NEXT: = metadata !{i32 27,
+; CHECK-NEXT: = metadata !{i32 28,
+
+; RUN: opt %s -debug-ir -S | FileCheck %s
OpenPOWER on IntegriCloud