1*1aecb0e0SCraig Topper# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 3 2*1aecb0e0SCraig Topper# RUN: llc %s -o - -mtriple=riscv64 -mattr=+f -run-pass=machine-combiner \ 3*1aecb0e0SCraig Topper# RUN: -verify-machineinstrs | FileCheck %s 4*1aecb0e0SCraig Topper 5*1aecb0e0SCraig Topper--- | 6*1aecb0e0SCraig Topper source_filename = "test.ll" 7*1aecb0e0SCraig Topper target datalayout = "e-m:e-p:64:64-i64:64-i128:128-n32:64-S128" 8*1aecb0e0SCraig Topper target triple = "riscv64" 9*1aecb0e0SCraig Topper 10*1aecb0e0SCraig Topper define void @foo(ptr %0, ptr %1, float %2, float %3, ptr %4, ptr %5) #0 { 11*1aecb0e0SCraig Topper %7 = load float, ptr %0, align 4 12*1aecb0e0SCraig Topper %8 = load float, ptr %1, align 4 13*1aecb0e0SCraig Topper %9 = fmul fast float %8, %7 14*1aecb0e0SCraig Topper %10 = fadd fast float %9, %2 15*1aecb0e0SCraig Topper store float %10, ptr %4, align 4 16*1aecb0e0SCraig Topper %11 = fsub fast float %3, %9 17*1aecb0e0SCraig Topper store float %11, ptr %5, align 4 18*1aecb0e0SCraig Topper ret void 19*1aecb0e0SCraig Topper } 20*1aecb0e0SCraig Topper 21*1aecb0e0SCraig Topper attributes #0 = { "target-features"="+f" } 22*1aecb0e0SCraig Topper 23*1aecb0e0SCraig Topper... 24*1aecb0e0SCraig Topper--- 25*1aecb0e0SCraig Toppername: foo 26*1aecb0e0SCraig Topperalignment: 4 27*1aecb0e0SCraig ToppertracksRegLiveness: true 28*1aecb0e0SCraig Topperregisters: 29*1aecb0e0SCraig Topper - { id: 0, class: gpr } 30*1aecb0e0SCraig Topper - { id: 1, class: gpr } 31*1aecb0e0SCraig Topper - { id: 2, class: fpr32 } 32*1aecb0e0SCraig Topper - { id: 3, class: fpr32 } 33*1aecb0e0SCraig Topper - { id: 4, class: gpr } 34*1aecb0e0SCraig Topper - { id: 5, class: gpr } 35*1aecb0e0SCraig Topper - { id: 6, class: fpr32 } 36*1aecb0e0SCraig Topper - { id: 7, class: fpr32 } 37*1aecb0e0SCraig Topper - { id: 8, class: fpr32 } 38*1aecb0e0SCraig Topper - { id: 9, class: fpr32 } 39*1aecb0e0SCraig Topper - { id: 10, class: fpr32 } 40*1aecb0e0SCraig Topperliveins: 41*1aecb0e0SCraig Topper - { reg: '$x10', virtual-reg: '%0' } 42*1aecb0e0SCraig Topper - { reg: '$x11', virtual-reg: '%1' } 43*1aecb0e0SCraig Topper - { reg: '$f10_f', virtual-reg: '%2' } 44*1aecb0e0SCraig Topper - { reg: '$f11_f', virtual-reg: '%3' } 45*1aecb0e0SCraig Topper - { reg: '$x12', virtual-reg: '%4' } 46*1aecb0e0SCraig Topper - { reg: '$x13', virtual-reg: '%5' } 47*1aecb0e0SCraig TopperframeInfo: 48*1aecb0e0SCraig Topper maxAlignment: 1 49*1aecb0e0SCraig ToppermachineFunctionInfo: 50*1aecb0e0SCraig Topper varArgsFrameIndex: 0 51*1aecb0e0SCraig Topper varArgsSaveSize: 0 52*1aecb0e0SCraig Topperbody: | 53*1aecb0e0SCraig Topper bb.0 (%ir-block.6): 54*1aecb0e0SCraig Topper liveins: $x10, $x11, $f10_f, $f11_f, $x12, $x13 55*1aecb0e0SCraig Topper 56*1aecb0e0SCraig Topper ; CHECK-LABEL: name: foo 57*1aecb0e0SCraig Topper ; CHECK: liveins: $x10, $x11, $f10_f, $f11_f, $x12, $x13 58*1aecb0e0SCraig Topper ; CHECK-NEXT: {{ $}} 59*1aecb0e0SCraig Topper ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x13 60*1aecb0e0SCraig Topper ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY $x12 61*1aecb0e0SCraig Topper ; CHECK-NEXT: [[COPY2:%[0-9]+]]:fpr32 = COPY $f11_f 62*1aecb0e0SCraig Topper ; CHECK-NEXT: [[COPY3:%[0-9]+]]:fpr32 = COPY $f10_f 63*1aecb0e0SCraig Topper ; CHECK-NEXT: [[COPY4:%[0-9]+]]:gpr = COPY $x11 64*1aecb0e0SCraig Topper ; CHECK-NEXT: [[COPY5:%[0-9]+]]:gpr = COPY $x10 65*1aecb0e0SCraig Topper ; CHECK-NEXT: [[FLW:%[0-9]+]]:fpr32 = FLW [[COPY5]], 0 :: (load (s32) from %ir.0) 66*1aecb0e0SCraig Topper ; CHECK-NEXT: [[FLW1:%[0-9]+]]:fpr32 = FLW [[COPY4]], 0 :: (load (s32) from %ir.1) 67*1aecb0e0SCraig Topper ; CHECK-NEXT: [[FMADD_S:%[0-9]+]]:fpr32 = nnan ninf nsz arcp contract afn reassoc nofpexcept FMADD_S [[FLW1]], [[FLW]], [[COPY3]], 7, implicit $frm 68*1aecb0e0SCraig Topper ; CHECK-NEXT: FSW killed [[FMADD_S]], [[COPY1]], 0 :: (store (s32) into %ir.4) 69*1aecb0e0SCraig Topper ; CHECK-NEXT: [[FNMSUB_S:%[0-9]+]]:fpr32 = nnan ninf nsz arcp contract afn reassoc nofpexcept FNMSUB_S [[FLW1]], [[FLW]], [[COPY2]], 7, implicit $frm 70*1aecb0e0SCraig Topper ; CHECK-NEXT: FSW killed [[FNMSUB_S]], [[COPY]], 0 :: (store (s32) into %ir.5) 71*1aecb0e0SCraig Topper ; CHECK-NEXT: PseudoRET 72*1aecb0e0SCraig Topper %5:gpr = COPY $x13 73*1aecb0e0SCraig Topper %4:gpr = COPY $x12 74*1aecb0e0SCraig Topper %3:fpr32 = COPY $f11_f 75*1aecb0e0SCraig Topper %2:fpr32 = COPY $f10_f 76*1aecb0e0SCraig Topper %1:gpr = COPY $x11 77*1aecb0e0SCraig Topper %0:gpr = COPY $x10 78*1aecb0e0SCraig Topper %6:fpr32 = FLW %0, 0 :: (load (s32) from %ir.0) 79*1aecb0e0SCraig Topper %7:fpr32 = FLW %1, 0 :: (load (s32) from %ir.1) 80*1aecb0e0SCraig Topper %8:fpr32 = nnan ninf nsz arcp contract afn reassoc nofpexcept FMUL_S killed %7, killed %6, 7, implicit $frm 81*1aecb0e0SCraig Topper %9:fpr32 = nnan ninf nsz arcp contract afn reassoc nofpexcept FADD_S %8, %2, 7, implicit $frm 82*1aecb0e0SCraig Topper FSW killed %9, %4, 0 :: (store (s32) into %ir.4) 83*1aecb0e0SCraig Topper %10:fpr32 = nnan ninf nsz arcp contract afn reassoc nofpexcept FSUB_S %3, %8, 7, implicit $frm 84*1aecb0e0SCraig Topper FSW killed %10, %5, 0 :: (store (s32) into %ir.5) 85*1aecb0e0SCraig Topper PseudoRET 86*1aecb0e0SCraig Topper 87*1aecb0e0SCraig Topper... 88