Move a DenseMap's declaration outside of a loop, and just call
[oota-llvm.git] / test / Transforms / InstCombine / div.ll
index 54199aedd07abb71add807243ad710ac0c40fb21..ea6ea6323c5645768f4612dd0980993c81f2ac44 100644 (file)
@@ -1,63 +1,84 @@
 ; This test makes sure that div instructions are properly eliminated.
-;
 
 ; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep div
 
-implementation
+define i32 @test1(i32 %A) {
+        %B = sdiv i32 %A, 1             ; <i32> [#uses=1]
+        ret i32 %B
+}
+
+define i32 @test2(i32 %A) {
+        ; => Shift
+        %B = udiv i32 %A, 8             ; <i32> [#uses=1]
+        ret i32 %B
+}
+
+define i32 @test3(i32 %A) {
+        ; => 0, don't need to keep traps
+        %B = sdiv i32 0, %A             ; <i32> [#uses=1]
+        ret i32 %B
+}
 
-int %test1(int %A) {
-       %B = div int %A, 1
-       ret int %B
+define i32 @test4(i32 %A) {
+        ; 0-A
+        %B = sdiv i32 %A, -1            ; <i32> [#uses=1]
+        ret i32 %B
 }
 
-uint %test2(uint %A) {
-       %B = div uint %A, 8   ; => Shift
-       ret uint %B
+define i32 @test5(i32 %A) {
+        %B = udiv i32 %A, -16           ; <i32> [#uses=1]
+        %C = udiv i32 %B, -4            ; <i32> [#uses=1]
+        ret i32 %C
 }
 
-int %test3(int %A) {
-       %B = div int 0, %A    ; => 0, don't need to keep traps
-       ret int %B
+define i1 @test6(i32 %A) {
+        %B = udiv i32 %A, 123           ; <i32> [#uses=1]
+        ; A < 123
+        %C = icmp eq i32 %B, 0          ; <i1> [#uses=1]
+        ret i1 %C
 }
 
-int %test4(int %A) {
-       %B = div int %A, -1    ; 0-A
-       ret int %B
+define i1 @test7(i32 %A) {
+        %B = udiv i32 %A, 10            ; <i32> [#uses=1]
+        ; A >= 20 && A < 30
+        %C = icmp eq i32 %B, 2          ; <i1> [#uses=1]
+        ret i1 %C
 }
 
-uint %test5(uint %A) {
-       %B = div uint %A, 4294967280
-       %C = div uint %B, 4294967292
-       ret uint %C
+define i1 @test8(i8 %A) {
+        %B = udiv i8 %A, 123            ; <i8> [#uses=1]
+        ; A >= 246
+        %C = icmp eq i8 %B, 2           ; <i1> [#uses=1]
+        ret i1 %C
 }
 
-bool %test6(uint %A) {
-       %B = div uint %A, 123
-       %C = seteq uint %B, 0   ; A < 123
-       ret bool %C
-} 
+define i1 @test9(i8 %A) {
+        %B = udiv i8 %A, 123            ; <i8> [#uses=1]
+        ; A < 246
+        %C = icmp ne i8 %B, 2           ; <i1> [#uses=1]
+        ret i1 %C
+}
 
-bool %test7(uint %A) {
-       %B = div uint %A, 10
-       %C = seteq uint %B, 2    ; A >= 20 && A < 30
-       ret bool %C
+define i32 @test10(i32 %X, i1 %C) {
+        %V = select i1 %C, i32 64, i32 8                ; <i32> [#uses=1]
+        %R = udiv i32 %X, %V            ; <i32> [#uses=1]
+        ret i32 %R
 }
 
-bool %test8(ubyte %A) {
-       %B = div ubyte %A, 123
-       %C = seteq ubyte %B, 2   ; A >= 246
-       ret bool %C
-} 
+define i32 @test11(i32 %X, i1 %C) {
+        %A = select i1 %C, i32 1024, i32 32             ; <i32> [#uses=1]
+        %B = udiv i32 %X, %A            ; <i32> [#uses=1]
+        ret i32 %B
+}
 
-bool %test9(ubyte %A) {
-       %B = div ubyte %A, 123
-       %C = setne ubyte %B, 2   ; A < 246
-       ret bool %C
-} 
+; PR2328
+define i32 @test12(i32 %x) nounwind  {
+       %tmp3 = udiv i32 %x, %x         ; 1
+       ret i32 %tmp3
+}
 
-uint %test10(uint %X, bool %C) {
-        %V = select bool %C, uint 64, uint 8
-        %R = div uint %X, %V
-        ret uint %R
+define i32 @test13(i32 %x) nounwind  {
+       %tmp3 = sdiv i32 %x, %x         ; 1
+       ret i32 %tmp3
 }