sms-phi-2.ll
2.04 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=powerpc64le-unknown-linux-gnu -verify-machineinstrs\
; RUN: -mcpu=pwr9 --ppc-enable-pipeliner 2>&1 | FileCheck %s
define void @phi2(i32, i32, i8*) local_unnamed_addr {
; CHECK-LABEL: phi2:
; CHECK: # %bb.0:
; CHECK-NEXT: divw 8, 3, 4
; CHECK-NEXT: li 5, 55
; CHECK-NEXT: li 6, 48
; CHECK-NEXT: mtctr 3
; CHECK-NEXT: bdz .LBB0_4
; CHECK-NEXT: # %bb.1:
; CHECK-NEXT: divw 9, 8, 4
; CHECK-NEXT: mullw 7, 8, 4
; CHECK-NEXT: subf 3, 7, 3
; CHECK-NEXT: cmplwi 3, 10
; CHECK-NEXT: isel 7, 6, 5, 0
; CHECK-NEXT: add 3, 7, 3
; CHECK-NEXT: stbu 3, -1(7)
; CHECK-NEXT: mr 3, 8
; CHECK-NEXT: bdz .LBB0_3
; CHECK-NEXT: .p2align 4
; CHECK-NEXT: .LBB0_2: #
; CHECK-NEXT: mr 3, 9
; CHECK-NEXT: mullw 9, 9, 4
; CHECK-NEXT: divw 10, 3, 4
; CHECK-NEXT: subf 8, 9, 8
; CHECK-NEXT: cmplwi 8, 10
; CHECK-NEXT: isel 9, 6, 5, 0
; CHECK-NEXT: add 8, 9, 8
; CHECK-NEXT: mr 9, 10
; CHECK-NEXT: stbu 8, -1(7)
; CHECK-NEXT: mr 8, 3
; CHECK-NEXT: bdnz .LBB0_2
; CHECK-NEXT: .LBB0_3:
; CHECK-NEXT: mr 8, 9
; CHECK-NEXT: b .LBB0_5
; CHECK-NEXT: .LBB0_4:
; CHECK-NEXT: # implicit-def: $x7
; CHECK-NEXT: .LBB0_5:
; CHECK-NEXT: mullw 4, 8, 4
; CHECK-NEXT: subf 3, 4, 3
; CHECK-NEXT: cmplwi 3, 10
; CHECK-NEXT: isel 4, 6, 5, 0
; CHECK-NEXT: add 3, 4, 3
; CHECK-NEXT: stbu 3, -1(7)
; CHECK-NEXT: blr
br label %4
4: ; preds = %4, %3
%5 = phi i64 [ %7, %4 ], [ undef, %3 ]
%6 = phi i32 [ %8, %4 ], [ %0, %3 ]
%7 = add nsw i64 %5, -1
%8 = sdiv i32 %6, %1
%9 = mul nsw i32 %8, %1
%10 = sub nsw i32 %6, %9
%11 = icmp ult i32 %10, 10
%12 = trunc i32 %10 to i8
%13 = select i1 %11, i8 48, i8 55
%14 = add i8 %13, %12
%15 = getelementptr inbounds i8, i8* %2, i64 %7
store i8 %14, i8* %15, align 1
%16 = icmp sgt i64 %5, 1
br i1 %16, label %4, label %17
17: ; preds = %4
ret void
}