From 509acc186eb62a59fa94c43285555c23f0f1e4ad Mon Sep 17 00:00:00 2001 From: Reid Spencer Date: Mon, 5 Mar 2007 22:51:08 +0000 Subject: [PATCH] Add a test case for a particular udiv/select transform. llvm-svn: 34935 --- .../InstCombine/udiv_select_to_select_shift.ll | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 llvm/test/Transforms/InstCombine/udiv_select_to_select_shift.ll 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 000000000000..33740d567d30 --- /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 +}