1 ; RUN: opt < %s -instcombine -S | FileCheck %s 2 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64" 3 4 ; Instcombine should be able to eliminate all of these ext casts. 5 6 declare void @use(i32) 7 8 define i64 @test1(i64 %a) { 9 %b = trunc i64 %a to i32 10 %c = and i32 %b, 15 11 %d = zext i32 %c to i64 12 call void @use(i32 %b) 13 ret i64 %d 14 ; CHECK-LABEL: @test1( 15 ; CHECK-NOT: ext 16 ; CHECK: ret 17 } 18 define i64 @test2(i64 %a) { 19 %b = trunc i64 %a to i32 20 %c = shl i32 %b, 4 21 %q = ashr i32 %c, 4 22 %d = sext i32 %q to i64 23 call void @use(i32 %b) 24 ret i64 %d 25 ; CHECK-LABEL: @test2( 26 ; CHECK: shl i64 %a, 36 27 ; CHECK: %d = ashr exact i64 {{.*}}, 36 28 ; CHECK: ret i64 %d 29 } 30 define i64 @test3(i64 %a) { 31 %b = trunc i64 %a to i32 32 %c = and i32 %b, 8 33 %d = zext i32 %c to i64 34 call void @use(i32 %b) 35 ret i64 %d 36 ; CHECK-LABEL: @test3( 37 ; CHECK-NOT: ext 38 ; CHECK: ret 39 } 40 define i64 @test4(i64 %a) { 41 %b = trunc i64 %a to i32 42 %c = and i32 %b, 8 43 %x = xor i32 %c, 8 44 %d = zext i32 %x to i64 45 call void @use(i32 %b) 46 ret i64 %d 47 ; CHECK-LABEL: @test4( 48 ; CHECK: = and i64 %a, 8 49 ; CHECK: = xor i64 {{.*}}, 8 50 ; CHECK-NOT: ext 51 ; CHECK: ret 52 } 53 54 define i32 @test5(i32 %A) { 55 %B = zext i32 %A to i128 56 %C = lshr i128 %B, 16 57 %D = trunc i128 %C to i32 58 ret i32 %D 59 ; CHECK-LABEL: @test5( 60 ; CHECK: %C = lshr i32 %A, 16 61 ; CHECK: ret i32 %C 62 } 63 64 define i32 @test6(i64 %A) { 65 %B = zext i64 %A to i128 66 %C = lshr i128 %B, 32 67 %D = trunc i128 %C to i32 68 ret i32 %D 69 ; CHECK-LABEL: @test6( 70 ; CHECK: %C = lshr i64 %A, 32 71 ; CHECK: %D = trunc i64 %C to i32 72 ; CHECK: ret i32 %D 73 } 74 75 define i92 @test7(i64 %A) { 76 %B = zext i64 %A to i128 77 %C = lshr i128 %B, 32 78 %D = trunc i128 %C to i92 79 ret i92 %D 80 ; CHECK-LABEL: @test7( 81 ; CHECK: %B = zext i64 %A to i92 82 ; CHECK: %C = lshr i92 %B, 32 83 ; CHECK: ret i92 %C 84 } 85 86 define i64 @test8(i32 %A, i32 %B) { 87 %tmp38 = zext i32 %A to i128 88 %tmp32 = zext i32 %B to i128 89 %tmp33 = shl i128 %tmp32, 32 90 %ins35 = or i128 %tmp33, %tmp38 91 %tmp42 = trunc i128 %ins35 to i64 92 ret i64 %tmp42 93 ; CHECK-LABEL: @test8( 94 ; CHECK: %tmp38 = zext i32 %A to i64 95 ; CHECK: %tmp32 = zext i32 %B to i64 96 ; CHECK: %tmp33 = shl nuw i64 %tmp32, 32 97 ; CHECK: %ins35 = or i64 %tmp33, %tmp38 98 ; CHECK: ret i64 %ins35 99 } 100 101 define i8 @test9(i32 %X) { 102 %Y = and i32 %X, 42 103 %Z = trunc i32 %Y to i8 104 ret i8 %Z 105 ; CHECK-LABEL: @test9( 106 ; CHECK: trunc 107 ; CHECK: and 108 ; CHECK: ret 109 } 110 111 ; rdar://8808586 112 define i8 @test10(i32 %X) { 113 %Y = trunc i32 %X to i8 114 %Z = and i8 %Y, 42 115 ret i8 %Z 116 ; CHECK-LABEL: @test10( 117 ; CHECK: trunc 118 ; CHECK: and 119 ; CHECK: ret 120 } 121