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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc -mtriple=riscv64 -regalloc-csr-first-time-cost=0 < %s | FileCheck %s -check-prefix=ZERO-COST
; RUN: llc -mtriple=riscv64 < %s | FileCheck %s -check-prefix=DEFAULT-COST
define fastcc void @Perl_sv_setnv(i8 %c, ptr %.str.54.3682) nounwind {
; ZERO-COST-LABEL: Perl_sv_setnv:
; ZERO-COST: # %bb.0: # %entry
; ZERO-COST-NEXT: addi sp, sp, -32
; ZERO-COST-NEXT: sd ra, 24(sp) # 8-byte Folded Spill
; ZERO-COST-NEXT: sd s0, 16(sp) # 8-byte Folded Spill
; ZERO-COST-NEXT: sd s1, 8(sp) # 8-byte Folded Spill
; ZERO-COST-NEXT: zext.b a0, a0
; ZERO-COST-NEXT: li a2, 2
; ZERO-COST-NEXT: blt a2, a0, .LBB0_3
; ZERO-COST-NEXT: # %bb.1: # %entry
; ZERO-COST-NEXT: beqz a0, .LBB0_4
; ZERO-COST-NEXT: # %bb.2: # %entry
; ZERO-COST-NEXT: mv s0, a1
; ZERO-COST-NEXT: li a1, 1
; ZERO-COST-NEXT: beq a0, a1, .LBB0_6
; ZERO-COST-NEXT: j .LBB0_7
; ZERO-COST-NEXT: .LBB0_3: # %entry
; ZERO-COST-NEXT: li a2, 3
; ZERO-COST-NEXT: bne a0, a2, .LBB0_5
; ZERO-COST-NEXT: .LBB0_4: # %sw.bb3
; ZERO-COST-NEXT: ld ra, 24(sp) # 8-byte Folded Reload
; ZERO-COST-NEXT: ld s0, 16(sp) # 8-byte Folded Reload
; ZERO-COST-NEXT: ld s1, 8(sp) # 8-byte Folded Reload
; ZERO-COST-NEXT: addi sp, sp, 32
; ZERO-COST-NEXT: ret
; ZERO-COST-NEXT: .LBB0_5: # %entry
; ZERO-COST-NEXT: mv s0, a1
; ZERO-COST-NEXT: li a1, 12
; ZERO-COST-NEXT: bne a0, a1, .LBB0_7
; ZERO-COST-NEXT: .LBB0_6: # %sw.bb34.i
; ZERO-COST-NEXT: li s0, 0
; ZERO-COST-NEXT: .LBB0_7: # %Perl_sv_reftype.exit
; ZERO-COST-NEXT: li s1, 0
; ZERO-COST-NEXT: li a0, 0
; ZERO-COST-NEXT: li a1, 0
; ZERO-COST-NEXT: jalr s1
; ZERO-COST-NEXT: li a0, 0
; ZERO-COST-NEXT: mv a1, s0
; ZERO-COST-NEXT: li a2, 0
; ZERO-COST-NEXT: jalr s1
;
; DEFAULT-COST-LABEL: Perl_sv_setnv:
; DEFAULT-COST: # %bb.0: # %entry
; DEFAULT-COST-NEXT: addi sp, sp, -32
; DEFAULT-COST-NEXT: sd ra, 24(sp) # 8-byte Folded Spill
; DEFAULT-COST-NEXT: sd s0, 16(sp) # 8-byte Folded Spill
; DEFAULT-COST-NEXT: zext.b a0, a0
; DEFAULT-COST-NEXT: li a2, 2
; DEFAULT-COST-NEXT: blt a2, a0, .LBB0_3
; DEFAULT-COST-NEXT: # %bb.1: # %entry
; DEFAULT-COST-NEXT: beqz a0, .LBB0_4
; DEFAULT-COST-NEXT: # %bb.2: # %entry
; DEFAULT-COST-NEXT: sd a1, 8(sp) # 8-byte Folded Spill
; DEFAULT-COST-NEXT: li a1, 1
; DEFAULT-COST-NEXT: beq a0, a1, .LBB0_6
; DEFAULT-COST-NEXT: j .LBB0_7
; DEFAULT-COST-NEXT: .LBB0_3: # %entry
; DEFAULT-COST-NEXT: li a2, 3
; DEFAULT-COST-NEXT: bne a0, a2, .LBB0_5
; DEFAULT-COST-NEXT: .LBB0_4: # %sw.bb3
; DEFAULT-COST-NEXT: ld ra, 24(sp) # 8-byte Folded Reload
; DEFAULT-COST-NEXT: ld s0, 16(sp) # 8-byte Folded Reload
; DEFAULT-COST-NEXT: addi sp, sp, 32
; DEFAULT-COST-NEXT: ret
; DEFAULT-COST-NEXT: .LBB0_5: # %entry
; DEFAULT-COST-NEXT: sd a1, 8(sp) # 8-byte Folded Spill
; DEFAULT-COST-NEXT: li a1, 12
; DEFAULT-COST-NEXT: bne a0, a1, .LBB0_7
; DEFAULT-COST-NEXT: .LBB0_6: # %sw.bb34.i
; DEFAULT-COST-NEXT: sd zero, 8(sp) # 8-byte Folded Spill
; DEFAULT-COST-NEXT: .LBB0_7: # %Perl_sv_reftype.exit
; DEFAULT-COST-NEXT: li s0, 0
; DEFAULT-COST-NEXT: li a0, 0
; DEFAULT-COST-NEXT: li a1, 0
; DEFAULT-COST-NEXT: jalr s0
; DEFAULT-COST-NEXT: li a0, 0
; DEFAULT-COST-NEXT: ld a1, 8(sp) # 8-byte Folded Reload
; DEFAULT-COST-NEXT: li a2, 0
; DEFAULT-COST-NEXT: jalr s0
entry:
switch i8 %c, label %Perl_sv_reftype.exit [
i8 1, label %sw.bb4
i8 12, label %sw.bb34.i
i8 3, label %sw.bb3
i8 0, label %sw.bb3
]
sw.bb3: ; preds = %entry, %entry
ret void
sw.bb4: ; preds = %entry
br label %Perl_sv_reftype.exit
sw.bb34.i: ; preds = %entry
br label %Perl_sv_reftype.exit
Perl_sv_reftype.exit: ; preds = %sw.bb34.i, %sw.bb4, %entry
%retval.0.i = phi ptr [ null, %sw.bb34.i ], [ null, %sw.bb4 ], [ %.str.54.3682, %entry ]
%call17 = tail call fastcc i64 null(ptr null, i32 0)
tail call void (ptr, ...) null(ptr null, ptr %retval.0.i, ptr null)
unreachable
}
|