; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc --mtriple=loongarch32 --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA32S ; RUN: llc --mtriple=loongarch32 --mattr=+f -target-abi=ilp32s --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA32F-ILP32S ; RUN: llc --mtriple=loongarch32 --mattr=+f -target-abi=ilp32d --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA32F-ILP32D ; RUN: llc --mtriple=loongarch32 --mattr=+d -target-abi=ilp32s --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA32D-ILP32S ; RUN: llc --mtriple=loongarch32 --mattr=+d -target-abi=ilp32d --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA32D-ILP32D ; RUN: llc --mtriple=loongarch64 --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA64S ; RUN: llc --mtriple=loongarch64 --mattr=+f -target-abi=lp64s --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA64F-LP64S ; RUN: llc --mtriple=loongarch64 --mattr=+f -target-abi=lp64d --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA64F-LP64D ; RUN: llc --mtriple=loongarch64 --mattr=+d -target-abi=lp64s --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA64D-LP64S ; RUN: llc --mtriple=loongarch64 --mattr=+d -target-abi=lp64d --verify-machineinstrs < %s | FileCheck %s --check-prefix=LA64D-LP64D define half @f(half %a, half %b, half %c) { ; LA32S-LABEL: f: ; LA32S: # %bb.0: ; LA32S-NEXT: addi.w $sp, $sp, -32 ; LA32S-NEXT: .cfi_def_cfa_offset 32 ; LA32S-NEXT: st.w $ra, $sp, 28 # 4-byte Folded Spill ; LA32S-NEXT: st.w $fp, $sp, 24 # 4-byte Folded Spill ; LA32S-NEXT: st.w $s0, $sp, 20 # 4-byte Folded Spill ; LA32S-NEXT: st.w $s1, $sp, 16 # 4-byte Folded Spill ; LA32S-NEXT: st.w $s2, $sp, 12 # 4-byte Folded Spill ; LA32S-NEXT: .cfi_offset 1, -4 ; LA32S-NEXT: .cfi_offset 22, -8 ; LA32S-NEXT: .cfi_offset 23, -12 ; LA32S-NEXT: .cfi_offset 24, -16 ; LA32S-NEXT: .cfi_offset 25, -20 ; LA32S-NEXT: move $fp, $a2 ; LA32S-NEXT: move $s0, $a1 ; LA32S-NEXT: lu12i.w $a1, 15 ; LA32S-NEXT: ori $s2, $a1, 4095 ; LA32S-NEXT: and $a0, $a0, $s2 ; LA32S-NEXT: bl __extendhfsf2 ; LA32S-NEXT: move $s1, $a0 ; LA32S-NEXT: and $a0, $s0, $s2 ; LA32S-NEXT: bl __extendhfsf2 ; LA32S-NEXT: move $a1, $a0 ; LA32S-NEXT: move $a0, $s1 ; LA32S-NEXT: bl __addsf3 ; LA32S-NEXT: bl __truncsfhf2 ; LA32S-NEXT: move $s0, $a0 ; LA32S-NEXT: and $a0, $fp, $s2 ; LA32S-NEXT: bl __extendhfsf2 ; LA32S-NEXT: move $fp, $a0 ; LA32S-NEXT: and $a0, $s0, $s2 ; LA32S-NEXT: bl __extendhfsf2 ; LA32S-NEXT: move $a1, $fp ; LA32S-NEXT: bl __addsf3 ; LA32S-NEXT: bl __truncsfhf2 ; LA32S-NEXT: ld.w $s2, $sp, 12 # 4-byte Folded Reload ; LA32S-NEXT: ld.w $s1, $sp, 16 # 4-byte Folded Reload ; LA32S-NEXT: ld.w $s0, $sp, 20 # 4-byte Folded Reload ; LA32S-NEXT: ld.w $fp, $sp, 24 # 4-byte Folded Reload ; LA32S-NEXT: ld.w $ra, $sp, 28 # 4-byte Folded Reload ; LA32S-NEXT: addi.w $sp, $sp, 32 ; LA32S-NEXT: ret ; ; LA32F-ILP32S-LABEL: f: ; LA32F-ILP32S: # %bb.0: ; LA32F-ILP32S-NEXT: addi.w $sp, $sp, -16 ; LA32F-ILP32S-NEXT: .cfi_def_cfa_offset 16 ; LA32F-ILP32S-NEXT: st.w $ra, $sp, 12 # 4-byte Folded Spill ; LA32F-ILP32S-NEXT: st.w $fp, $sp, 8 # 4-byte Folded Spill ; LA32F-ILP32S-NEXT: st.w $s0, $sp, 4 # 4-byte Folded Spill ; LA32F-ILP32S-NEXT: .cfi_offset 1, -4 ; LA32F-ILP32S-NEXT: .cfi_offset 22, -8 ; LA32F-ILP32S-NEXT: .cfi_offset 23, -12 ; LA32F-ILP32S-NEXT: move $fp, $a2 ; LA32F-ILP32S-NEXT: move $s0, $a0 ; LA32F-ILP32S-NEXT: move $a0, $a1 ; LA32F-ILP32S-NEXT: bl __extendhfsf2 ; LA32F-ILP32S-NEXT: movgr2fr.w $fa0, $a0 ; LA32F-ILP32S-NEXT: fst.s $fa0, $sp, 0 # 4-byte Folded Spill ; LA32F-ILP32S-NEXT: move $a0, $s0 ; LA32F-ILP32S-NEXT: bl __extendhfsf2 ; LA32F-ILP32S-NEXT: movgr2fr.w $fa0, $a0 ; LA32F-ILP32S-NEXT: fld.s $fa1, $sp, 0 # 4-byte Folded Reload ; LA32F-ILP32S-NEXT: fadd.s $fa0, $fa0, $fa1 ; LA32F-ILP32S-NEXT: movfr2gr.s $a0, $fa0 ; LA32F-ILP32S-NEXT: bl __truncsfhf2 ; LA32F-ILP32S-NEXT: bl __extendhfsf2 ; LA32F-ILP32S-NEXT: movgr2fr.w $fa0, $a0 ; LA32F-ILP32S-NEXT: fst.s $fa0, $sp, 0 # 4-byte Folded Spill ; LA32F-ILP32S-NEXT: move $a0, $fp ; LA32F-ILP32S-NEXT: bl __extendhfsf2 ; LA32F-ILP32S-NEXT: movgr2fr.w $fa0, $a0 ; LA32F-ILP32S-NEXT: fld.s $fa1, $sp, 0 # 4-byte Folded Reload ; LA32F-ILP32S-NEXT: fadd.s $fa0, $fa1, $fa0 ; LA32F-ILP32S-NEXT: movfr2gr.s $a0, $fa0 ; LA32F-ILP32S-NEXT: bl __truncsfhf2 ; LA32F-ILP32S-NEXT: lu12i.w $a1, -16 ; LA32F-ILP32S-NEXT: or $a0, $a0, $a1 ; LA32F-ILP32S-NEXT: ld.w $s0, $sp, 4 # 4-byte Folded Reload ; LA32F-ILP32S-NEXT: ld.w $fp, $sp, 8 # 4-byte Folded Reload ; LA32F-ILP32S-NEXT: ld.w $ra, $sp, 12 # 4-byte Folded Reload ; LA32F-ILP32S-NEXT: addi.w $sp, $sp, 16 ; LA32F-ILP32S-NEXT: ret ; ; LA32F-ILP32D-LABEL: f: ; LA32F-ILP32D: # %bb.0: ; LA32F-ILP32D-NEXT: addi.w $sp, $sp, -16 ; LA32F-ILP32D-NEXT: .cfi_def_cfa_offset 16 ; LA32F-ILP32D-NEXT: st.w $ra, $sp, 12 # 4-byte Folded Spill ; LA32F-ILP32D-NEXT: fst.s $fs0, $sp, 8 # 4-byte Folded Spill ; LA32F-ILP32D-NEXT: fst.s $fs1, $sp, 4 # 4-byte Folded Spill ; LA32F-ILP32D-NEXT: fst.s $fs2, $sp, 0 # 4-byte Folded Spill ; LA32F-ILP32D-NEXT: .cfi_offset 1, -4 ; LA32F-ILP32D-NEXT: .cfi_offset 56, -8 ; LA32F-ILP32D-NEXT: .cfi_offset 57, -12 ; LA32F-ILP32D-NEXT: .cfi_offset 58, -16 ; LA32F-ILP32D-NEXT: fmov.s $fs0, $fa2 ; LA32F-ILP32D-NEXT: fmov.s $fs1, $fa0 ; LA32F-ILP32D-NEXT: fmov.s $fa0, $fa1 ; LA32F-ILP32D-NEXT: bl __extendhfsf2 ; LA32F-ILP32D-NEXT: fmov.s $fs2, $fa0 ; LA32F-ILP32D-NEXT: fmov.s $fa0, $fs1 ; LA32F-ILP32D-NEXT: bl __extendhfsf2 ; LA32F-ILP32D-NEXT: fadd.s $fa0, $fa0, $fs2 ; LA32F-ILP32D-NEXT: bl __truncsfhf2 ; LA32F-ILP32D-NEXT: bl __extendhfsf2 ; LA32F-ILP32D-NEXT: fmov.s $fs1, $fa0 ; LA32F-ILP32D-NEXT: fmov.s $fa0, $fs0 ; LA32F-ILP32D-NEXT: bl __extendhfsf2 ; LA32F-ILP32D-NEXT: fadd.s $fa0, $fs1, $fa0 ; LA32F-ILP32D-NEXT: bl __truncsfhf2 ; LA32F-ILP32D-NEXT: movfr2gr.s $a0, $fa0 ; LA32F-ILP32D-NEXT: lu12i.w $a1, -16 ; LA32F-ILP32D-NEXT: or $a0, $a0, $a1 ; LA32F-ILP32D-NEXT: movgr2fr.w $fa0, $a0 ; LA32F-ILP32D-NEXT: fld.s $fs2, $sp, 0 # 4-byte Folded Reload ; LA32F-ILP32D-NEXT: fld.s $fs1, $sp, 4 # 4-byte Folded Reload ; LA32F-ILP32D-NEXT: fld.s $fs0, $sp, 8 # 4-byte Folded Reload ; LA32F-ILP32D-NEXT: ld.w $ra, $sp, 12 # 4-byte Folded Reload ; LA32F-ILP32D-NEXT: addi.w $sp, $sp, 16 ; LA32F-ILP32D-NEXT: ret ; ; LA32D-ILP32S-LABEL: f: ; LA32D-ILP32S: # %bb.0: ; LA32D-ILP32S-NEXT: addi.w $sp, $sp, -16 ; LA32D-ILP32S-NEXT: .cfi_def_cfa_offset 16 ; LA32D-ILP32S-NEXT: st.w $ra, $sp, 12 # 4-byte Folded Spill ; LA32D-ILP32S-NEXT: st.w $fp, $sp, 8 # 4-byte Folded Spill ; LA32D-ILP32S-NEXT: st.w $s0, $sp, 4 # 4-byte Folded Spill ; LA32D-ILP32S-NEXT: .cfi_offset 1, -4 ; LA32D-ILP32S-NEXT: .cfi_offset 22, -8 ; LA32D-ILP32S-NEXT: .cfi_offset 23, -12 ; LA32D-ILP32S-NEXT: move $fp, $a2 ; LA32D-ILP32S-NEXT: move $s0, $a0 ; LA32D-ILP32S-NEXT: move $a0, $a1 ; LA32D-ILP32S-NEXT: bl __extendhfsf2 ; LA32D-ILP32S-NEXT: movgr2fr.w $fa0, $a0 ; LA32D-ILP32S-NEXT: fst.s $fa0, $sp, 0 # 4-byte Folded Spill ; LA32D-ILP32S-NEXT: move $a0, $s0 ; LA32D-ILP32S-NEXT: bl __extendhfsf2 ; LA32D-ILP32S-NEXT: movgr2fr.w $fa0, $a0 ; LA32D-ILP32S-NEXT: fld.s $fa1, $sp, 0 # 4-byte Folded Reload ; LA32D-ILP32S-NEXT: fadd.s $fa0, $fa0, $fa1 ; LA32D-ILP32S-NEXT: movfr2gr.s $a0, $fa0 ; LA32D-ILP32S-NEXT: bl __truncsfhf2 ; LA32D-ILP32S-NEXT: bl __extendhfsf2 ; LA32D-ILP32S-NEXT: movgr2fr.w $fa0, $a0 ; LA32D-ILP32S-NEXT: fst.s $fa0, $sp, 0 # 4-byte Folded Spill ; LA32D-ILP32S-NEXT: move $a0, $fp ; LA32D-ILP32S-NEXT: bl __extendhfsf2 ; LA32D-ILP32S-NEXT: movgr2fr.w $fa0, $a0 ; LA32D-ILP32S-NEXT: fld.s $fa1, $sp, 0 # 4-byte Folded Reload ; LA32D-ILP32S-NEXT: fadd.s $fa0, $fa1, $fa0 ; LA32D-ILP32S-NEXT: movfr2gr.s $a0, $fa0 ; LA32D-ILP32S-NEXT: bl __truncsfhf2 ; LA32D-ILP32S-NEXT: lu12i.w $a1, -16 ; LA32D-ILP32S-NEXT: or $a0, $a0, $a1 ; LA32D-ILP32S-NEXT: ld.w $s0, $sp, 4 # 4-byte Folded Reload ; LA32D-ILP32S-NEXT: ld.w $fp, $sp, 8 # 4-byte Folded Reload ; LA32D-ILP32S-NEXT: ld.w $ra, $sp, 12 # 4-byte Folded Reload ; LA32D-ILP32S-NEXT: addi.w $sp, $sp, 16 ; LA32D-ILP32S-NEXT: ret ; ; LA32D-ILP32D-LABEL: f: ; LA32D-ILP32D: # %bb.0: ; LA32D-ILP32D-NEXT: addi.w $sp, $sp, -32 ; LA32D-ILP32D-NEXT: .cfi_def_cfa_offset 32 ; LA32D-ILP32D-NEXT: st.w $ra, $sp, 28 # 4-byte Folded Spill ; LA32D-ILP32D-NEXT: fst.d $fs0, $sp, 16 # 8-byte Folded Spill ; LA32D-ILP32D-NEXT: fst.d $fs1, $sp, 8 # 8-byte Folded Spill ; LA32D-ILP32D-NEXT: fst.d $fs2, $sp, 0 # 8-byte Folded Spill ; LA32D-ILP32D-NEXT: .cfi_offset 1, -4 ; LA32D-ILP32D-NEXT: .cfi_offset 56, -16 ; LA32D-ILP32D-NEXT: .cfi_offset 57, -24 ; LA32D-ILP32D-NEXT: .cfi_offset 58, -32 ; LA32D-ILP32D-NEXT: fmov.s $fs0, $fa2 ; LA32D-ILP32D-NEXT: fmov.s $fs1, $fa0 ; LA32D-ILP32D-NEXT: fmov.s $fa0, $fa1 ; LA32D-ILP32D-NEXT: bl __extendhfsf2 ; LA32D-ILP32D-NEXT: fmov.s $fs2, $fa0 ; LA32D-ILP32D-NEXT: fmov.s $fa0, $fs1 ; LA32D-ILP32D-NEXT: bl __extendhfsf2 ; LA32D-ILP32D-NEXT: fadd.s $fa0, $fa0, $fs2 ; LA32D-ILP32D-NEXT: bl __truncsfhf2 ; LA32D-ILP32D-NEXT: bl __extendhfsf2 ; LA32D-ILP32D-NEXT: fmov.s $fs1, $fa0 ; LA32D-ILP32D-NEXT: fmov.s $fa0, $fs0 ; LA32D-ILP32D-NEXT: bl __extendhfsf2 ; LA32D-ILP32D-NEXT: fadd.s $fa0, $fs1, $fa0 ; LA32D-ILP32D-NEXT: bl __truncsfhf2 ; LA32D-ILP32D-NEXT: movfr2gr.s $a0, $fa0 ; LA32D-ILP32D-NEXT: lu12i.w $a1, -16 ; LA32D-ILP32D-NEXT: or $a0, $a0, $a1 ; LA32D-ILP32D-NEXT: movgr2fr.w $fa0, $a0 ; LA32D-ILP32D-NEXT: fld.d $fs2, $sp, 0 # 8-byte Folded Reload ; LA32D-ILP32D-NEXT: fld.d $fs1, $sp, 8 # 8-byte Folded Reload ; LA32D-ILP32D-NEXT: fld.d $fs0, $sp, 16 # 8-byte Folded Reload ; LA32D-ILP32D-NEXT: ld.w $ra, $sp, 28 # 4-byte Folded Reload ; LA32D-ILP32D-NEXT: addi.w $sp, $sp, 32 ; LA32D-ILP32D-NEXT: ret ; ; LA64S-LABEL: f: ; LA64S: # %bb.0: ; LA64S-NEXT: addi.d $sp, $sp, -32 ; LA64S-NEXT: .cfi_def_cfa_offset 32 ; LA64S-NEXT: st.d $ra, $sp, 24 # 8-byte Folded Spill ; LA64S-NEXT: fst.d $fs0, $sp, 16 # 8-byte Folded Spill ; LA64S-NEXT: fst.d $fs1, $sp, 8 # 8-byte Folded Spill ; LA64S-NEXT: fst.d $fs2, $sp, 0 # 8-byte Folded Spill ; LA64S-NEXT: .cfi_offset 1, -8 ; LA64S-NEXT: .cfi_offset 56, -16 ; LA64S-NEXT: .cfi_offset 57, -24 ; LA64S-NEXT: .cfi_offset 58, -32 ; LA64S-NEXT: fmov.s $fs0, $fa2 ; LA64S-NEXT: fmov.s $fs1, $fa0 ; LA64S-NEXT: fmov.s $fa0, $fa1 ; LA64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64S-NEXT: jirl $ra, $ra, 0 ; LA64S-NEXT: fmov.s $fs2, $fa0 ; LA64S-NEXT: fmov.s $fa0, $fs1 ; LA64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64S-NEXT: jirl $ra, $ra, 0 ; LA64S-NEXT: fadd.s $fa0, $fa0, $fs2 ; LA64S-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64S-NEXT: jirl $ra, $ra, 0 ; LA64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64S-NEXT: jirl $ra, $ra, 0 ; LA64S-NEXT: fmov.s $fs1, $fa0 ; LA64S-NEXT: fmov.s $fa0, $fs0 ; LA64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64S-NEXT: jirl $ra, $ra, 0 ; LA64S-NEXT: fadd.s $fa0, $fs1, $fa0 ; LA64S-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64S-NEXT: jirl $ra, $ra, 0 ; LA64S-NEXT: movfr2gr.s $a0, $fa0 ; LA64S-NEXT: lu12i.w $a1, -16 ; LA64S-NEXT: or $a0, $a0, $a1 ; LA64S-NEXT: movgr2fr.w $fa0, $a0 ; LA64S-NEXT: fld.d $fs2, $sp, 0 # 8-byte Folded Reload ; LA64S-NEXT: fld.d $fs1, $sp, 8 # 8-byte Folded Reload ; LA64S-NEXT: fld.d $fs0, $sp, 16 # 8-byte Folded Reload ; LA64S-NEXT: ld.d $ra, $sp, 24 # 8-byte Folded Reload ; LA64S-NEXT: addi.d $sp, $sp, 32 ; LA64S-NEXT: ret ; ; LA64F-LP64S-LABEL: f: ; LA64F-LP64S: # %bb.0: ; LA64F-LP64S-NEXT: addi.d $sp, $sp, -32 ; LA64F-LP64S-NEXT: .cfi_def_cfa_offset 32 ; LA64F-LP64S-NEXT: st.d $ra, $sp, 24 # 8-byte Folded Spill ; LA64F-LP64S-NEXT: st.d $fp, $sp, 16 # 8-byte Folded Spill ; LA64F-LP64S-NEXT: st.d $s0, $sp, 8 # 8-byte Folded Spill ; LA64F-LP64S-NEXT: .cfi_offset 1, -8 ; LA64F-LP64S-NEXT: .cfi_offset 22, -16 ; LA64F-LP64S-NEXT: .cfi_offset 23, -24 ; LA64F-LP64S-NEXT: move $fp, $a2 ; LA64F-LP64S-NEXT: move $s0, $a0 ; LA64F-LP64S-NEXT: move $a0, $a1 ; LA64F-LP64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64F-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64S-NEXT: movgr2fr.w $fa0, $a0 ; LA64F-LP64S-NEXT: fst.s $fa0, $sp, 4 # 4-byte Folded Spill ; LA64F-LP64S-NEXT: move $a0, $s0 ; LA64F-LP64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64F-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64S-NEXT: movgr2fr.w $fa0, $a0 ; LA64F-LP64S-NEXT: fld.s $fa1, $sp, 4 # 4-byte Folded Reload ; LA64F-LP64S-NEXT: fadd.s $fa0, $fa0, $fa1 ; LA64F-LP64S-NEXT: movfr2gr.s $a0, $fa0 ; LA64F-LP64S-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64F-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64F-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64S-NEXT: movgr2fr.w $fa0, $a0 ; LA64F-LP64S-NEXT: fst.s $fa0, $sp, 4 # 4-byte Folded Spill ; LA64F-LP64S-NEXT: move $a0, $fp ; LA64F-LP64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64F-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64S-NEXT: movgr2fr.w $fa0, $a0 ; LA64F-LP64S-NEXT: fld.s $fa1, $sp, 4 # 4-byte Folded Reload ; LA64F-LP64S-NEXT: fadd.s $fa0, $fa1, $fa0 ; LA64F-LP64S-NEXT: movfr2gr.s $a0, $fa0 ; LA64F-LP64S-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64F-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64S-NEXT: lu12i.w $a1, -16 ; LA64F-LP64S-NEXT: or $a0, $a0, $a1 ; LA64F-LP64S-NEXT: ld.d $s0, $sp, 8 # 8-byte Folded Reload ; LA64F-LP64S-NEXT: ld.d $fp, $sp, 16 # 8-byte Folded Reload ; LA64F-LP64S-NEXT: ld.d $ra, $sp, 24 # 8-byte Folded Reload ; LA64F-LP64S-NEXT: addi.d $sp, $sp, 32 ; LA64F-LP64S-NEXT: ret ; ; LA64F-LP64D-LABEL: f: ; LA64F-LP64D: # %bb.0: ; LA64F-LP64D-NEXT: addi.d $sp, $sp, -32 ; LA64F-LP64D-NEXT: .cfi_def_cfa_offset 32 ; LA64F-LP64D-NEXT: st.d $ra, $sp, 24 # 8-byte Folded Spill ; LA64F-LP64D-NEXT: fst.d $fs0, $sp, 16 # 8-byte Folded Spill ; LA64F-LP64D-NEXT: fst.d $fs1, $sp, 8 # 8-byte Folded Spill ; LA64F-LP64D-NEXT: fst.d $fs2, $sp, 0 # 8-byte Folded Spill ; LA64F-LP64D-NEXT: .cfi_offset 1, -8 ; LA64F-LP64D-NEXT: .cfi_offset 56, -16 ; LA64F-LP64D-NEXT: .cfi_offset 57, -24 ; LA64F-LP64D-NEXT: .cfi_offset 58, -32 ; LA64F-LP64D-NEXT: fmov.s $fs0, $fa2 ; LA64F-LP64D-NEXT: fmov.s $fs1, $fa0 ; LA64F-LP64D-NEXT: fmov.s $fa0, $fa1 ; LA64F-LP64D-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64F-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64D-NEXT: fmov.s $fs2, $fa0 ; LA64F-LP64D-NEXT: fmov.s $fa0, $fs1 ; LA64F-LP64D-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64F-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64D-NEXT: fadd.s $fa0, $fa0, $fs2 ; LA64F-LP64D-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64F-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64D-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64F-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64D-NEXT: fmov.s $fs1, $fa0 ; LA64F-LP64D-NEXT: fmov.s $fa0, $fs0 ; LA64F-LP64D-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64F-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64D-NEXT: fadd.s $fa0, $fs1, $fa0 ; LA64F-LP64D-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64F-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64F-LP64D-NEXT: movfr2gr.s $a0, $fa0 ; LA64F-LP64D-NEXT: lu12i.w $a1, -16 ; LA64F-LP64D-NEXT: or $a0, $a0, $a1 ; LA64F-LP64D-NEXT: movgr2fr.w $fa0, $a0 ; LA64F-LP64D-NEXT: fld.d $fs2, $sp, 0 # 8-byte Folded Reload ; LA64F-LP64D-NEXT: fld.d $fs1, $sp, 8 # 8-byte Folded Reload ; LA64F-LP64D-NEXT: fld.d $fs0, $sp, 16 # 8-byte Folded Reload ; LA64F-LP64D-NEXT: ld.d $ra, $sp, 24 # 8-byte Folded Reload ; LA64F-LP64D-NEXT: addi.d $sp, $sp, 32 ; LA64F-LP64D-NEXT: ret ; ; LA64D-LP64S-LABEL: f: ; LA64D-LP64S: # %bb.0: ; LA64D-LP64S-NEXT: addi.d $sp, $sp, -32 ; LA64D-LP64S-NEXT: .cfi_def_cfa_offset 32 ; LA64D-LP64S-NEXT: st.d $ra, $sp, 24 # 8-byte Folded Spill ; LA64D-LP64S-NEXT: st.d $fp, $sp, 16 # 8-byte Folded Spill ; LA64D-LP64S-NEXT: st.d $s0, $sp, 8 # 8-byte Folded Spill ; LA64D-LP64S-NEXT: .cfi_offset 1, -8 ; LA64D-LP64S-NEXT: .cfi_offset 22, -16 ; LA64D-LP64S-NEXT: .cfi_offset 23, -24 ; LA64D-LP64S-NEXT: move $fp, $a2 ; LA64D-LP64S-NEXT: move $s0, $a0 ; LA64D-LP64S-NEXT: move $a0, $a1 ; LA64D-LP64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64D-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64S-NEXT: movgr2fr.w $fa0, $a0 ; LA64D-LP64S-NEXT: fst.s $fa0, $sp, 4 # 4-byte Folded Spill ; LA64D-LP64S-NEXT: move $a0, $s0 ; LA64D-LP64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64D-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64S-NEXT: movgr2fr.w $fa0, $a0 ; LA64D-LP64S-NEXT: fld.s $fa1, $sp, 4 # 4-byte Folded Reload ; LA64D-LP64S-NEXT: fadd.s $fa0, $fa0, $fa1 ; LA64D-LP64S-NEXT: movfr2gr.s $a0, $fa0 ; LA64D-LP64S-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64D-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64D-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64S-NEXT: movgr2fr.w $fa0, $a0 ; LA64D-LP64S-NEXT: fst.s $fa0, $sp, 4 # 4-byte Folded Spill ; LA64D-LP64S-NEXT: move $a0, $fp ; LA64D-LP64S-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64D-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64S-NEXT: movgr2fr.w $fa0, $a0 ; LA64D-LP64S-NEXT: fld.s $fa1, $sp, 4 # 4-byte Folded Reload ; LA64D-LP64S-NEXT: fadd.s $fa0, $fa1, $fa0 ; LA64D-LP64S-NEXT: movfr2gr.s $a0, $fa0 ; LA64D-LP64S-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64D-LP64S-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64S-NEXT: lu12i.w $a1, -16 ; LA64D-LP64S-NEXT: or $a0, $a0, $a1 ; LA64D-LP64S-NEXT: ld.d $s0, $sp, 8 # 8-byte Folded Reload ; LA64D-LP64S-NEXT: ld.d $fp, $sp, 16 # 8-byte Folded Reload ; LA64D-LP64S-NEXT: ld.d $ra, $sp, 24 # 8-byte Folded Reload ; LA64D-LP64S-NEXT: addi.d $sp, $sp, 32 ; LA64D-LP64S-NEXT: ret ; ; LA64D-LP64D-LABEL: f: ; LA64D-LP64D: # %bb.0: ; LA64D-LP64D-NEXT: addi.d $sp, $sp, -32 ; LA64D-LP64D-NEXT: .cfi_def_cfa_offset 32 ; LA64D-LP64D-NEXT: st.d $ra, $sp, 24 # 8-byte Folded Spill ; LA64D-LP64D-NEXT: fst.d $fs0, $sp, 16 # 8-byte Folded Spill ; LA64D-LP64D-NEXT: fst.d $fs1, $sp, 8 # 8-byte Folded Spill ; LA64D-LP64D-NEXT: fst.d $fs2, $sp, 0 # 8-byte Folded Spill ; LA64D-LP64D-NEXT: .cfi_offset 1, -8 ; LA64D-LP64D-NEXT: .cfi_offset 56, -16 ; LA64D-LP64D-NEXT: .cfi_offset 57, -24 ; LA64D-LP64D-NEXT: .cfi_offset 58, -32 ; LA64D-LP64D-NEXT: fmov.s $fs0, $fa2 ; LA64D-LP64D-NEXT: fmov.s $fs1, $fa0 ; LA64D-LP64D-NEXT: fmov.s $fa0, $fa1 ; LA64D-LP64D-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64D-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64D-NEXT: fmov.s $fs2, $fa0 ; LA64D-LP64D-NEXT: fmov.s $fa0, $fs1 ; LA64D-LP64D-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64D-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64D-NEXT: fadd.s $fa0, $fa0, $fs2 ; LA64D-LP64D-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64D-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64D-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64D-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64D-NEXT: fmov.s $fs1, $fa0 ; LA64D-LP64D-NEXT: fmov.s $fa0, $fs0 ; LA64D-LP64D-NEXT: pcaddu18i $ra, %call36(__extendhfsf2) ; LA64D-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64D-NEXT: fadd.s $fa0, $fs1, $fa0 ; LA64D-LP64D-NEXT: pcaddu18i $ra, %call36(__truncsfhf2) ; LA64D-LP64D-NEXT: jirl $ra, $ra, 0 ; LA64D-LP64D-NEXT: movfr2gr.s $a0, $fa0 ; LA64D-LP64D-NEXT: lu12i.w $a1, -16 ; LA64D-LP64D-NEXT: or $a0, $a0, $a1 ; LA64D-LP64D-NEXT: movgr2fr.w $fa0, $a0 ; LA64D-LP64D-NEXT: fld.d $fs2, $sp, 0 # 8-byte Folded Reload ; LA64D-LP64D-NEXT: fld.d $fs1, $sp, 8 # 8-byte Folded Reload ; LA64D-LP64D-NEXT: fld.d $fs0, $sp, 16 # 8-byte Folded Reload ; LA64D-LP64D-NEXT: ld.d $ra, $sp, 24 # 8-byte Folded Reload ; LA64D-LP64D-NEXT: addi.d $sp, $sp, 32 ; LA64D-LP64D-NEXT: ret %d = fadd half %a, %b %e = fadd half %d, %c ret half %e }