2017-02-16 08:04:05 +08:00
|
|
|
# RUN: llc -mtriple x86_64-- -verify-machineinstrs -run-pass branch-folder -o - %s | FileCheck %s
|
|
|
|
|
|
|
|
# Check the TCRETURNdi64cc optimization.
|
|
|
|
|
|
|
|
--- |
|
|
|
|
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
|
|
|
|
|
|
|
|
define i64 @test(i64 %arg, i8* %arg1) optsize {
|
|
|
|
%tmp = icmp ult i64 %arg, 100
|
|
|
|
br i1 %tmp, label %1, label %4
|
|
|
|
|
|
|
|
%tmp3 = icmp ult i64 %arg, 10
|
|
|
|
br i1 %tmp3, label %2, label %3
|
|
|
|
|
|
|
|
%tmp5 = tail call i64 @f1(i8* %arg1, i64 %arg)
|
|
|
|
ret i64 %tmp5
|
|
|
|
|
|
|
|
%tmp7 = tail call i64 @f2(i8* %arg1, i64 %arg)
|
|
|
|
ret i64 %tmp7
|
|
|
|
|
|
|
|
ret i64 123
|
|
|
|
}
|
|
|
|
|
|
|
|
declare i64 @f1(i8*, i64)
|
|
|
|
declare i64 @f2(i8*, i64)
|
|
|
|
|
|
|
|
...
|
|
|
|
---
|
|
|
|
name: test
|
|
|
|
tracksRegLiveness: true
|
|
|
|
liveins:
|
2018-02-01 06:04:26 +08:00
|
|
|
- { reg: '$rdi' }
|
|
|
|
- { reg: '$rsi' }
|
2017-02-16 08:04:05 +08:00
|
|
|
body: |
|
|
|
|
bb.0:
|
|
|
|
successors: %bb.1, %bb.4
|
2018-02-01 06:04:26 +08:00
|
|
|
liveins: $rdi, $rsi
|
2017-02-16 08:04:05 +08:00
|
|
|
|
2018-02-01 06:04:26 +08:00
|
|
|
$rax = COPY $rdi
|
|
|
|
CMP64ri8 $rax, 99, implicit-def $eflags
|
|
|
|
JA_1 %bb.4, implicit $eflags
|
2017-02-16 08:04:05 +08:00
|
|
|
JMP_1 %bb.1
|
|
|
|
|
|
|
|
; CHECK: bb.1:
|
|
|
|
; CHECK-NEXT: successors: %bb.2({{[^)]+}}){{$}}
|
2018-02-01 06:04:26 +08:00
|
|
|
; CHECK-NEXT: liveins: $rax, $rsi
|
2017-02-16 08:04:05 +08:00
|
|
|
; CHECK-NEXT: {{^ $}}
|
2018-02-01 06:04:26 +08:00
|
|
|
; CHECK-NEXT: $rdi = COPY $rsi
|
|
|
|
; CHECK-NEXT: $rsi = COPY $rax
|
|
|
|
; CHECK-NEXT: CMP64ri8 $rax, 9, implicit-def $eflags
|
2018-03-21 02:46:55 +08:00
|
|
|
; CHECK-NEXT: TCRETURNdi64cc @f1, 0, 3, csr_64, implicit $rsp, implicit $eflags, implicit $ssp, implicit $rsp, implicit $rdi, implicit $rsi, implicit $rax, implicit-def $rax, implicit $hsi, implicit-def $hsi, implicit $sil, implicit-def $sil, implicit $si, implicit-def $si, implicit $esi, implicit-def $esi, implicit $rsi, implicit-def $rsi, implicit $hdi, implicit-def $hdi, implicit $dil, implicit-def $dil, implicit $di, implicit-def $di, implicit $edi, implicit-def $edi, implicit $rdi, implicit-def $rdi, implicit $hax, implicit-def $hax, implicit $ah, implicit-def $ah, implicit $al, implicit-def $al, implicit $ax, implicit-def $ax, implicit $eax, implicit-def $eax
|
2017-02-16 08:04:05 +08:00
|
|
|
|
|
|
|
bb.1:
|
|
|
|
successors: %bb.2, %bb.3
|
2018-02-01 06:04:26 +08:00
|
|
|
liveins: $rax, $rsi
|
2017-02-16 08:04:05 +08:00
|
|
|
|
2018-02-01 06:04:26 +08:00
|
|
|
CMP64ri8 $rax, 9, implicit-def $eflags
|
|
|
|
JA_1 %bb.3, implicit $eflags
|
2017-02-16 08:04:05 +08:00
|
|
|
JMP_1 %bb.2
|
|
|
|
|
|
|
|
bb.2:
|
2018-02-01 06:04:26 +08:00
|
|
|
liveins: $rax, $rsi
|
2017-02-16 08:04:05 +08:00
|
|
|
|
2018-02-01 06:04:26 +08:00
|
|
|
$rdi = COPY $rsi
|
|
|
|
$rsi = COPY $rax
|
2017-02-16 08:04:05 +08:00
|
|
|
|
2018-02-01 06:04:26 +08:00
|
|
|
TCRETURNdi64 @f1, 0, csr_64, implicit $rsp, implicit $rdi, implicit $rsi
|
2017-02-16 08:04:05 +08:00
|
|
|
|
|
|
|
; CHECK: bb.2:
|
2018-02-01 06:04:26 +08:00
|
|
|
; CHECK-NEXT: liveins: $rax, $rdi, $rsi
|
2017-02-16 08:04:05 +08:00
|
|
|
; CHECK-NEXT: {{^ $}}
|
2018-02-01 06:04:26 +08:00
|
|
|
; CHECK-NEXT: TCRETURNdi64 @f2, 0, csr_64, implicit $rsp, implicit $rdi, implicit $rsi
|
2017-02-16 08:04:05 +08:00
|
|
|
|
|
|
|
bb.3:
|
2018-02-01 06:04:26 +08:00
|
|
|
liveins: $rax, $rsi
|
2017-02-16 08:04:05 +08:00
|
|
|
|
2018-02-01 06:04:26 +08:00
|
|
|
$rdi = COPY $rsi
|
|
|
|
$rsi = COPY $rax
|
|
|
|
TCRETURNdi64 @f2, 0, csr_64, implicit $rsp, implicit $rdi, implicit $rsi
|
2017-02-16 08:04:05 +08:00
|
|
|
|
|
|
|
bb.4:
|
2018-02-01 06:04:26 +08:00
|
|
|
dead $eax = MOV32ri64 123, implicit-def $rax
|
|
|
|
RET 0, $rax
|
2017-02-16 08:04:05 +08:00
|
|
|
|
|
|
|
...
|