summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2007-03-05 22:51:08 +0000
committerReid Spencer <rspencer@reidspencer.com>2007-03-05 22:51:08 +0000
commit509acc186eb62a59fa94c43285555c23f0f1e4ad (patch)
tree386f3d28f41d8cedbde2591d22c6ce5872d27b30 /llvm/test
parent003a559633d2ec060d37b7f6657d82da72f5107d (diff)
downloadbcm5719-llvm-509acc186eb62a59fa94c43285555c23f0f1e4ad.tar.gz
bcm5719-llvm-509acc186eb62a59fa94c43285555c23f0f1e4ad.zip
Add a test case for a particular udiv/select transform.
llvm-svn: 34935
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/Transforms/InstCombine/udiv_select_to_select_shift.ll17
1 files changed, 17 insertions, 0 deletions
diff --git a/llvm/test/Transforms/InstCombine/udiv_select_to_select_shift.ll b/llvm/test/Transforms/InstCombine/udiv_select_to_select_shift.ll
new file mode 100644
index 00000000000..33740d567d3
--- /dev/null
+++ b/llvm/test/Transforms/InstCombine/udiv_select_to_select_shift.ll
@@ -0,0 +1,17 @@
+; This tests that this transform:
+; udiv X, (Select Cond, C1, C2) --> Select Cond, (shr X, C1), (shr X, C2)
+;
+; RUN: llvm-as %s -o - | opt -instcombine | llvm-dis -f -o %t && \
+; RUN: grep select %t | wc -l | grep 1 && \
+; RUN: grep lshr %t | wc -l | grep 2 && \
+; RUN: grep udiv %t | wc -l | grep 0
+
+define i64 @test(i64 %X, i1 %Cond ) {
+entry:
+ %divisor1 = select i1 %Cond, i64 8, i64 16
+ %quotient1 = udiv i64 %X, %divisor1
+ %divisor2 = select i1 %Cond, i64 8, i64 0
+ %quotient2 = udiv i64 %X, %divisor2
+ %sum = add i64 %quotient1, %quotient2
+ ret i64 %sum
+}
OpenPOWER on IntegriCloud