Skip to content

Commit 421c416

Browse files
nikicmattarde
authored andcommitted
[LSR] Add test for implicit truncation on icmp immediate (NFC)
Test case for: llvm#171456 (comment)
1 parent befdc4e commit 421c416

File tree

1 file changed

+48
-0
lines changed

1 file changed

+48
-0
lines changed
Lines changed: 48 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6
2+
; RUN: opt -S -loop-reduce < %s | FileCheck %s
3+
4+
target triple = "x86_64-unknown-linux-gnu"
5+
6+
declare void @use(i1)
7+
8+
; Make sure this does not assert.
9+
define i16 @test(i16 %start) #0 {
10+
; CHECK-LABEL: define i16 @test(
11+
; CHECK-SAME: i16 [[START:%.*]]) #[[ATTR0:[0-9]+]] {
12+
; CHECK-NEXT: [[ENTRY:.*]]:
13+
; CHECK-NEXT: [[TMP0:%.*]] = sub i16 0, [[START]]
14+
; CHECK-NEXT: [[TMP1:%.*]] = zext i16 [[TMP0]] to i64
15+
; CHECK-NEXT: br label %[[LOOP:.*]]
16+
; CHECK: [[LOOP]]:
17+
; CHECK-NEXT: [[LSR_IV:%.*]] = phi i64 [ [[LSR_IV_NEXT:%.*]], %[[LOOP]] ], [ 65536, %[[ENTRY]] ]
18+
; CHECK-NEXT: [[TMP2:%.*]] = add i64 [[TMP1]], [[LSR_IV]]
19+
; CHECK-NEXT: [[TMP:%.*]] = trunc i64 [[TMP2]] to i16
20+
; CHECK-NEXT: [[IV2_CMP:%.*]] = icmp ne i16 [[TMP]], 0
21+
; CHECK-NEXT: call void @use(i1 [[IV2_CMP]])
22+
; CHECK-NEXT: [[LSR_IV_NEXT]] = add nsw i64 [[LSR_IV]], -1
23+
; CHECK-NEXT: [[IV1_CMP:%.*]] = icmp eq i64 [[LSR_IV_NEXT]], 65532
24+
; CHECK-NEXT: br i1 [[IV1_CMP]], label %[[EXIT:.*]], label %[[LOOP]]
25+
; CHECK: [[EXIT]]:
26+
; CHECK-NEXT: [[TMP3:%.*]] = zext i16 [[START]] to i64
27+
; CHECK-NEXT: [[TMP4:%.*]] = sub i64 [[TMP3]], [[LSR_IV_NEXT]]
28+
; CHECK-NEXT: [[TMP1:%.*]] = trunc i64 [[TMP4]] to i16
29+
; CHECK-NEXT: ret i16 [[TMP1]]
30+
;
31+
entry:
32+
br label %loop
33+
34+
loop:
35+
%iv1 = phi i64 [ 3, %entry ], [ %iv1.dec, %loop ]
36+
%iv2 = phi i16 [ %start, %entry ], [ %iv2.inc, %loop ]
37+
%iv2.inc = add i16 %iv2, 1
38+
%iv2.cmp = icmp ne i16 %iv2, 0
39+
call void @use(i1 %iv2.cmp)
40+
%iv1.dec = add i64 %iv1, -1
41+
%iv1.cmp = icmp eq i64 %iv1, 0
42+
br i1 %iv1.cmp, label %exit, label %loop
43+
44+
exit:
45+
ret i16 %iv2.inc
46+
}
47+
48+
attributes #0 = { "target-cpu"="x86-64" }

0 commit comments

Comments
 (0)