summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/PowerPC/fast-isel-const.ll
diff options
context:
space:
mode:
authorHal Finkel <hfinkel@anl.gov>2014-12-25 23:08:25 +0000
committerHal Finkel <hfinkel@anl.gov>2014-12-25 23:08:25 +0000
commit0c505b08a53a8cd96124264512f4bdf81e648f72 (patch)
treeccd63c8bf37335d1ae6efd7f87d33025896c2cfd /llvm/test/CodeGen/PowerPC/fast-isel-const.ll
parentb723834d82961103dcaf75dd8fa98eb81ca092ff (diff)
downloadbcm5719-llvm-0c505b08a53a8cd96124264512f4bdf81e648f72.tar.gz
bcm5719-llvm-0c505b08a53a8cd96124264512f4bdf81e648f72.zip
[PowerPC] [FastISel] i1 constants must be zero extended
When materializing constant i1 values, they must be zero extended. We represent i1 values as [0, 1], not [0, -1], in i32 registers. As it turns out, this code path was dead for i1 values prior to r216006 (which is why this did not manifest in miscompiles until recently). Fixes -O0 self-hosting on PPC64/Linux. llvm-svn: 224842
Diffstat (limited to 'llvm/test/CodeGen/PowerPC/fast-isel-const.ll')
-rw-r--r--llvm/test/CodeGen/PowerPC/fast-isel-const.ll27
1 files changed, 27 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/PowerPC/fast-isel-const.ll b/llvm/test/CodeGen/PowerPC/fast-isel-const.ll
new file mode 100644
index 00000000000..1057d0a0ce2
--- /dev/null
+++ b/llvm/test/CodeGen/PowerPC/fast-isel-const.ll
@@ -0,0 +1,27 @@
+; RUN: llc < %s -O0 -verify-machineinstrs -fast-isel-abort -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -mattr=-vsx | FileCheck %s --check-prefix=ELF64
+
+define zeroext i1 @testi1(i8 %in) nounwind uwtable ssp {
+entry:
+ %c = icmp eq i8 %in, 5
+ br i1 %c, label %true, label %false
+
+; ELF64-LABEL: @testi1
+
+true:
+ br label %end
+
+; ELF64-NOT: li {{[0-9]+}}, -1
+; ELF64: li {{[0-9]+}}, 1
+
+false:
+ br label %end
+
+; ELF64: li {{[0-9]+}}, 0
+
+end:
+ %r = phi i1 [ 0, %false], [ 1, %true ]
+ ret i1 %r
+
+; ELF64: blr
+}
+
OpenPOWER on IntegriCloud