1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -passes=sccp -S | FileCheck %s
4 define i1 @foo(i32 %t4, i32 %t10) {
6 ; CHECK-NEXT: [[T09:%.*]] = shl i32 [[T10:%.*]], 24
7 ; CHECK-NEXT: [[T010:%.*]] = ashr exact i32 [[T09]], 24
8 ; CHECK-NEXT: [[T011:%.*]] = add nsw i32 [[T010]], 979
9 ; CHECK-NEXT: [[T11:%.*]] = trunc i32 [[T4:%.*]] to i8
10 ; CHECK-NEXT: [[T12:%.*]] = icmp eq i8 [[T11]], 0
11 ; CHECK-NEXT: [[T14:%.*]] = zext i1 [[T12]] to i32
12 ; CHECK-NEXT: [[T15:%.*]] = shl i32 [[T4]], [[T14]]
13 ; CHECK-NEXT: [[T17:%.*]] = and i32 [[T15]], 255
14 ; CHECK-NEXT: ret i1 false
16 %t09 = shl i32 %t10, 24
17 %t010 = ashr exact i32 %t09, 24
18 %t011 = add nsw i32 %t010, 979
19 %t11 = trunc i32 %t4 to i8
20 %t12 = icmp eq i8 %t11, 0
21 %t14 = zext i1 %t12 to i32
22 %t15 = shl i32 %t4, %t14
23 %t17 = and i32 %t15, 255
24 %t18 = icmp eq i32 %t011, %t17
28 define i1 @bar(i32 %t4, i32 %t10) {
30 ; CHECK-NEXT: [[T09:%.*]] = shl i32 [[T10:%.*]], 24
31 ; CHECK-NEXT: [[T010:%.*]] = ashr exact i32 [[T09]], 24
32 ; CHECK-NEXT: [[T011:%.*]] = add nsw i32 [[T010]], 979
33 ; CHECK-NEXT: [[T11:%.*]] = trunc i32 [[T4:%.*]] to i8
34 ; CHECK-NEXT: [[T12:%.*]] = icmp eq i8 [[T11]], 0
35 ; CHECK-NEXT: [[T14:%.*]] = zext i1 [[T12]] to i8
36 ; CHECK-NEXT: [[T15:%.*]] = shl i8 [[T11]], [[T14]]
37 ; CHECK-NEXT: [[T17:%.*]] = zext i8 [[T15]] to i32
38 ; CHECK-NEXT: ret i1 false
40 %t09 = shl i32 %t10, 24
41 %t010 = ashr exact i32 %t09, 24
42 %t011 = add nsw i32 %t010, 979
43 %t11 = trunc i32 %t4 to i8
44 %t12 = icmp eq i8 %t11, 0
45 %t14 = zext i1 %t12 to i8
46 %t15 = shl i8 %t11, %t14
47 %t17 = zext i8 %t15 to i32
48 %t18 = icmp eq i32 %t011, %t17
52 define i1 @foobar(i32 %t4, i32 %t10) {
53 ; CHECK-LABEL: @foobar(
54 ; CHECK-NEXT: [[T09:%.*]] = shl i32 [[T10:%.*]], 24
55 ; CHECK-NEXT: [[T010:%.*]] = ashr exact i32 [[T09]], 24
56 ; CHECK-NEXT: [[T011:%.*]] = add nsw i32 [[T010]], 979
57 ; CHECK-NEXT: [[T11:%.*]] = trunc i32 [[T4:%.*]] to i8
58 ; CHECK-NEXT: [[T12:%.*]] = icmp eq i8 [[T11]], 0
59 ; CHECK-NEXT: [[T13:%.*]] = zext i8 [[T11]] to i32
60 ; CHECK-NEXT: [[T14:%.*]] = select i1 [[T12]], i32 1, i32 0
61 ; CHECK-NEXT: [[T15:%.*]] = shl nuw nsw i32 [[T13]], [[T14]]
62 ; CHECK-NEXT: [[T16:%.*]] = trunc i32 [[T15]] to i8
63 ; CHECK-NEXT: [[T17:%.*]] = zext i8 [[T16]] to i32
64 ; CHECK-NEXT: ret i1 false
66 %t09 = shl i32 %t10, 24
67 %t010 = ashr exact i32 %t09, 24
68 %t011 = add nsw i32 %t010, 979
70 %t11 = trunc i32 %t4 to i8
71 %t12 = icmp eq i8 %t11, 0
72 %t13 = zext i8 %t11 to i32
73 %t14 = select i1 %t12, i32 1, i32 0
74 %t15 = shl nuw nsw i32 %t13, %t14
75 %t16 = trunc i32 %t15 to i8
76 %t17 = zext i8 %t16 to i32
78 %t18 = icmp eq i32 %t011, %t17