diff options
author | Florian Hahn <florian.hahn@arm.com> | 2016-12-06 10:24:55 +0000 |
---|---|---|
committer | Florian Hahn <florian.hahn@arm.com> | 2016-12-06 10:24:55 +0000 |
commit | 7582c669bdc4aed10c18eb799313c2b6f7e71edb (patch) | |
tree | 351e66af97790bde58f9bd3ce315ca39c6a4f600 /llvm/test/CodeGen/X86 | |
parent | 6aeb2498914b915fc7ffaa5ddb97c77248440914 (diff) | |
download | bcm5719-llvm-7582c669bdc4aed10c18eb799313c2b6f7e71edb.tar.gz bcm5719-llvm-7582c669bdc4aed10c18eb799313c2b6f7e71edb.zip |
[framelowering] Improve tracking of first CS pop instruction.
Summary: This patch makes sure FirstCSPop and MBBI never point to DBG_VALUE instructions, which affected the code generated.
Reviewers: mkuper, aprantl, MatzeB
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D27343
llvm-svn: 288794
Diffstat (limited to 'llvm/test/CodeGen/X86')
-rw-r--r-- | llvm/test/CodeGen/X86/frame-lowering-debug-intrinsic.ll | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/X86/frame-lowering-debug-intrinsic.ll b/llvm/test/CodeGen/X86/frame-lowering-debug-intrinsic.ll new file mode 100644 index 00000000000..8614d1b4c6c --- /dev/null +++ b/llvm/test/CodeGen/X86/frame-lowering-debug-intrinsic.ll @@ -0,0 +1,41 @@ +; Test ensuring debug intrinsics do not affect generated function prologue. +; +; RUN: llc -O1 -mtriple=x86_64-unknown-unknown -o - %s | FileCheck %s + + +define i64 @noDebug(i64 %a) { + %call = call i64 @fn(i64 %a, i64 0) + ret i64 %call +} + +; CHECK-LABEL: noDebug +; CHECK: popq %rcx +; CHECK: ret + + +define i64 @withDebug(i64 %a) !dbg !4 { + %call = call i64 @fn(i64 %a, i64 0) + tail call void @llvm.dbg.value(metadata i64 %call, i64 0, metadata !5, metadata !6), !dbg !7 + ret i64 %call +} + +; CHECK-LABEL: withDebug +; CHECK: popq %rcx +; CHECK: ret + + +declare i64 @fn(i64, i64) + +declare void @llvm.dbg.value(metadata, i64, metadata, metadata) + +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!2,!3} + +!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "clang version 4.0.0") +!1 = !DIFile(filename: "test.c", directory: "/") +!2 = !{i32 2, !"Dwarf Version", i32 4} +!3 = !{i32 2, !"Debug Info Version", i32 3} +!4 = distinct !DISubprogram(name: "withDebug", unit: !0) +!5 = !DILocalVariable(name: "w", scope: !4) +!6 = !DIExpression() +!7 = !DILocation(line: 210, column: 12, scope: !4) |