| ; RUN: llc -mcpu=pwr9 -mtriple=powerpc64le-unknown-unknown \ |
| ; RUN: -enable-ppc-quad-precision -ppc-vsr-nums-as-vr \ |
| ; RUN: -ppc-asm-full-reg-names < %s | FileCheck %s |
| |
| define void @qpFmadd(fp128* nocapture readonly %a, fp128* nocapture %b, |
| fp128* nocapture readonly %c, fp128* nocapture %res) { |
| entry: |
| %0 = load fp128, fp128* %a, align 16 |
| %1 = load fp128, fp128* %b, align 16 |
| %2 = load fp128, fp128* %c, align 16 |
| %madd = tail call fp128 @llvm.fmuladd.f128(fp128 %0, fp128 %1, fp128 %2) |
| store fp128 %madd, fp128* %res, align 16 |
| ret void |
| ; CHECK-LABEL: qpFmadd |
| ; CHECK-NOT: bl fmal |
| ; CHECK-DAG: lxv v[[REG3:[0-9]+]], 0(r3) |
| ; CHECK-DAG: lxv v[[REG4:[0-9]+]], 0(r4) |
| ; CHECK-DAG: lxv v[[REG5:[0-9]+]], 0(r5) |
| ; CHECK: xsmaddqp v[[REG5]], v[[REG3]], v[[REG4]] |
| ; CHECK-NEXT: stxv v[[REG5]], 0(r6) |
| ; CHECK-NEXT: blr |
| } |
| declare fp128 @llvm.fmuladd.f128(fp128, fp128, fp128) |
| |
| ; Function Attrs: norecurse nounwind |
| define void @qpFmadd_02(fp128* nocapture readonly %a, |
| fp128* nocapture readonly %b, |
| fp128* nocapture readonly %c, fp128* nocapture %res) { |
| entry: |
| %0 = load fp128, fp128* %a, align 16 |
| %1 = load fp128, fp128* %b, align 16 |
| %2 = load fp128, fp128* %c, align 16 |
| %mul = fmul contract fp128 %1, %2 |
| %add = fadd contract fp128 %0, %mul |
| store fp128 %add, fp128* %res, align 16 |
| ret void |
| ; CHECK-LABEL: qpFmadd_02 |
| ; CHECK-NOT: bl __multf3 |
| ; CHECK-DAG: lxv v[[REG3:[0-9]+]], 0(r3) |
| ; CHECK-DAG: lxv v[[REG4:[0-9]+]], 0(r4) |
| ; CHECK-DAG: lxv v[[REG5:[0-9]+]], 0(r5) |
| ; CHECK: xsmaddqp v[[REG3]], v[[REG4]], v[[REG5]] |
| ; CHECK-NEXT: stxv v[[REG3]], 0(r6) |
| ; CHECK-NEXT: blr |
| } |
| |
| ; Function Attrs: norecurse nounwind |
| define void @qpFmadd_03(fp128* nocapture readonly %a, |
| fp128* nocapture readonly %b, |
| fp128* nocapture readonly %c, fp128* nocapture %res) { |
| entry: |
| %0 = load fp128, fp128* %a, align 16 |
| %1 = load fp128, fp128* %b, align 16 |
| %mul = fmul contract fp128 %0, %1 |
| %2 = load fp128, fp128* %c, align 16 |
| %add = fadd contract fp128 %mul, %2 |
| store fp128 %add, fp128* %res, align 16 |
| ret void |
| ; CHECK-LABEL: qpFmadd_03 |
| ; CHECK-NOT: bl __multf3 |
| ; CHECK-DAG: lxv v[[REG3:[0-9]+]], 0(r3) |
| ; CHECK-DAG: lxv v[[REG4:[0-9]+]], 0(r4) |
| ; CHECK-DAG: lxv v[[REG5:[0-9]+]], 0(r5) |
| ; CHECK: xsmaddqp v[[REG5]], v[[REG3]], v[[REG4]] |
| ; CHECK-NEXT: stxv v[[REG5]], 0(r6) |
| ; CHECK-NEXT: blr |
| } |
| |
| ; Function Attrs: norecurse nounwind |
| define void @qpFnmadd(fp128* nocapture readonly %a, |
| fp128* nocapture readonly %b, |
| fp128* nocapture readonly %c, fp128* nocapture %res) { |
| entry: |
| %0 = load fp128, fp128* %a, align 16 |
| %1 = load fp128, fp128* %b, align 16 |
| %2 = load fp128, fp128* %c, align 16 |
| %mul = fmul contract fp128 %1, %2 |
| %add = fadd contract fp128 %0, %mul |
| %sub = fsub fp128 0xL00000000000000008000000000000000, %add |
| store fp128 %sub, fp128* %res, align 16 |
| ret void |
| ; CHECK-LABEL: qpFnmadd |
| ; CHECK-NOT: bl __multf3 |
| ; CHECK-DAG: lxv v[[REG3:[0-9]+]], 0(r3) |
| ; CHECK-DAG: lxv v[[REG4:[0-9]+]], 0(r4) |
| ; CHECK-DAG: lxv v[[REG5:[0-9]+]], 0(r5) |
| ; CHECK: xsnmaddqp v[[REG3]], v[[REG4]], v[[REG5]] |
| ; CHECK-NEXT: stxv v[[REG3]], 0(r6) |
| ; CHECK-NEXT: blr |
| } |
| |
| ; Function Attrs: norecurse nounwind |
| define void @qpFnmadd_02(fp128* nocapture readonly %a, |
| fp128* nocapture readonly %b, |
| fp128* nocapture readonly %c, fp128* nocapture %res) { |
| entry: |
| %0 = load fp128, fp128* %a, align 16 |
| %1 = load fp128, fp128* %b, align 16 |
| %mul = fmul contract fp128 %0, %1 |
| %2 = load fp128, fp128* %c, align 16 |
| %add = fadd contract fp128 %mul, %2 |
| %sub = fsub fp128 0xL00000000000000008000000000000000, %add |
| store fp128 %sub, fp128* %res, align 16 |
| ret void |
| ; CHECK-LABEL: qpFnmadd_02 |
| ; CHECK-NOT: bl __multf3 |
| ; CHECK-DAG: lxv v[[REG3:[0-9]+]], 0(r3) |
| ; CHECK-DAG: lxv v[[REG4:[0-9]+]], 0(r4) |
| ; CHECK-DAG: lxv v[[REG5:[0-9]+]], 0(r5) |
| ; CHECK: xsnmaddqp v[[REG5]], v[[REG3]], v[[REG4]] |
| ; CHECK-NEXT: stxv v[[REG5]], 0(r6) |
| ; CHECK-NEXT: blr |
| } |
| |
| ; Function Attrs: norecurse nounwind |
| define void @qpFmsub(fp128* nocapture readonly %a, |
| fp128* nocapture readonly %b, |
| fp128* nocapture readonly %c, fp128* nocapture %res) { |
| entry: |
| %0 = load fp128, fp128* %a, align 16 |
| %1 = load fp128, fp128* %b, align 16 |
| %2 = load fp128, fp128* %c, align 16 |
| %mul = fmul contract fp128 %1, %2 |
| %sub = fsub contract fp128 %0, %mul |
| store fp128 %sub, fp128* %res, align 16 |
| ret void |
| ; CHECK-LABEL: qpFmsub |
| ; CHECK-NOT: bl __multf3 |
| ; CHECK-DAG: lxv v[[REG3:[0-9]+]], 0(r3) |
| ; CHECK-DAG: lxv v[[REG4:[0-9]+]], 0(r4) |
| ; CHECK-DAG: lxv v[[REG5:[0-9]+]], 0(r5) |
| ; CHECK: xsnmsubqp v[[REG3]], v[[REG5]], v[[REG4]] |
| ; CHECK-NEXT: stxv v[[REG3]], 0(r6) |
| ; CHECK-NEXT: blr |
| } |
| |
| ; Function Attrs: norecurse nounwind |
| define void @qpFmsub_02(fp128* nocapture readonly %a, |
| fp128* nocapture readonly %b, |
| fp128* nocapture readonly %c, fp128* nocapture %res) { |
| entry: |
| %0 = load fp128, fp128* %a, align 16 |
| %1 = load fp128, fp128* %b, align 16 |
| %mul = fmul contract fp128 %0, %1 |
| %2 = load fp128, fp128* %c, align 16 |
| %sub = fsub contract fp128 %mul, %2 |
| store fp128 %sub, fp128* %res, align 16 |
| ret void |
| ; CHECK-LABEL: qpFmsub_02 |
| ; CHECK-NOT: bl __multf3 |
| ; CHECK-DAG: lxv v[[REG3:[0-9]+]], 0(r3) |
| ; CHECK-DAG: lxv v[[REG4:[0-9]+]], 0(r4) |
| ; CHECK-DAG: lxv v[[REG5:[0-9]+]], 0(r5) |
| ; CHECK: xsmsubqp v[[REG5]], v[[REG3]], v[[REG4]] |
| ; CHECK-NEXT: stxv v[[REG5]], 0(r6) |
| ; CHECK-NEXT: blr |
| } |
| |
| ; Function Attrs: norecurse nounwind |
| define void @qpFnmsub(fp128* nocapture readonly %a, |
| fp128* nocapture readonly %b, |
| fp128* nocapture readonly %c, fp128* nocapture %res) { |
| entry: |
| %0 = load fp128, fp128* %a, align 16 |
| %1 = load fp128, fp128* %b, align 16 |
| %2 = load fp128, fp128* %c, align 16 |
| %mul = fmul contract fp128 %1, %2 |
| %sub = fsub contract fp128 %0, %mul |
| %sub1 = fsub fp128 0xL00000000000000008000000000000000, %sub |
| store fp128 %sub1, fp128* %res, align 16 |
| ret void |
| ; CHECK-LABEL: qpFnmsub |
| ; CHECK-NOT: bl __multf3 |
| ; CHECK-DAG: lxv v[[REG3:[0-9]+]], 0(r3) |
| ; CHECK-DAG: lxv v[[REG4:[0-9]+]], 0(r4) |
| ; CHECK-DAG: lxv v[[REG5:[0-9]+]], 0(r5) |
| ; CHECK: xsnegqp v[[REG4]], v[[REG4]] |
| ; CHECK: xsnmaddqp v[[REG3]], v[[REG4]], v[[REG5]] |
| ; CHECK-NEXT: stxv v[[REG3]], 0(r6) |
| ; CHECK-NEXT: blr |
| } |
| |
| ; Function Attrs: norecurse nounwind |
| define void @qpFnmsub_02(fp128* nocapture readonly %a, |
| fp128* nocapture readonly %b, |
| fp128* nocapture readonly %c, fp128* nocapture %res) { |
| entry: |
| %0 = load fp128, fp128* %a, align 16 |
| %1 = load fp128, fp128* %b, align 16 |
| %mul = fmul contract fp128 %0, %1 |
| %2 = load fp128, fp128* %c, align 16 |
| %sub = fsub contract fp128 %mul, %2 |
| %sub1 = fsub fp128 0xL00000000000000008000000000000000, %sub |
| store fp128 %sub1, fp128* %res, align 16 |
| ret void |
| ; CHECK-LABEL: qpFnmsub_02 |
| ; CHECK-NOT: bl __multf3 |
| ; CHECK-DAG: lxv v[[REG3:[0-9]+]], 0(r3) |
| ; CHECK-DAG: lxv v[[REG4:[0-9]+]], 0(r4) |
| ; CHECK-DAG: lxv v[[REG5:[0-9]+]], 0(r5) |
| ; CHECK: xsnmsubqp v[[REG5]], v[[REG3]], v[[REG4]] |
| ; CHECK-NEXT: stxv v[[REG5]], 0(r6) |
| ; CHECK-NEXT: blr |
| } |