llvm.org GIT mirror llvm / release_60 test / CodeGen / X86 / tail-call-conditional.mir
release_60

Tree @release_60 (Download .tar.gz)

tail-call-conditional.mir @release_60raw · history · blame

# 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:
  - { reg: '%rdi' }
  - { reg: '%rsi' }
body:             |
  bb.0:
    successors: %bb.1, %bb.4
    liveins: %rdi, %rsi

    %rax = COPY %rdi
    CMP64ri8 %rax, 99, implicit-def %eflags
    JA_1 %bb.4, implicit %eflags
    JMP_1 %bb.1

  ; CHECK: bb.1:
  ; CHECK-NEXT: successors: %bb.2({{[^)]+}}){{$}}
  ; CHECK-NEXT: liveins: %rax, %rsi
  ; CHECK-NEXT: {{^  $}}
  ; CHECK-NEXT: %rdi = COPY %rsi
  ; CHECK-NEXT: %rsi = COPY %rax
  ; CHECK-NEXT: CMP64ri8 %rax, 9, implicit-def %eflags
  ; 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 %sil, implicit-def %sil, implicit %si, implicit-def %si, implicit %esi, implicit-def %esi, implicit %rsi, implicit-def %rsi, implicit %dil, implicit-def %dil, implicit %di, implicit-def %di, implicit %edi, implicit-def %edi, implicit %rdi, implicit-def %rdi, implicit %ah, implicit-def %ah, implicit %al, implicit-def %al, implicit %ax, implicit-def %ax, implicit %eax, implicit-def %eax

  bb.1:
    successors: %bb.2, %bb.3
    liveins: %rax, %rsi

    CMP64ri8 %rax, 9, implicit-def %eflags
    JA_1 %bb.3, implicit %eflags
    JMP_1 %bb.2

  bb.2:
    liveins: %rax, %rsi

    %rdi = COPY %rsi
    %rsi = COPY %rax

    TCRETURNdi64 @f1, 0, csr_64, implicit %rsp, implicit %rdi, implicit %rsi

  ; CHECK: bb.2:
  ; CHECK-NEXT: liveins: %rax, %rdi, %rsi
  ; CHECK-NEXT: {{^  $}}
  ; CHECK-NEXT: TCRETURNdi64 @f2, 0, csr_64, implicit %rsp, implicit %rdi, implicit %rsi

  bb.3:
    liveins: %rax, %rsi

    %rdi = COPY %rsi
    %rsi = COPY %rax
    TCRETURNdi64 @f2, 0, csr_64, implicit %rsp, implicit %rdi, implicit %rsi

  bb.4:
    dead %eax = MOV32ri64 123, implicit-def %rax
    RET 0, %rax

...