llvm/llvm/test/CodeGen/X86/isel-x87.ll

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc < %s -mtriple=i686-- -mattr=+x87,-sse,-sse2 -global-isel | FileCheck %s --check-prefixes=CHECK-32,GISEL_X86
; RUN: llc < %s -mtriple=i686-- -mattr=+x87,-sse,-sse2 | FileCheck %s --check-prefixes=CHECK-32,SDAG_X86
; RUN: llc < %s -mtriple=i686-- -mattr=+x87,-sse,-sse2 -fast-isel=true | FileCheck %s --check-prefixes=CHECK-32,SDAG_X86,FAST_X86
; RUN: llc < %s -mtriple=x86_64-- -mattr=+x87,-sse,-sse2 -global-isel | FileCheck %s --check-prefixes=CHECK-64,GISEL_X64
; RUN: llc < %s -mtriple=x86_64-- -mattr=+x87,-sse,-sse2 | FileCheck %s --check-prefixes=CHECK-64,SDAG_X64
; RUN: llc < %s -mtriple=x86_64-- -mattr=+x87,-sse,-sse2 -fast-isel=true | FileCheck %s --check-prefixes=CHECK-64,SDAG_X64,FAST_X64

define x86_fp80 @f0(x86_fp80 noundef %a) nounwind {
; GISEL_X86-LABEL: f0:
; GISEL_X86:       # %bb.0:
; GISEL_X86-NEXT:    pushl %ebp
; GISEL_X86-NEXT:    movl %esp, %ebp
; GISEL_X86-NEXT:    andl $-16, %esp
; GISEL_X86-NEXT:    subl $48, %esp
; GISEL_X86-NEXT:    fldt 8(%ebp)
; GISEL_X86-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}
; GISEL_X86-NEXT:    fxch %st(1)
; GISEL_X86-NEXT:    fstpt {{[0-9]+}}(%esp)
; GISEL_X86-NEXT:    fstpt (%esp)
; GISEL_X86-NEXT:    fldt {{[0-9]+}}(%esp)
; GISEL_X86-NEXT:    fldt (%esp)
; GISEL_X86-NEXT:    faddp %st, %st(1)
; GISEL_X86-NEXT:    movl %ebp, %esp
; GISEL_X86-NEXT:    popl %ebp
; GISEL_X86-NEXT:    retl
;
; SDAG_X86-LABEL: f0:
; SDAG_X86:       # %bb.0:
; SDAG_X86-NEXT:    pushl %ebp
; SDAG_X86-NEXT:    movl %esp, %ebp
; SDAG_X86-NEXT:    andl $-16, %esp
; SDAG_X86-NEXT:    subl $48, %esp
; SDAG_X86-NEXT:    fldt 8(%ebp)
; SDAG_X86-NEXT:    fld %st(0)
; SDAG_X86-NEXT:    fstpt {{[0-9]+}}(%esp)
; SDAG_X86-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
; SDAG_X86-NEXT:    fld %st(0)
; SDAG_X86-NEXT:    fstpt (%esp)
; SDAG_X86-NEXT:    faddp %st, %st(1)
; SDAG_X86-NEXT:    movl %ebp, %esp
; SDAG_X86-NEXT:    popl %ebp
; SDAG_X86-NEXT:    retl
;
; GISEL_X64-LABEL: f0:
; GISEL_X64:       # %bb.0:
; GISEL_X64-NEXT:    fldt {{[0-9]+}}(%rsp)
; GISEL_X64-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
; GISEL_X64-NEXT:    fxch %st(1)
; GISEL_X64-NEXT:    fstpt -{{[0-9]+}}(%rsp)
; GISEL_X64-NEXT:    fstpt -{{[0-9]+}}(%rsp)
; GISEL_X64-NEXT:    fldt -{{[0-9]+}}(%rsp)
; GISEL_X64-NEXT:    fldt -{{[0-9]+}}(%rsp)
; GISEL_X64-NEXT:    faddp %st, %st(1)
; GISEL_X64-NEXT:    retq
;
; SDAG_X64-LABEL: f0:
; SDAG_X64:       # %bb.0:
; SDAG_X64-NEXT:    fldt {{[0-9]+}}(%rsp)
; SDAG_X64-NEXT:    fld %st(0)
; SDAG_X64-NEXT:    fstpt -{{[0-9]+}}(%rsp)
; SDAG_X64-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
; SDAG_X64-NEXT:    fld %st(0)
; SDAG_X64-NEXT:    fstpt -{{[0-9]+}}(%rsp)
; SDAG_X64-NEXT:    faddp %st, %st(1)
; SDAG_X64-NEXT:    retq
  %a.addr = alloca x86_fp80, align 16
  %x = alloca x86_fp80, align 16
  store x86_fp80 %a, ptr %a.addr, align 16
  store x86_fp80 0xK400A8000000000000000, ptr %x, align 16
  %load1 = load x86_fp80, ptr %a.addr, align 16
  %load2 = load x86_fp80, ptr %x, align 16
  %add = fadd x86_fp80 %load1, %load2
  ret x86_fp80 %add
}


define void @f1(ptr %a, ptr %b) nounwind {
; GISEL_X86-LABEL: f1:
; GISEL_X86:       # %bb.0:
; GISEL_X86-NEXT:    movl {{[0-9]+}}(%esp), %eax
; GISEL_X86-NEXT:    movl {{[0-9]+}}(%esp), %ecx
; GISEL_X86-NEXT:    fldt (%eax)
; GISEL_X86-NEXT:    fldt (%ecx)
; GISEL_X86-NEXT:    fsubrp %st, %st(1)
; GISEL_X86-NEXT:    fstpt (%eax)
; GISEL_X86-NEXT:    retl
;
; SDAG_X86-LABEL: f1:
; SDAG_X86:       # %bb.0:
; SDAG_X86-NEXT:    movl {{[0-9]+}}(%esp), %eax
; SDAG_X86-NEXT:    movl {{[0-9]+}}(%esp), %ecx
; SDAG_X86-NEXT:    fldt (%ecx)
; SDAG_X86-NEXT:    fldt (%eax)
; SDAG_X86-NEXT:    fsubrp %st, %st(1)
; SDAG_X86-NEXT:    fstpt (%ecx)
; SDAG_X86-NEXT:    retl
;
; CHECK-64-LABEL: f1:
; CHECK-64:       # %bb.0:
; CHECK-64-NEXT:    fldt (%rdi)
; CHECK-64-NEXT:    fldt (%rsi)
; CHECK-64-NEXT:    fsubrp %st, %st(1)
; CHECK-64-NEXT:    fstpt (%rdi)
; CHECK-64-NEXT:    retq
  %load1 = load x86_fp80, ptr %a, align 4
  %load2 = load x86_fp80, ptr %b, align 4
  %sub = fsub x86_fp80 %load1, %load2
  store x86_fp80 %sub, ptr %a, align 4
  ret void
}

define void @f2(ptr %a, ptr %b) nounwind {
; GISEL_X86-LABEL: f2:
; GISEL_X86:       # %bb.0:
; GISEL_X86-NEXT:    movl {{[0-9]+}}(%esp), %eax
; GISEL_X86-NEXT:    movl {{[0-9]+}}(%esp), %ecx
; GISEL_X86-NEXT:    fldt (%eax)
; GISEL_X86-NEXT:    fldt (%ecx)
; GISEL_X86-NEXT:    fmulp %st, %st(1)
; GISEL_X86-NEXT:    fstpt (%eax)
; GISEL_X86-NEXT:    retl
;
; SDAG_X86-LABEL: f2:
; SDAG_X86:       # %bb.0:
; SDAG_X86-NEXT:    movl {{[0-9]+}}(%esp), %eax
; SDAG_X86-NEXT:    movl {{[0-9]+}}(%esp), %ecx
; SDAG_X86-NEXT:    fldt (%ecx)
; SDAG_X86-NEXT:    fldt (%eax)
; SDAG_X86-NEXT:    fmulp %st, %st(1)
; SDAG_X86-NEXT:    fstpt (%ecx)
; SDAG_X86-NEXT:    retl
;
; CHECK-64-LABEL: f2:
; CHECK-64:       # %bb.0:
; CHECK-64-NEXT:    fldt (%rdi)
; CHECK-64-NEXT:    fldt (%rsi)
; CHECK-64-NEXT:    fmulp %st, %st(1)
; CHECK-64-NEXT:    fstpt (%rdi)
; CHECK-64-NEXT:    retq
  %load1 = load x86_fp80, ptr %a, align 16
  %load2 = load x86_fp80, ptr %b, align 16
  %mul = fmul x86_fp80 %load1, %load2
  store x86_fp80 %mul, ptr %a, align 16
  ret void
}

define void @f3(ptr %a, ptr %b) nounwind {
; GISEL_X86-LABEL: f3:
; GISEL_X86:       # %bb.0:
; GISEL_X86-NEXT:    movl {{[0-9]+}}(%esp), %eax
; GISEL_X86-NEXT:    movl {{[0-9]+}}(%esp), %ecx
; GISEL_X86-NEXT:    fldt (%eax)
; GISEL_X86-NEXT:    fldt (%ecx)
; GISEL_X86-NEXT:    fdivrp %st, %st(1)
; GISEL_X86-NEXT:    fstpt (%eax)
; GISEL_X86-NEXT:    retl
;
; SDAG_X86-LABEL: f3:
; SDAG_X86:       # %bb.0:
; SDAG_X86-NEXT:    movl {{[0-9]+}}(%esp), %eax
; SDAG_X86-NEXT:    movl {{[0-9]+}}(%esp), %ecx
; SDAG_X86-NEXT:    fldt (%ecx)
; SDAG_X86-NEXT:    fldt (%eax)
; SDAG_X86-NEXT:    fdivrp %st, %st(1)
; SDAG_X86-NEXT:    fstpt (%ecx)
; SDAG_X86-NEXT:    retl
;
; CHECK-64-LABEL: f3:
; CHECK-64:       # %bb.0:
; CHECK-64-NEXT:    fldt (%rdi)
; CHECK-64-NEXT:    fldt (%rsi)
; CHECK-64-NEXT:    fdivrp %st, %st(1)
; CHECK-64-NEXT:    fstpt (%rdi)
; CHECK-64-NEXT:    retq
  %load1 = load x86_fp80, ptr %a, align 4
  %load2 = load x86_fp80, ptr %b, align 4
  %div = fdiv x86_fp80 %load1, %load2
  store x86_fp80 %div, ptr %a, align 4
  ret void
}

define void @f6(ptr %a, ptr %b) nounwind {
; GISEL_X86-LABEL: f6:
; GISEL_X86:       # %bb.0:
; GISEL_X86-NEXT:    movl {{[0-9]+}}(%esp), %eax
; GISEL_X86-NEXT:    movl {{[0-9]+}}(%esp), %ecx
; GISEL_X86-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
; GISEL_X86-NEXT:    flds (%eax)
; GISEL_X86-NEXT:    faddp %st, %st(1)
; GISEL_X86-NEXT:    fstps (%ecx)
; GISEL_X86-NEXT:    retl
;
; SDAG_X86-LABEL: f6:
; SDAG_X86:       # %bb.0:
; SDAG_X86-NEXT:    movl {{[0-9]+}}(%esp), %eax
; SDAG_X86-NEXT:    movl {{[0-9]+}}(%esp), %ecx
; SDAG_X86-NEXT:    flds (%ecx)
; SDAG_X86-NEXT:    fadds {{\.?LCPI[0-9]+_[0-9]+}}
; SDAG_X86-NEXT:    fstps (%eax)
; SDAG_X86-NEXT:    retl
;
; GISEL_X64-LABEL: f6:
; GISEL_X64:       # %bb.0:
; GISEL_X64-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
; GISEL_X64-NEXT:    flds (%rdi)
; GISEL_X64-NEXT:    faddp %st, %st(1)
; GISEL_X64-NEXT:    fstps (%rsi)
; GISEL_X64-NEXT:    retq
;
; SDAG_X64-LABEL: f6:
; SDAG_X64:       # %bb.0:
; SDAG_X64-NEXT:    flds (%rdi)
; SDAG_X64-NEXT:    fadds {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
; SDAG_X64-NEXT:    fstps (%rsi)
; SDAG_X64-NEXT:    retq
  %load1 = load float, ptr %a
  %add = fadd float %load1, 20.0
  store float %add, ptr %b
  ret void
}
;; NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line:
; CHECK-32: {{.*}}
; FAST_X64: {{.*}}
; FAST_X86: {{.*}}