llvm/llvm/test/CodeGen/X86/tailcall-range.ll

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4
; RUN: llc -mtriple=x86_64-linux < %s | FileCheck %s

define range(i32 0, 2) i32 @foo(ptr %this) {
; CHECK-LABEL: foo:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    movzbl (%rdi), %eax
; CHECK-NEXT:    retq
entry:
  %call = load volatile i1, ptr %this, align 1
  %spec.select = zext i1 %call to i32
  ret i32 %spec.select
}

define range(i32 0, 2) i32 @bar(ptr %this) {
; CHECK-LABEL: bar:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    xorl %edi, %edi
; CHECK-NEXT:    jmp foo@PLT # TAILCALL
entry:
  %ret = musttail call i32 @foo(ptr null)
  ret i32 %ret
}

declare i64 @llvm.llround.f32(float) nounwind readnone
define range(i64 0, 8) i64 @testmsxs(float %x) {
; CHECK-LABEL: testmsxs:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    jmp llroundf@PLT # TAILCALL
entry:
  %ret = tail call i64 @llvm.llround.f32(float %x)
  ret i64 %ret
}

declare i32 @callee()

define range(i32 0, 2) i32 @func_with_range_attr() {
; CHECK-LABEL: func_with_range_attr:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    jmp callee@PLT # TAILCALL
entry:
  %ret = musttail call i32 @callee()
  ret i32 %ret
}

define i32 @call_with_range_attr() {
; CHECK-LABEL: call_with_range_attr:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    jmp callee@PLT # TAILCALL
entry:
  %ret = musttail call range(i32 0, 2) i32 @callee()
  ret i32 %ret
}