Index: lib/Target/PowerPC/PPCMIPeephole.cpp =================================================================== --- lib/Target/PowerPC/PPCMIPeephole.cpp +++ lib/Target/PowerPC/PPCMIPeephole.cpp @@ -125,6 +125,37 @@ && TargetRegisterInfo::isVirtualRegister(TrueReg1)) { MachineInstr *DefMI = MRI->getVRegDef(TrueReg1); + // If this is a splat fed by a splatting load, the splat is + // redundant. Replace with a copy. This doesn't happen directly due + // to code in PPCDAGToDAGISel.cpp, but it can happen when converting + // a load of a double to a vector of 64-bit integers. + auto isConversionOfLoadAndSplat = [=]() -> bool { + if (DefMI->getOpcode() != PPC::XVCVDPSXDS && + DefMI->getOpcode() != PPC::XVCVDPUXDS) + return false; + unsigned DefReg = lookThruCopyLike(DefMI->getOperand(1).getReg()); + if (TargetRegisterInfo::isVirtualRegister(DefReg)) { + MachineInstr *LoadMI = MRI->getVRegDef(DefReg); + if (LoadMI && LoadMI->getOpcode() == PPC::LXVDSX) + return true; + } + return false; + }; + if (DefMI && (Immed == 0 || Immed == 3)) { + if (DefMI->getOpcode() == PPC::LXVDSX || + isConversionOfLoadAndSplat()) { + DEBUG(dbgs() + << "Optimizing load-and-splat/splat " + "to load-and-splat/copy: "); + DEBUG(MI.dump()); + BuildMI(MBB, &MI, MI.getDebugLoc(), + TII->get(PPC::COPY), MI.getOperand(0).getReg()) + .addOperand(MI.getOperand(1)); + ToErase = &MI; + Simplified = true; + } + } + // If this is a splat or a swap fed by another splat, we // can replace it with a copy. if (DefMI && DefMI->getOpcode() == PPC::XXPERMDI) { @@ -190,17 +221,32 @@ unsigned MyOpcode = MI.getOpcode(); unsigned OpNo = MyOpcode == PPC::XXSPLTW ? 1 : 2; unsigned TrueReg = lookThruCopyLike(MI.getOperand(OpNo).getReg()); + if (!TargetRegisterInfo::isVirtualRegister(TrueReg)) + break; MachineInstr *DefMI = MRI->getVRegDef(TrueReg); if (!DefMI) break; unsigned DefOpcode = DefMI->getOpcode(); - bool SameOpcode = (MyOpcode == DefOpcode) || + auto isConvertOfSplat = [=]() -> bool { + if (DefOpcode != PPC::XVCVSPSXWS && DefOpcode != PPC::XVCVSPUXWS) + return false; + unsigned ConvReg = DefMI->getOperand(1).getReg(); + if (!TargetRegisterInfo::isVirtualRegister(ConvReg)) + return false; + MachineInstr *Splt = MRI->getVRegDef(ConvReg); + return Splt && (Splt->getOpcode() == PPC::LXVWSX || + Splt->getOpcode() == PPC::XXSPLTW); + }; + bool AlreadySplat = (MyOpcode == DefOpcode) || (MyOpcode == PPC::VSPLTB && DefOpcode == PPC::VSPLTBs) || (MyOpcode == PPC::VSPLTH && DefOpcode == PPC::VSPLTHs) || - (MyOpcode == PPC::XXSPLTW && DefOpcode == PPC::XXSPLTWs); - // Splat fed by another splat - switch the output of the first - // and remove the second. - if (SameOpcode) { + (MyOpcode == PPC::XXSPLTW && DefOpcode == PPC::XXSPLTWs) || + (MyOpcode == PPC::XXSPLTW && DefOpcode == PPC::LXVWSX) || + (MyOpcode == PPC::XXSPLTW && DefOpcode == PPC::MTVSRWS)|| + (MyOpcode == PPC::XXSPLTW && isConvertOfSplat()); + // If the instruction[s] that feed this splat have already splat + // the value, this splat is redundant. + if (AlreadySplat) { DEBUG(dbgs() << "Changing redundant splat to a copy: "); DEBUG(MI.dump()); BuildMI(MBB, &MI, MI.getDebugLoc(), TII->get(PPC::COPY), @@ -234,6 +280,62 @@ } break; } + case PPC::XVCVDPSP: { + // If this is a DP->SP conversion fed by an FRSP, the FRSP is redundant. + unsigned TrueReg = lookThruCopyLike(MI.getOperand(1).getReg()); + if (!TargetRegisterInfo::isVirtualRegister(TrueReg)) + break; + MachineInstr *DefMI = MRI->getVRegDef(TrueReg); + + // This can occur when building a vector of single precision or integer + // values. + if (DefMI && DefMI->getOpcode() == PPC::XXPERMDI) { + unsigned DefsReg1 = lookThruCopyLike(DefMI->getOperand(1).getReg()); + unsigned DefsReg2 = lookThruCopyLike(DefMI->getOperand(2).getReg()); + if (!TargetRegisterInfo::isVirtualRegister(DefsReg1) || + !TargetRegisterInfo::isVirtualRegister(DefsReg2)) + break; + MachineInstr *P1 = MRI->getVRegDef(DefsReg1); + MachineInstr *P2 = MRI->getVRegDef(DefsReg2); + + if (!P1 || !P2) + break; + + // Remove the passed FRSP instruction if it only feeds this MI and + // set any uses of that FRSP (in this MI) to the source of the FRSP. + auto removeFRSPIfPossible = [&](MachineInstr *RoundInstr) { + if (RoundInstr->getOpcode() == PPC::FRSP && + MRI->hasOneNonDBGUse(RoundInstr->getOperand(0).getReg())) { + Simplified = true; + unsigned ConvReg1 = RoundInstr->getOperand(1).getReg(); + unsigned FRSPDefines = RoundInstr->getOperand(0).getReg(); + MachineInstr &Use = *(MRI->use_instr_begin(FRSPDefines)); + for (int i = 0, e = Use.getNumOperands(); i < e; ++i) + if (Use.getOperand(i).isReg() && + Use.getOperand(i).getReg() == FRSPDefines) + Use.getOperand(i).setReg(ConvReg1); + DEBUG(dbgs() << "Removing redundant FRSP:\n"); + DEBUG(RoundInstr->dump()); + DEBUG(dbgs() << "As it feeds instruction:\n"); + DEBUG(MI.dump()); + DEBUG(dbgs() << "Through instruction:\n"); + DEBUG(DefMI->dump()); + RoundInstr->eraseFromParent(); + } + }; + + // If the input to XVCVDPSP is a vector that was built (even + // partially) out of FRSP's, the FRSP(s) can safely be removed + // since this instruction performs the same operation. + if (P1 != P2) { + removeFRSPIfPossible(P1); + removeFRSPIfPossible(P2); + break; + } + removeFRSPIfPossible(P1); + } + break; + } } } Index: test/CodeGen/PowerPC/build-vector-tests.ll =================================================================== --- test/CodeGen/PowerPC/build-vector-tests.ll +++ test/CodeGen/PowerPC/build-vector-tests.ll @@ -0,0 +1,4858 @@ +; RUN: llc -mcpu=pwr9 -ppc-vsr-nums-as-vr -mtriple=powerpc64-unknown-unknown \ +; RUN: < %s | FileCheck %s -check-prefix=P9BE -implicit-check-not frsp +; RUN: llc -mcpu=pwr9 -ppc-vsr-nums-as-vr -mtriple=powerpc64le-unknown-unknown \ +; RUN: < %s | FileCheck %s -check-prefix=P9LE -implicit-check-not frsp +; RUN: llc -mcpu=pwr8 -ppc-vsr-nums-as-vr -mtriple=powerpc64-unknown-unknown \ +; RUN: < %s | FileCheck %s -check-prefix=P8BE -implicit-check-not frsp +; RUN: llc -mcpu=pwr8 -ppc-vsr-nums-as-vr -mtriple=powerpc64le-unknown-unknown \ +; RUN: < %s | FileCheck %s -check-prefix=P8LE -implicit-check-not frsp + +; This test case comes from the following C test case (included as it may be +; slightly more readable than the LLVM IR. + +;/* This test case provides various ways of building vectors to ensure we +; produce optimal code for all cases. The cases are (for each type): +; - All zeros +; - All ones +; - Splat of a constant +; - From different values already in registers +; - From different constants +; - From different values in memory +; - Splat of a value in register +; - Splat of a value in memory +; - Inserting element into existing vector +; - Inserting element from existing vector into existing vector +; +; With conversions (float <-> int) +; - Splat of a constant +; - From different values already in registers +; - From different constants +; - From different values in memory +; - Splat of a value in register +; - Splat of a value in memory +; - Inserting element into existing vector +; - Inserting element from existing vector into existing vector +;*/ +; +;/*=================================== int ===================================*/ +;// P8: xxlxor // +;// P9: xxlxor // +;vector int allZeroi() { // +; return (vector int)0; // +;} // +;// P8: vspltisb -1 // +;// P9: xxspltisb 255 // +;vector int allOnei() { // +; return (vector int)-1; // +;} // +;// P8: vspltisw 1 // +;// P9: vspltisw 1 // +;vector int spltConst1i() { // +; return (vector int)1; // +;} // +;// P8: vspltisw -15; vsrw // +;// P9: vspltisw -15; vsrw // +;vector int spltConst16ki() { // +; return (vector int)((1<<15) - 1); // +;} // +;// P8: vspltisw -16; vsrw // +;// P9: vspltisw -16; vsrw // +;vector int spltConst32ki() { // +; return (vector int)((1<<16) - 1); // +;} // +;// P8: 4 x mtvsrwz, 2 x xxmrgh, vmrgow // +;// P9: 2 x mtvsrdd, vmrgow // +;vector int fromRegsi(int a, int b, int c, int d) { // +; return (vector int){ a, b, c, d }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (or even lxv) // +;vector int fromDiffConstsi() { // +; return (vector int) { 242, -113, 889, 19 }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx // +;vector int fromDiffMemConsAi(int *arr) { // +; return (vector int) { arr[0], arr[1], arr[2], arr[3] }; // +;} // +;// P8: 2 x lxvd2x, 2 x xxswapd, vperm // +;// P9: 2 x lxvx, vperm // +;vector int fromDiffMemConsDi(int *arr) { // +; return (vector int) { arr[3], arr[2], arr[1], arr[0] }; // +;} // +;// P8: sldi 2, lxvd2x, xxswapd // +;// P9: sldi 2, lxvx // +;vector int fromDiffMemVarAi(int *arr, int elem) { // +; return (vector int) { arr[elem], arr[elem+1], arr[elem+2], arr[elem+3] }; // +;} // +;// P8: sldi 2, 2 x lxvd2x, 2 x xxswapd, vperm // +;// P9: sldi 2, 2 x lxvx, vperm // +;vector int fromDiffMemVarDi(int *arr, int elem) { // +; return (vector int) { arr[elem], arr[elem-1], arr[elem-2], arr[elem-3] }; // +;} // +;// P8: 4 x lwz, 4 x mtvsrwz, 2 x xxmrghd, vmrgow // +;// P9: 4 x lwz, 2 x mtvsrdd, vmrgow // +;vector int fromRandMemConsi(int *arr) { // +; return (vector int) { arr[4], arr[18], arr[2], arr[88] }; // +;} // +;// P8: sldi 2, 4 x lwz, 4 x mtvsrwz, 2 x xxmrghd, vmrgow // +;// P9: sldi 2, add, 4 x lwz, 2 x mtvsrdd, vmrgow // +;vector int fromRandMemVari(int *arr, int elem) { // +; return (vector int) { arr[elem+4], arr[elem+1], arr[elem+2], arr[elem+8] };// +;} // +;// P8: mtvsrwz, xxspltw // +;// P9: mtvsrws // +;vector int spltRegVali(int val) { // +; return (vector int) val; // +;} // +;// P8: lxsiwax, xxspltw // +;// P9: lxvwsx // +;vector int spltMemVali(int *ptr) { // +; return (vector int)*ptr; // +;} // +;// P8: vspltisw // +;// P9: vspltisw // +;vector int spltCnstConvftoi() { // +; return (vector int) 4.74f; // +;} // +;// P8: 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;// P9: 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvdpsxws // +;vector int fromRegsConvftoi(float a, float b, float c, float d) { // +; return (vector int) { a, b, c, d }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (even lxv) // +;vector int fromDiffConstsConvftoi() { // +; return (vector int) { 24.46f, 234.f, 988.19f, 422.39f }; // +;} // +;// P8: lxvd2x, xxswapd, xvcvspsxws // +;// P9: lxvx, xvcvspsxws // +;vector int fromDiffMemConsAConvftoi(float *ptr) { // +; return (vector int) { ptr[0], ptr[1], ptr[2], ptr[3] }; // +;} // +;// P8: 2 x lxvd2x, 2 x xxswapd, vperm, xvcvspsxws // +;// P9: 2 x lxvx, vperm, xvcvspsxws // +;vector int fromDiffMemConsDConvftoi(float *ptr) { // +; return (vector int) { ptr[3], ptr[2], ptr[1], ptr[0] }; // +;} // +;// P8: 4 x lxsspx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;// P9: 4 x lxssp, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;// Note: if the consecutive loads learns to handle pre-inc, this can be: // +;// sldi 2, load, xvcvspuxws // +;vector int fromDiffMemVarAConvftoi(float *arr, int elem) { // +; return (vector int) { arr[elem], arr[elem+1], arr[elem+2], arr[elem+3] }; // +;} // +;// P8: 4 x lxsspx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;// P9: 4 x lxssp, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;// Note: if the consecutive loads learns to handle pre-inc, this can be: // +;// sldi 2, 2 x load, vperm, xvcvspuxws // +;vector int fromDiffMemVarDConvftoi(float *arr, int elem) { // +; return (vector int) { arr[elem], arr[elem-1], arr[elem-2], arr[elem-3] }; // +;} // +;// P8: xscvdpsxws, xxspltw // +;// P9: xscvdpsxws, xxspltw // +;vector int spltRegValConvftoi(float val) { // +; return (vector int) val; // +;} // +;// P8: lxsspx, xscvdpsxws, xxspltw // +;// P9: lxvwsx, xvcvspsxws // +;vector int spltMemValConvftoi(float *ptr) { // +; return (vector int)*ptr; // +;} // +;// P8: vspltisw // +;// P9: vspltisw // +;vector int spltCnstConvdtoi() { // +; return (vector int) 4.74; // +;} // +;// P8: 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;// P9: 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;vector int fromRegsConvdtoi(double a, double b, double c, double d) { // +; return (vector int) { a, b, c, d }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (even lxv) // +;vector int fromDiffConstsConvdtoi() { // +; return (vector int) { 24.46, 234., 988.19, 422.39 }; // +;} // +;// P8: 2 x lxvd2x, 2 x xxswapd, xxmrgld, xxmrghd, 2 x xvcvdpsp, vmrgew, // +;// xvcvspsxws // +;// P9: 2 x lxvx, 2 x xxswapd, xxmrgld, xxmrghd, 2 x xvcvdpsp, vmrgew, // +;// xvcvspsxws // +;vector int fromDiffMemConsAConvdtoi(double *ptr) { // +; return (vector int) { ptr[0], ptr[1], ptr[2], ptr[3] }; // +;} // +;// P8: 4 x lxsdx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;// P9: 4 x lfd, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;vector int fromDiffMemConsDConvdtoi(double *ptr) { // +; return (vector int) { ptr[3], ptr[2], ptr[1], ptr[0] }; // +;} // +;// P8: lfdux, 3 x lxsdx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;// P9: lfdux, 3 x lfd, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;vector int fromDiffMemVarAConvdtoi(double *arr, int elem) { // +; return (vector int) { arr[elem], arr[elem+1], arr[elem+2], arr[elem+3] }; // +;} // +;// P8: lfdux, 3 x lxsdx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;// P9: lfdux, 3 x lfd, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspsxws // +;vector int fromDiffMemVarDConvdtoi(double *arr, int elem) { // +; return (vector int) { arr[elem], arr[elem-1], arr[elem-2], arr[elem-3] }; // +;} // +;// P8: xscvdpsxws, xxspltw // +;// P9: xscvdpsxws, xxspltw // +;vector int spltRegValConvdtoi(double val) { // +; return (vector int) val; // +;} // +;// P8: lxsdx, xscvdpsxws, xxspltw // +;// P9: lxssp, xscvdpsxws, xxspltw // +;vector int spltMemValConvdtoi(double *ptr) { // +; return (vector int)*ptr; // +;} // +;/*=================================== int ===================================*/ +;/*=============================== unsigned int ==============================*/ +;// P8: xxlxor // +;// P9: xxlxor // +;vector unsigned int allZeroui() { // +; return (vector unsigned int)0; // +;} // +;// P8: vspltisb -1 // +;// P9: xxspltisb 255 // +;vector unsigned int allOneui() { // +; return (vector unsigned int)-1; // +;} // +;// P8: vspltisw 1 // +;// P9: vspltisw 1 // +;vector unsigned int spltConst1ui() { // +; return (vector unsigned int)1; // +;} // +;// P8: vspltisw -15; vsrw // +;// P9: vspltisw -15; vsrw // +;vector unsigned int spltConst16kui() { // +; return (vector unsigned int)((1<<15) - 1); // +;} // +;// P8: vspltisw -16; vsrw // +;// P9: vspltisw -16; vsrw // +;vector unsigned int spltConst32kui() { // +; return (vector unsigned int)((1<<16) - 1); // +;} // +;// P8: 4 x mtvsrwz, 2 x xxmrghd, vmrgow // +;// P9: 2 x mtvsrdd, vmrgow // +;vector unsigned int fromRegsui(unsigned int a, unsigned int b, // +; unsigned int c, unsigned int d) { // +; return (vector unsigned int){ a, b, c, d }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (or even lxv) // +;vector unsigned int fromDiffConstsui() { // +; return (vector unsigned int) { 242, -113, 889, 19 }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx // +;vector unsigned int fromDiffMemConsAui(unsigned int *arr) { // +; return (vector unsigned int) { arr[0], arr[1], arr[2], arr[3] }; // +;} // +;// P8: 2 x lxvd2x, 2 x xxswapd, vperm // +;// P9: 2 x lxvx, vperm // +;vector unsigned int fromDiffMemConsDui(unsigned int *arr) { // +; return (vector unsigned int) { arr[3], arr[2], arr[1], arr[0] }; // +;} // +;// P8: sldi 2, lxvd2x, xxswapd // +;// P9: sldi 2, lxvx // +;vector unsigned int fromDiffMemVarAui(unsigned int *arr, int elem) { // +; return (vector unsigned int) { arr[elem], arr[elem+1], // +; arr[elem+2], arr[elem+3] }; // +;} // +;// P8: sldi 2, 2 x lxvd2x, 2 x xxswapd, vperm // +;// P9: sldi 2, 2 x lxvx, vperm // +;vector unsigned int fromDiffMemVarDui(unsigned int *arr, int elem) { // +; return (vector unsigned int) { arr[elem], arr[elem-1], // +; arr[elem-2], arr[elem-3] }; // +;} // +;// P8: 4 x lwz, 4 x mtvsrwz, 2 x xxmrghd, vmrgow // +;// P9: 4 x lwz, 2 x mtvsrdd, vmrgow // +;vector unsigned int fromRandMemConsui(unsigned int *arr) { // +; return (vector unsigned int) { arr[4], arr[18], arr[2], arr[88] }; // +;} // +;// P8: sldi 2, 4 x lwz, 4 x mtvsrwz, 2 x xxmrghd, vmrgow // +;// P9: sldi 2, add, 4 x lwz, 2 x mtvsrdd, vmrgow // +;vector unsigned int fromRandMemVarui(unsigned int *arr, int elem) { // +; return (vector unsigned int) { arr[elem+4], arr[elem+1], // +; arr[elem+2], arr[elem+8] }; // +;} // +;// P8: mtvsrwz, xxspltw // +;// P9: mtvsrws // +;vector unsigned int spltRegValui(unsigned int val) { // +; return (vector unsigned int) val; // +;} // +;// P8: lxsiwax, xxspltw // +;// P9: lxvwsx // +;vector unsigned int spltMemValui(unsigned int *ptr) { // +; return (vector unsigned int)*ptr; // +;} // +;// P8: vspltisw // +;// P9: vspltisw // +;vector unsigned int spltCnstConvftoui() { // +; return (vector unsigned int) 4.74f; // +;} // +;// P8: 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;// P9: 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;vector unsigned int fromRegsConvftoui(float a, float b, float c, float d) { // +; return (vector unsigned int) { a, b, c, d }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (even lxv) // +;vector unsigned int fromDiffConstsConvftoui() { // +; return (vector unsigned int) { 24.46f, 234.f, 988.19f, 422.39f }; // +;} // +;// P8: lxvd2x, xxswapd, xvcvspuxws // +;// P9: lxvx, xvcvspuxws // +;vector unsigned int fromDiffMemConsAConvftoui(float *ptr) { // +; return (vector unsigned int) { ptr[0], ptr[1], ptr[2], ptr[3] }; // +;} // +;// P8: 2 x lxvd2x, 2 x xxswapd, vperm, xvcvspuxws // +;// P9: 2 x lxvx, vperm, xvcvspuxws // +;vector unsigned int fromDiffMemConsDConvftoui(float *ptr) { // +; return (vector unsigned int) { ptr[3], ptr[2], ptr[1], ptr[0] }; // +;} // +;// P8: lfsux, 3 x lxsspx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;// P9: lfsux, 3 x lfs, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;// Note: if the consecutive loads learns to handle pre-inc, this can be: // +;// sldi 2, load, xvcvspuxws // +;vector unsigned int fromDiffMemVarAConvftoui(float *arr, int elem) { // +; return (vector unsigned int) { arr[elem], arr[elem+1], // +; arr[elem+2], arr[elem+3] }; // +;} // +;// P8: lfsux, 3 x lxsspx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;// P9: lfsux, 3 x lfs, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;// Note: if the consecutive loads learns to handle pre-inc, this can be: // +;// sldi 2, 2 x load, vperm, xvcvspuxws // +;vector unsigned int fromDiffMemVarDConvftoui(float *arr, int elem) { // +; return (vector unsigned int) { arr[elem], arr[elem-1], // +; arr[elem-2], arr[elem-3] }; // +;} // +;// P8: xscvdpuxws, xxspltw // +;// P9: xscvdpuxws, xxspltw // +;vector unsigned int spltRegValConvftoui(float val) { // +; return (vector unsigned int) val; // +;} // +;// P8: lxsspx, xscvdpuxws, xxspltw // +;// P9: lxvwsx, xvcvspuxws // +;vector unsigned int spltMemValConvftoui(float *ptr) { // +; return (vector unsigned int)*ptr; // +;} // +;// P8: vspltisw // +;// P9: vspltisw // +;vector unsigned int spltCnstConvdtoui() { // +; return (vector unsigned int) 4.74; // +;} // +;// P8: 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;// P9: 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;vector unsigned int fromRegsConvdtoui(double a, double b, // +; double c, double d) { // +; return (vector unsigned int) { a, b, c, d }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (even lxv) // +;vector unsigned int fromDiffConstsConvdtoui() { // +; return (vector unsigned int) { 24.46, 234., 988.19, 422.39 }; // +;} // +;// P8: 2 x lxvd2x, 2 x xxswapd, xxmrgld, xxmrghd, 2 x xvcvdpsp, vmrgew, // +;// xvcvspuxws // +;// P9: 2 x lxvx, xxmrgld, xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;vector unsigned int fromDiffMemConsAConvdtoui(double *ptr) { // +; return (vector unsigned int) { ptr[0], ptr[1], ptr[2], ptr[3] }; // +;} // +;// P8: 4 x lxsdx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;// P9: 4 x lfd, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;vector unsigned int fromDiffMemConsDConvdtoui(double *ptr) { // +; return (vector unsigned int) { ptr[3], ptr[2], ptr[1], ptr[0] }; // +;} // +;// P8: lfdux, 3 x lxsdx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;// P9: lfdux, 3 x lfd, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;vector unsigned int fromDiffMemVarAConvdtoui(double *arr, int elem) { // +; return (vector unsigned int) { arr[elem], arr[elem+1], // +; arr[elem+2], arr[elem+3] }; // +;} // +;// P8: lfdux, 3 x lxsdx, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;// P9: lfdux, 3 x lfd, 2 x xxmrghd, 2 x xvcvdpsp, vmrgew, xvcvspuxws // +;vector unsigned int fromDiffMemVarDConvdtoui(double *arr, int elem) { // +; return (vector unsigned int) { arr[elem], arr[elem-1], // +; arr[elem-2], arr[elem-3] }; // +;} // +;// P8: xscvdpuxws, xxspltw // +;// P9: xscvdpuxws, xxspltw // +;vector unsigned int spltRegValConvdtoui(double val) { // +; return (vector unsigned int) val; // +;} // +;// P8: lxsspx, xscvdpuxws, xxspltw // +;// P9: lfd, xscvdpuxws, xxspltw // +;vector unsigned int spltMemValConvdtoui(double *ptr) { // +; return (vector unsigned int)*ptr; // +;} // +;/*=============================== unsigned int ==============================*/ +;/*=============================== long long =================================*/ +;// P8: xxlxor // +;// P9: xxlxor // +;vector long long allZeroll() { // +; return (vector long long)0; // +;} // +;// P8: vspltisb -1 // +;// P9: xxspltisb 255 // +;vector long long allOnell() { // +; return (vector long long)-1; // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;vector long long spltConst1ll() { // +; return (vector long long)1; // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw, vsrw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw, vsrw)) // +;vector long long spltConst16kll() { // +; return (vector long long)((1<<15) - 1); // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw, vsrw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw, vsrw)) // +;vector long long spltConst32kll() { // +; return (vector long long)((1<<16) - 1); // +;} // +;// P8: 2 x mtvsrd, xxmrghd // +;// P9: mtvsrdd // +;vector long long fromRegsll(long long a, long long b) { // +; return (vector long long){ a, b }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (or even lxv) // +;vector long long fromDiffConstsll() { // +; return (vector long long) { 242, -113 }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx // +;vector long long fromDiffMemConsAll(long long *arr) { // +; return (vector long long) { arr[0], arr[1] }; // +;} // +;// P8: lxvd2x // +;// P9: lxvx, xxswapd (maybe just use lxvd2x) // +;vector long long fromDiffMemConsDll(long long *arr) { // +; return (vector long long) { arr[3], arr[2] }; // +;} // +;// P8: sldi 3, lxvd2x, xxswapd // +;// P9: sldi 3, lxvx // +;vector long long fromDiffMemVarAll(long long *arr, int elem) { // +; return (vector long long) { arr[elem], arr[elem+1] }; // +;} // +;// P8: sldi 3, lxvd2x // +;// P9: sldi 3, lxvx, xxswapd (maybe just use lxvd2x) // +;vector long long fromDiffMemVarDll(long long *arr, int elem) { // +; return (vector long long) { arr[elem], arr[elem-1] }; // +;} // +;// P8: 2 x ld, 2 x mtvsrd, xxmrghd // +;// P9: 2 x ld, mtvsrdd // +;vector long long fromRandMemConsll(long long *arr) { // +; return (vector long long) { arr[4], arr[18] }; // +;} // +;// P8: sldi 3, add, 2 x ld, 2 x mtvsrd, xxmrghd // +;// P9: sldi 3, add, 2 x ld, mtvsrdd // +;vector long long fromRandMemVarll(long long *arr, int elem) { // +; return (vector long long) { arr[elem+4], arr[elem+1] }; // +;} // +;// P8: mtvsrd, xxspltd // +;// P9: mtvsrdd // +;vector long long spltRegValll(long long val) { // +; return (vector long long) val; // +;} // +;// P8: lxvdsx // +;// P9: lxvdsx // +;vector long long spltMemValll(long long *ptr) { // +; return (vector long long)*ptr; // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;vector long long spltCnstConvftoll() { // +; return (vector long long) 4.74f; // +;} // +;// P8: xxmrghd, xvcvdpsxds // +;// P9: xxmrghd, xvcvdpsxds // +;vector long long fromRegsConvftoll(float a, float b) { // +; return (vector long long) { a, b }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (even lxv) // +;vector long long fromDiffConstsConvftoll() { // +; return (vector long long) { 24.46f, 234.f }; // +;} // +;// P8: 2 x lxsspx, xxmrghd, xvcvdpsxds // +;// P9: 2 x lxssp, xxmrghd, xvcvdpsxds // +;vector long long fromDiffMemConsAConvftoll(float *ptr) { // +; return (vector long long) { ptr[0], ptr[1] }; // +;} // +;// P8: 2 x lxsspx, xxmrghd, xvcvdpsxds // +;// P9: 2 x lxssp, xxmrghd, xvcvdpsxds // +;vector long long fromDiffMemConsDConvftoll(float *ptr) { // +; return (vector long long) { ptr[3], ptr[2] }; // +;} // +;// P8: sldi 2, lfsux, lxsspx, xxmrghd, xvcvdpsxds // +;// P9: sldi 2, lfsux, lfs, xxmrghd, xvcvdpsxds // +;vector long long fromDiffMemVarAConvftoll(float *arr, int elem) { // +; return (vector long long) { arr[elem], arr[elem+1] }; // +;} // +;// P8: sldi 2, lfsux, lxsspx, xxmrghd, xvcvdpsxds // +;// P9: sldi 2, lfsux, lfs, xxmrghd, xvcvdpsxds // +;vector long long fromDiffMemVarDConvftoll(float *arr, int elem) { // +; return (vector long long) { arr[elem], arr[elem-1] }; // +;} // +;// P8: xscvdpsxds, xxspltd // +;// P9: xscvdpsxds, xxspltd // +;vector long long spltRegValConvftoll(float val) { // +; return (vector long long) val; // +;} // +;// P8: lxsspx, xscvdpsxds, xxspltd // +;// P9: lfs, xscvdpsxds, xxspltd // +;vector long long spltMemValConvftoll(float *ptr) { // +; return (vector long long)*ptr; // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;vector long long spltCnstConvdtoll() { // +; return (vector long long) 4.74; // +;} // +;// P8: xxmrghd, xvcvdpsxds // +;// P9: xxmrghd, xvcvdpsxds // +;vector long long fromRegsConvdtoll(double a, double b) { // +; return (vector long long) { a, b }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (even lxv) // +;vector long long fromDiffConstsConvdtoll() { // +; return (vector long long) { 24.46, 234. }; // +;} // +;// P8: lxvd2x, xxswapd, xvcvdpsxds // +;// P9: lxvx, xvcvdpsxds // +;vector long long fromDiffMemConsAConvdtoll(double *ptr) { // +; return (vector long long) { ptr[0], ptr[1] }; // +;} // +;// P8: lxvd2x, xvcvdpsxds // +;// P9: lxvx, xxswapd, xvcvdpsxds // +;vector long long fromDiffMemConsDConvdtoll(double *ptr) { // +; return (vector long long) { ptr[3], ptr[2] }; // +;} // +;// P8: sldi 3, lxvd2x, xxswapd, xvcvdpsxds // +;// P9: sldi 3, lxvx, xvcvdpsxds // +;vector long long fromDiffMemVarAConvdtoll(double *arr, int elem) { // +; return (vector long long) { arr[elem], arr[elem+1] }; // +;} // +;// P8: sldi 3, lxvd2x, xvcvdpsxds // +;// P9: sldi 3, lxvx, xxswapd, xvcvdpsxds // +;vector long long fromDiffMemVarDConvdtoll(double *arr, int elem) { // +; return (vector long long) { arr[elem], arr[elem-1] }; // +;} // +;// P8: xscvdpsxds, xxspltd // +;// P9: xscvdpsxds, xxspltd // +;vector long long spltRegValConvdtoll(double val) { // +; return (vector long long) val; // +;} // +;// P8: lxvdsx, xvcvdpsxds // +;// P9: lxvdsx, xvcvdpsxds // +;vector long long spltMemValConvdtoll(double *ptr) { // +; return (vector long long)*ptr; // +;} // +;/*=============================== long long =================================*/ +;/*========================== unsigned long long =============================*/ +;// P8: xxlxor // +;// P9: xxlxor // +;vector unsigned long long allZeroull() { // +; return (vector unsigned long long)0; // +;} // +;// P8: vspltisb -1 // +;// P9: xxspltisb 255 // +;vector unsigned long long allOneull() { // +; return (vector unsigned long long)-1; // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;vector unsigned long long spltConst1ull() { // +; return (vector unsigned long long)1; // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw, vsrw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw, vsrw)) // +;vector unsigned long long spltConst16kull() { // +; return (vector unsigned long long)((1<<15) - 1); // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw, vsrw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw, vsrw)) // +;vector unsigned long long spltConst32kull() { // +; return (vector unsigned long long)((1<<16) - 1); // +;} // +;// P8: 2 x mtvsrd, xxmrghd // +;// P9: mtvsrdd // +;vector unsigned long long fromRegsull(unsigned long long a, // +; unsigned long long b) { // +; return (vector unsigned long long){ a, b }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (or even lxv) // +;vector unsigned long long fromDiffConstsull() { // +; return (vector unsigned long long) { 242, -113 }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx // +;vector unsigned long long fromDiffMemConsAull(unsigned long long *arr) { // +; return (vector unsigned long long) { arr[0], arr[1] }; // +;} // +;// P8: lxvd2x // +;// P9: lxvx, xxswapd (maybe just use lxvd2x) // +;vector unsigned long long fromDiffMemConsDull(unsigned long long *arr) { // +; return (vector unsigned long long) { arr[3], arr[2] }; // +;} // +;// P8: sldi 3, lxvd2x, xxswapd // +;// P9: sldi 3, lxvx // +;vector unsigned long long fromDiffMemVarAull(unsigned long long *arr, // +; int elem) { // +; return (vector unsigned long long) { arr[elem], arr[elem+1] }; // +;} // +;// P8: sldi 3, lxvd2x // +;// P9: sldi 3, lxvx, xxswapd (maybe just use lxvd2x) // +;vector unsigned long long fromDiffMemVarDull(unsigned long long *arr, // +; int elem) { // +; return (vector unsigned long long) { arr[elem], arr[elem-1] }; // +;} // +;// P8: 2 x ld, 2 x mtvsrd, xxmrghd // +;// P9: 2 x ld, mtvsrdd // +;vector unsigned long long fromRandMemConsull(unsigned long long *arr) { // +; return (vector unsigned long long) { arr[4], arr[18] }; // +;} // +;// P8: sldi 3, add, 2 x ld, 2 x mtvsrd, xxmrghd // +;// P9: sldi 3, add, 2 x ld, mtvsrdd // +;vector unsigned long long fromRandMemVarull(unsigned long long *arr, // +; int elem) { // +; return (vector unsigned long long) { arr[elem+4], arr[elem+1] }; // +;} // +;// P8: mtvsrd, xxspltd // +;// P9: mtvsrdd // +;vector unsigned long long spltRegValull(unsigned long long val) { // +; return (vector unsigned long long) val; // +;} // +;// P8: lxvdsx // +;// P9: lxvdsx // +;vector unsigned long long spltMemValull(unsigned long long *ptr) { // +; return (vector unsigned long long)*ptr; // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;vector unsigned long long spltCnstConvftoull() { // +; return (vector unsigned long long) 4.74f; // +;} // +;// P8: xxmrghd, xvcvdpuxds // +;// P9: xxmrghd, xvcvdpuxds // +;vector unsigned long long fromRegsConvftoull(float a, float b) { // +; return (vector unsigned long long) { a, b }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (even lxv) // +;vector unsigned long long fromDiffConstsConvftoull() { // +; return (vector unsigned long long) { 24.46f, 234.f }; // +;} // +;// P8: 2 x lxsspx, xxmrghd, xvcvdpuxds // +;// P9: 2 x lxssp, xxmrghd, xvcvdpuxds // +;vector unsigned long long fromDiffMemConsAConvftoull(float *ptr) { // +; return (vector unsigned long long) { ptr[0], ptr[1] }; // +;} // +;// P8: 2 x lxsspx, xxmrghd, xvcvdpuxds // +;// P9: 2 x lxssp, xxmrghd, xvcvdpuxds // +;vector unsigned long long fromDiffMemConsDConvftoull(float *ptr) { // +; return (vector unsigned long long) { ptr[3], ptr[2] }; // +;} // +;// P8: sldi 2, lfsux, lxsspx, xxmrghd, xvcvdpuxds // +;// P9: sldi 2, lfsux, lfs, xxmrghd, xvcvdpuxds // +;vector unsigned long long fromDiffMemVarAConvftoull(float *arr, int elem) { // +; return (vector unsigned long long) { arr[elem], arr[elem+1] }; // +;} // +;// P8: sldi 2, lfsux, lxsspx, xxmrghd, xvcvdpuxds // +;// P9: sldi 2, lfsux, lfs, xxmrghd, xvcvdpuxds // +;vector unsigned long long fromDiffMemVarDConvftoull(float *arr, int elem) { // +; return (vector unsigned long long) { arr[elem], arr[elem-1] }; // +;} // +;// P8: xscvdpuxds, xxspltd // +;// P9: xscvdpuxds, xxspltd // +;vector unsigned long long spltRegValConvftoull(float val) { // +; return (vector unsigned long long) val; // +;} // +;// P8: lxsspx, xscvdpuxds, xxspltd // +;// P9: lfs, xscvdpuxds, xxspltd // +;vector unsigned long long spltMemValConvftoull(float *ptr) { // +; return (vector unsigned long long)*ptr; // +;} // +;// P8: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;// P9: constant pool load (possible: vmrgew (xxlxor), (vspltisw)) // +;vector unsigned long long spltCnstConvdtoull() { // +; return (vector unsigned long long) 4.74; // +;} // +;// P8: xxmrghd, xvcvdpuxds // +;// P9: xxmrghd, xvcvdpuxds // +;vector unsigned long long fromRegsConvdtoull(double a, double b) { // +; return (vector unsigned long long) { a, b }; // +;} // +;// P8: lxvd2x, xxswapd // +;// P9: lxvx (even lxv) // +;vector unsigned long long fromDiffConstsConvdtoull() { // +; return (vector unsigned long long) { 24.46, 234. }; // +;} // +;// P8: lxvd2x, xxswapd, xvcvdpuxds // +;// P9: lxvx, xvcvdpuxds // +;vector unsigned long long fromDiffMemConsAConvdtoull(double *ptr) { // +; return (vector unsigned long long) { ptr[0], ptr[1] }; // +;} // +;// P8: lxvd2x, xvcvdpuxds // +;// P9: lxvx, xxswapd, xvcvdpuxds // +;vector unsigned long long fromDiffMemConsDConvdtoull(double *ptr) { // +; return (vector unsigned long long) { ptr[3], ptr[2] }; // +;} // +;// P8: sldi 3, lxvd2x, xxswapd, xvcvdpuxds // +;// P9: sldi 3, lxvx, xvcvdpuxds // +;vector unsigned long long fromDiffMemVarAConvdtoull(double *arr, int elem) { // +; return (vector unsigned long long) { arr[elem], arr[elem+1] }; // +;} // +;// P8: sldi 3, lxvd2x, xvcvdpuxds // +;// P9: sldi 3, lxvx, xxswapd, xvcvdpuxds // +;vector unsigned long long fromDiffMemVarDConvdtoull(double *arr, int elem) { // +; return (vector unsigned long long) { arr[elem], arr[elem-1] }; // +;} // +;// P8: xscvdpuxds, xxspltd // +;// P9: xscvdpuxds, xxspltd // +;vector unsigned long long spltRegValConvdtoull(double val) { // +; return (vector unsigned long long) val; // +;} // +;// P8: lxvdsx, xvcvdpuxds // +;// P9: lxvdsx, xvcvdpuxds // +;vector unsigned long long spltMemValConvdtoull(double *ptr) { // +; return (vector unsigned long long)*ptr; // +;} // +;/*========================== unsigned long long ==============================*/ + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @allZeroi() { +entry: + ret <4 x i32> zeroinitializer +; P9BE-LABEL: allZeroi +; P9LE-LABEL: allZeroi +; P8BE-LABEL: allZeroi +; P8LE-LABEL: allZeroi +; P9BE: xxlxor v2, v2, v2 +; P9BE: blr +; P9LE: xxlxor v2, v2, v2 +; P9LE: blr +; P8BE: xxlxor v2, v2, v2 +; P8BE: blr +; P8LE: xxlxor v2, v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @allOnei() { +entry: + ret <4 x i32> +; P9BE-LABEL: allOnei +; P9LE-LABEL: allOnei +; P8BE-LABEL: allOnei +; P8LE-LABEL: allOnei +; P9BE: xxspltib v2, 255 +; P9BE: blr +; P9LE: xxspltib v2, 255 +; P9LE: blr +; P8BE: vspltisb v2, -1 +; P8BE: blr +; P8LE: vspltisb v2, -1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltConst1i() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltConst1i +; P9LE-LABEL: spltConst1i +; P8BE-LABEL: spltConst1i +; P8LE-LABEL: spltConst1i +; P9BE: vspltisw v2, 1 +; P9BE: blr +; P9LE: vspltisw v2, 1 +; P9LE: blr +; P8BE: vspltisw v2, 1 +; P8BE: blr +; P8LE: vspltisw v2, 1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltConst16ki() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltConst16ki +; P9LE-LABEL: spltConst16ki +; P8BE-LABEL: spltConst16ki +; P8LE-LABEL: spltConst16ki +; P9BE: vspltisw v2, -15 +; P9BE: vsrw v2, v2, v2 +; P9BE: blr +; P9LE: vspltisw v2, -15 +; P9LE: vsrw v2, v2, v2 +; P9LE: blr +; P8BE: vspltisw v2, -15 +; P8BE: vsrw v2, v2, v2 +; P8BE: blr +; P8LE: vspltisw v2, -15 +; P8LE: vsrw v2, v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltConst32ki() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltConst32ki +; P9LE-LABEL: spltConst32ki +; P8BE-LABEL: spltConst32ki +; P8LE-LABEL: spltConst32ki +; P9BE: vspltisw v2, -16 +; P9BE: vsrw v2, v2, v2 +; P9BE: blr +; P9LE: vspltisw v2, -16 +; P9LE: vsrw v2, v2, v2 +; P9LE: blr +; P8BE: vspltisw v2, -16 +; P8BE: vsrw v2, v2, v2 +; P8BE: blr +; P8LE: vspltisw v2, -16 +; P8LE: vsrw v2, v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromRegsi(i32 signext %a, i32 signext %b, i32 signext %c, i32 signext %d) { +entry: + %vecinit = insertelement <4 x i32> undef, i32 %a, i32 0 + %vecinit1 = insertelement <4 x i32> %vecinit, i32 %b, i32 1 + %vecinit2 = insertelement <4 x i32> %vecinit1, i32 %c, i32 2 + %vecinit3 = insertelement <4 x i32> %vecinit2, i32 %d, i32 3 + ret <4 x i32> %vecinit3 +; P9BE-LABEL: fromRegsi +; P9LE-LABEL: fromRegsi +; P8BE-LABEL: fromRegsi +; P8LE-LABEL: fromRegsi +; P9BE-DAG: mtvsrdd [[REG1:v[0-9]+]], r3, r5 +; P9BE-DAG: mtvsrdd [[REG2:v[0-9]+]], r4, r6 +; P9BE: vmrgow v2, [[REG1]], [[REG2]] +; P9BE: blr +; P9LE-DAG: mtvsrdd [[REG1:v[0-9]+]], r5, r3 +; P9LE-DAG: mtvsrdd [[REG2:v[0-9]+]], r6, r4 +; P9LE: vmrgow v2, [[REG2]], [[REG1]] +; P9LE: blr +; P8BE-DAG: mtvsrwz {{[vf]}}[[REG1:[0-9]+]], r3 +; P8BE-DAG: mtvsrwz {{[vf]}}[[REG2:[0-9]+]], r4 +; P8BE-DAG: mtvsrwz {{[vf]}}[[REG3:[0-9]+]], r5 +; P8BE-DAG: mtvsrwz {{[vf]}}[[REG4:[0-9]+]], r6 +; P8BE-DAG: xxmrghd [[REG5:v[0-9]+]], {{[v][s]*}}[[REG1]], {{[v][s]*}}[[REG3]] +; P8BE-DAG: xxmrghd [[REG6:v[0-9]+]], {{[v][s]*}}[[REG2]], {{[v][s]*}}[[REG4]] +; P8BE: vmrgow v2, [[REG5]], [[REG6]] +; P8LE-DAG: mtvsrwz {{[vf]}}[[REG1:[0-9]+]], r3 +; P8LE-DAG: mtvsrwz {{[vf]}}[[REG2:[0-9]+]], r4 +; P8LE-DAG: mtvsrwz {{[vf]}}[[REG3:[0-9]+]], r5 +; P8LE-DAG: mtvsrwz {{[vf]}}[[REG4:[0-9]+]], r6 +; P8LE: xxmrghd [[REG5:v[0-9]+]], {{[v][s]*}}[[REG3]], {{[v][s]*}}[[REG1]] +; P8LE: xxmrghd [[REG6:v[0-9]+]], {{[v][s]*}}[[REG4]], {{[v][s]*}}[[REG2]] +; P8LE: vmrgow v2, [[REG6]], [[REG5]] +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromDiffConstsi() { +entry: + ret <4 x i32> +; P9BE-LABEL: fromDiffConstsi +; P9LE-LABEL: fromDiffConstsi +; P8BE-LABEL: fromDiffConstsi +; P8LE-LABEL: fromDiffConstsi +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvw4x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsAi(i32* nocapture readonly %arr) { +entry: + %0 = load i32, i32* %arr, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %arrayidx1 = getelementptr inbounds i32, i32* %arr, i64 1 + %1 = load i32, i32* %arrayidx1, align 4 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %arrayidx3 = getelementptr inbounds i32, i32* %arr, i64 2 + %2 = load i32, i32* %arrayidx3, align 4 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %2, i32 2 + %arrayidx5 = getelementptr inbounds i32, i32* %arr, i64 3 + %3 = load i32, i32* %arrayidx5, align 4 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %3, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromDiffMemConsAi +; P9LE-LABEL: fromDiffMemConsAi +; P8BE-LABEL: fromDiffMemConsAi +; P8LE-LABEL: fromDiffMemConsAi +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvw4x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsDi(i32* nocapture readonly %arr) { +entry: + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 3 + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %arrayidx1 = getelementptr inbounds i32, i32* %arr, i64 2 + %1 = load i32, i32* %arrayidx1, align 4 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %arrayidx3 = getelementptr inbounds i32, i32* %arr, i64 1 + %2 = load i32, i32* %arrayidx3, align 4 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %2, i32 2 + %3 = load i32, i32* %arr, align 4 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %3, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromDiffMemConsDi +; P9LE-LABEL: fromDiffMemConsDi +; P8BE-LABEL: fromDiffMemConsDi +; P8LE-LABEL: fromDiffMemConsDi +; P9BE: lxvx +; P9BE: lxvx +; P9BE: vperm +; P9BE: blr +; P9LE: lxvx +; P9LE: lxvx +; P9LE: vperm +; P9LE: blr +; P8BE: lxvw4x +; P8BE: lxvw4x +; P8BE: vperm +; P8BE: blr +; P8LE: lxvd2x +; P8LE-DAG: lxvd2x +; P8LE-DAG: xxswapd +; P8LE: xxswapd +; P8LE: vperm +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarAi(i32* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 %idxprom + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds i32, i32* %arr, i64 %idxprom1 + %1 = load i32, i32* %arrayidx2, align 4 + %vecinit3 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %add4 = add nsw i32 %elem, 2 + %idxprom5 = sext i32 %add4 to i64 + %arrayidx6 = getelementptr inbounds i32, i32* %arr, i64 %idxprom5 + %2 = load i32, i32* %arrayidx6, align 4 + %vecinit7 = insertelement <4 x i32> %vecinit3, i32 %2, i32 2 + %add8 = add nsw i32 %elem, 3 + %idxprom9 = sext i32 %add8 to i64 + %arrayidx10 = getelementptr inbounds i32, i32* %arr, i64 %idxprom9 + %3 = load i32, i32* %arrayidx10, align 4 + %vecinit11 = insertelement <4 x i32> %vecinit7, i32 %3, i32 3 + ret <4 x i32> %vecinit11 +; P9BE-LABEL: fromDiffMemVarAi +; P9LE-LABEL: fromDiffMemVarAi +; P8BE-LABEL: fromDiffMemVarAi +; P8LE-LABEL: fromDiffMemVarAi +; P9BE: sldi r4, r4, 2 +; P9BE: lxvx v2, r3, r4 +; P9BE: blr +; P9LE: sldi r4, r4, 2 +; P9LE: lxvx v2, r3, r4 +; P9LE: blr +; P8BE: sldi r4, r4, 2 +; P8BE: lxvw4x {{[vs0-9]+}}, r3, r4 +; P8BE: blr +; P8LE: sldi r4, r4, 2 +; P8LE: lxvd2x {{[vs0-9]+}}, r3, r4 +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarDi(i32* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 %idxprom + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds i32, i32* %arr, i64 %idxprom1 + %1 = load i32, i32* %arrayidx2, align 4 + %vecinit3 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %sub4 = add nsw i32 %elem, -2 + %idxprom5 = sext i32 %sub4 to i64 + %arrayidx6 = getelementptr inbounds i32, i32* %arr, i64 %idxprom5 + %2 = load i32, i32* %arrayidx6, align 4 + %vecinit7 = insertelement <4 x i32> %vecinit3, i32 %2, i32 2 + %sub8 = add nsw i32 %elem, -3 + %idxprom9 = sext i32 %sub8 to i64 + %arrayidx10 = getelementptr inbounds i32, i32* %arr, i64 %idxprom9 + %3 = load i32, i32* %arrayidx10, align 4 + %vecinit11 = insertelement <4 x i32> %vecinit7, i32 %3, i32 3 + ret <4 x i32> %vecinit11 +; P9BE-LABEL: fromDiffMemVarDi +; P9LE-LABEL: fromDiffMemVarDi +; P8BE-LABEL: fromDiffMemVarDi +; P8LE-LABEL: fromDiffMemVarDi +; P9BE: sldi r4, r4, 2 +; P9BE-DAG: lxvx {{[vs0-9]+}}, r3, r4 +; P9BE-DAG: lxvx +; P9BE: vperm +; P9BE: blr +; P9LE: sldi r4, r4, 2 +; P9LE-DAG: lxvx {{[vs0-9]+}}, r3, r4 +; P9LE-DAG: lxvx +; P9LE: vperm +; P9LE: blr +; P8BE: sldi r4, r4, 2 +; P8BE-DAG: lxvw4x {{[vs0-9]+}}, r3, r4 +; P8BE-DAG: lxvw4x +; P8BE: vperm +; P8BE: blr +; P8LE: sldi r4, r4, 2 +; P8LE-DAG: lxvd2x +; P8LE-DAG: lxvd2x +; P8LE-DAG: xxswapd +; P8LE: xxswapd +; P8LE: vperm +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromRandMemConsi(i32* nocapture readonly %arr) { +entry: + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 4 + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %arrayidx1 = getelementptr inbounds i32, i32* %arr, i64 18 + %1 = load i32, i32* %arrayidx1, align 4 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %arrayidx3 = getelementptr inbounds i32, i32* %arr, i64 2 + %2 = load i32, i32* %arrayidx3, align 4 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %2, i32 2 + %arrayidx5 = getelementptr inbounds i32, i32* %arr, i64 88 + %3 = load i32, i32* %arrayidx5, align 4 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %3, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromRandMemConsi +; P9LE-LABEL: fromRandMemConsi +; P8BE-LABEL: fromRandMemConsi +; P8LE-LABEL: fromRandMemConsi +; P9BE: lwz +; P9BE: lwz +; P9BE: lwz +; P9BE: lwz +; P9BE: mtvsrdd +; P9BE: mtvsrdd +; P9BE: vmrgow +; P9LE: lwz +; P9LE: lwz +; P9LE: lwz +; P9LE: lwz +; P9LE: mtvsrdd +; P9LE: mtvsrdd +; P9LE: vmrgow +; P8BE: lwz +; P8BE: lwz +; P8BE: lwz +; P8BE: lwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: vmrgow +; P8LE: lwz +; P8LE: lwz +; P8LE: lwz +; P8LE: lwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: vmrgow +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromRandMemVari(i32* nocapture readonly %arr, i32 signext %elem) { +entry: + %add = add nsw i32 %elem, 4 + %idxprom = sext i32 %add to i64 + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 %idxprom + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %add1 = add nsw i32 %elem, 1 + %idxprom2 = sext i32 %add1 to i64 + %arrayidx3 = getelementptr inbounds i32, i32* %arr, i64 %idxprom2 + %1 = load i32, i32* %arrayidx3, align 4 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %add5 = add nsw i32 %elem, 2 + %idxprom6 = sext i32 %add5 to i64 + %arrayidx7 = getelementptr inbounds i32, i32* %arr, i64 %idxprom6 + %2 = load i32, i32* %arrayidx7, align 4 + %vecinit8 = insertelement <4 x i32> %vecinit4, i32 %2, i32 2 + %add9 = add nsw i32 %elem, 8 + %idxprom10 = sext i32 %add9 to i64 + %arrayidx11 = getelementptr inbounds i32, i32* %arr, i64 %idxprom10 + %3 = load i32, i32* %arrayidx11, align 4 + %vecinit12 = insertelement <4 x i32> %vecinit8, i32 %3, i32 3 + ret <4 x i32> %vecinit12 +; P9BE-LABEL: fromRandMemVari +; P9LE-LABEL: fromRandMemVari +; P8BE-LABEL: fromRandMemVari +; P8LE-LABEL: fromRandMemVari +; P9BE: sldi r4, r4, 2 +; P9BE: lwz +; P9BE: lwz +; P9BE: lwz +; P9BE: lwz +; P9BE: mtvsrdd +; P9BE: mtvsrdd +; P9BE: vmrgow +; P9LE: sldi r4, r4, 2 +; P9LE: lwz +; P9LE: lwz +; P9LE: lwz +; P9LE: lwz +; P9LE: mtvsrdd +; P9LE: mtvsrdd +; P9LE: vmrgow +; P8BE: sldi r4, r4, 2 +; P8BE: lwz +; P8BE: lwz +; P8BE: lwz +; P8BE: lwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: vmrgow +; P8LE: sldi r4, r4, 2 +; P8LE: lwz +; P8LE: lwz +; P8LE: lwz +; P8LE: lwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: vmrgow +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltRegVali(i32 signext %val) { +entry: + %splat.splatinsert = insertelement <4 x i32> undef, i32 %val, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltRegVali +; P9LE-LABEL: spltRegVali +; P8BE-LABEL: spltRegVali +; P8LE-LABEL: spltRegVali +; P9BE: mtvsrws v2, r3 +; P9BE: blr +; P9LE: mtvsrws v2, r3 +; P9LE: blr +; P8BE: mtvsrwz {{[vsf0-9]+}}, r3 +; P8BE: xxspltw v2, {{[vsf0-9]+}}, 1 +; P8BE: blr +; P8LE: mtvsrwz {{[vsf0-9]+}}, r3 +; P8LE: xxspltw v2, {{[vsf0-9]+}}, 1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @spltMemVali(i32* nocapture readonly %ptr) { +entry: + %0 = load i32, i32* %ptr, align 4 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %0, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltMemVali +; P9LE-LABEL: spltMemVali +; P8BE-LABEL: spltMemVali +; P8LE-LABEL: spltMemVali +; P9BE: lxvwsx v2, 0, r3 +; P9BE: blr +; P9LE: lxvwsx v2, 0, r3 +; P9LE: blr +; P8BE: lxsiwax {{[vsf0-9]+}}, 0, r3 +; P8BE: xxspltw v2, {{[vsf0-9]+}}, 1 +; P8BE: blr +; P8LE: lxsiwax {{[vsf0-9]+}}, 0, r3 +; P8LE: xxspltw v2, {{[vsf0-9]+}}, 1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltCnstConvftoi() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltCnstConvftoi +; P9LE-LABEL: spltCnstConvftoi +; P8BE-LABEL: spltCnstConvftoi +; P8LE-LABEL: spltCnstConvftoi +; P9BE: vspltisw v2, 4 +; P9BE: blr +; P9LE: vspltisw v2, 4 +; P9LE: blr +; P8BE: vspltisw v2, 4 +; P8BE: blr +; P8LE: vspltisw v2, 4 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromRegsConvftoi(float %a, float %b, float %c, float %d) { +entry: + %conv = fptosi float %a to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %conv1 = fptosi float %b to i32 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %conv1, i32 1 + %conv3 = fptosi float %c to i32 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %conv3, i32 2 + %conv5 = fptosi float %d to i32 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %conv5, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromRegsConvftoi +; P9LE-LABEL: fromRegsConvftoi +; P8BE-LABEL: fromRegsConvftoi +; P8LE-LABEL: fromRegsConvftoi +; P9BE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs1, vs3 +; P9BE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs2, vs4 +; P9BE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P9BE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P9BE: vmrgew v2, [[REG3]], [[REG4]] +; P9BE: xvcvspsxws v2, v2 +; P9LE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs3, vs1 +; P9LE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs4, vs2 +; P9LE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P9LE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P9LE: vmrgew v2, [[REG4]], [[REG3]] +; P9LE: xvcvspsxws v2, v2 +; P8BE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs1, vs3 +; P8BE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs2, vs4 +; P8BE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P8BE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P8BE: vmrgew v2, [[REG3]], [[REG4]] +; P8BE: xvcvspsxws v2, v2 +; P8LE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs3, vs1 +; P8LE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs4, vs2 +; P8LE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P8LE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P8LE: vmrgew v2, [[REG4]], [[REG3]] +; P8LE: xvcvspsxws v2, v2 +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromDiffConstsConvftoi() { +entry: + ret <4 x i32> +; P9BE-LABEL: fromDiffConstsConvftoi +; P9LE-LABEL: fromDiffConstsConvftoi +; P8BE-LABEL: fromDiffConstsConvftoi +; P8LE-LABEL: fromDiffConstsConvftoi +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvw4x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsAConvftoi(float* nocapture readonly %ptr) { +entry: + %0 = bitcast float* %ptr to <4 x float>* + %1 = load <4 x float>, <4 x float>* %0, align 4 + %2 = fptosi <4 x float> %1 to <4 x i32> + ret <4 x i32> %2 +; P9BE-LABEL: fromDiffMemConsAConvftoi +; P9LE-LABEL: fromDiffMemConsAConvftoi +; P8BE-LABEL: fromDiffMemConsAConvftoi +; P8LE-LABEL: fromDiffMemConsAConvftoi +; P9BE: lxvx [[REG1:[vs0-9]+]], 0, r3 +; P9BE: xvcvspsxws v2, [[REG1]] +; P9BE: blr +; P9LE: lxvx [[REG1:[vs0-9]+]], 0, r3 +; P9LE: xvcvspsxws v2, [[REG1]] +; P9LE: blr +; P8BE: lxvw4x [[REG1:[vs0-9]+]], 0, r3 +; P8BE: xvcvspsxws v2, [[REG1]] +; P8BE: blr +; P8LE: lxvd2x [[REG1:[vs0-9]+]], 0, r3 +; P8LE: xxswapd v2, [[REG1]] +; P8LE: xvcvspsxws v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsDConvftoi(float* nocapture readonly %ptr) { +entry: + %arrayidx = getelementptr inbounds float, float* %ptr, i64 3 + %0 = load float, float* %arrayidx, align 4 + %conv = fptosi float %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %arrayidx1 = getelementptr inbounds float, float* %ptr, i64 2 + %1 = load float, float* %arrayidx1, align 4 + %conv2 = fptosi float %1 to i32 + %vecinit3 = insertelement <4 x i32> %vecinit, i32 %conv2, i32 1 + %arrayidx4 = getelementptr inbounds float, float* %ptr, i64 1 + %2 = load float, float* %arrayidx4, align 4 + %conv5 = fptosi float %2 to i32 + %vecinit6 = insertelement <4 x i32> %vecinit3, i32 %conv5, i32 2 + %3 = load float, float* %ptr, align 4 + %conv8 = fptosi float %3 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit6, i32 %conv8, i32 3 + ret <4 x i32> %vecinit9 +; P9BE-LABEL: fromDiffMemConsDConvftoi +; P9LE-LABEL: fromDiffMemConsDConvftoi +; P8BE-LABEL: fromDiffMemConsDConvftoi +; P8LE-LABEL: fromDiffMemConsDConvftoi +; P9BE: lxvx +; P9BE: lxvx +; P9BE: vperm +; P9BE: xvcvspsxws +; P9BE: blr +; P9LE: lxvx +; P9LE: lxvx +; P9LE: vperm +; P9LE: xvcvspsxws +; P9LE: blr +; P8BE: lxvw4x +; P8BE: lxvw4x +; P8BE: vperm +; P8BE: xvcvspsxws +; P8BE: blr +; P8LE: lxvd2x +; P8LE-DAG: lxvd2x +; P8LE-DAG: xxswapd +; P8LE: xxswapd +; P8LE: vperm +; P8LE: xvcvspsxws +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarAConvftoi(float* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds float, float* %arr, i64 %idxprom + %0 = load float, float* %arrayidx, align 4 + %conv = fptosi float %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds float, float* %arr, i64 %idxprom1 + %1 = load float, float* %arrayidx2, align 4 + %conv3 = fptosi float %1 to i32 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %conv3, i32 1 + %add5 = add nsw i32 %elem, 2 + %idxprom6 = sext i32 %add5 to i64 + %arrayidx7 = getelementptr inbounds float, float* %arr, i64 %idxprom6 + %2 = load float, float* %arrayidx7, align 4 + %conv8 = fptosi float %2 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit4, i32 %conv8, i32 2 + %add10 = add nsw i32 %elem, 3 + %idxprom11 = sext i32 %add10 to i64 + %arrayidx12 = getelementptr inbounds float, float* %arr, i64 %idxprom11 + %3 = load float, float* %arrayidx12, align 4 + %conv13 = fptosi float %3 to i32 + %vecinit14 = insertelement <4 x i32> %vecinit9, i32 %conv13, i32 3 + ret <4 x i32> %vecinit14 +; P9BE-LABEL: fromDiffMemVarAConvftoi +; P9LE-LABEL: fromDiffMemVarAConvftoi +; P8BE-LABEL: fromDiffMemVarAConvftoi +; P8LE-LABEL: fromDiffMemVarAConvftoi +; FIXME: implement finding consecutive loads with pre-inc +; P9BE: lfsux +; P9LE: lfsux +; P8BE: lfsux +; P8LE: lfsux +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarDConvftoi(float* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds float, float* %arr, i64 %idxprom + %0 = load float, float* %arrayidx, align 4 + %conv = fptosi float %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds float, float* %arr, i64 %idxprom1 + %1 = load float, float* %arrayidx2, align 4 + %conv3 = fptosi float %1 to i32 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %conv3, i32 1 + %sub5 = add nsw i32 %elem, -2 + %idxprom6 = sext i32 %sub5 to i64 + %arrayidx7 = getelementptr inbounds float, float* %arr, i64 %idxprom6 + %2 = load float, float* %arrayidx7, align 4 + %conv8 = fptosi float %2 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit4, i32 %conv8, i32 2 + %sub10 = add nsw i32 %elem, -3 + %idxprom11 = sext i32 %sub10 to i64 + %arrayidx12 = getelementptr inbounds float, float* %arr, i64 %idxprom11 + %3 = load float, float* %arrayidx12, align 4 + %conv13 = fptosi float %3 to i32 + %vecinit14 = insertelement <4 x i32> %vecinit9, i32 %conv13, i32 3 + ret <4 x i32> %vecinit14 +; P9BE-LABEL: fromDiffMemVarDConvftoi +; P9LE-LABEL: fromDiffMemVarDConvftoi +; P8BE-LABEL: fromDiffMemVarDConvftoi +; P8LE-LABEL: fromDiffMemVarDConvftoi +; FIXME: implement finding consecutive loads with pre-inc +; P9BE: lfsux +; P9LE: lfsux +; P8BE: lfsux +; P8LE: lfsux +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltRegValConvftoi(float %val) { +entry: + %conv = fptosi float %val to i32 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltRegValConvftoi +; P9LE-LABEL: spltRegValConvftoi +; P8BE-LABEL: spltRegValConvftoi +; P8LE-LABEL: spltRegValConvftoi +; P9BE: xscvdpsxws f[[REG1:[0-9]+]], f1 +; P9BE: xxspltw v2, vs[[REG1]], 1 +; P9BE: blr +; P9LE: xscvdpsxws f[[REG1:[0-9]+]], f1 +; P9LE: xxspltw v2, vs[[REG1]], 1 +; P9LE: blr +; P8BE: xscvdpsxws f[[REG1:[0-9]+]], f1 +; P8BE: xxspltw v2, vs[[REG1]], 1 +; P8BE: blr +; P8LE: xscvdpsxws f[[REG1:[0-9]+]], f1 +; P8LE: xxspltw v2, vs[[REG1]], 1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @spltMemValConvftoi(float* nocapture readonly %ptr) { +entry: + %0 = load float, float* %ptr, align 4 + %conv = fptosi float %0 to i32 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltMemValConvftoi +; P9LE-LABEL: spltMemValConvftoi +; P8BE-LABEL: spltMemValConvftoi +; P8LE-LABEL: spltMemValConvftoi +; P9BE: lxvwsx [[REG1:[vs0-9]+]], 0, r3 +; P9BE: xvcvspsxws v2, [[REG1]] +; P9LE: [[REG1:[vs0-9]+]], 0, r3 +; P9LE: xvcvspsxws v2, [[REG1]] +; P8BE: lxsspx [[REG1:f[0-9]+]], 0, r3 +; P8BE: xscvdpsxws f[[REG2:[0-9]+]], [[REG1]] +; P8BE: xxspltw v2, vs[[REG2]], 1 +; P8LE: lxsspx [[REG1:f[0-9]+]], 0, r3 +; P8LE: xscvdpsxws f[[REG2:[vs0-9]+]], [[REG1]] +; P8LE: xxspltw v2, vs[[REG2]], 1 +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltCnstConvdtoi() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltCnstConvdtoi +; P9LE-LABEL: spltCnstConvdtoi +; P8BE-LABEL: spltCnstConvdtoi +; P8LE-LABEL: spltCnstConvdtoi +; P9BE: vspltisw v2, 4 +; P9BE: blr +; P9LE: vspltisw v2, 4 +; P9LE: blr +; P8BE: vspltisw v2, 4 +; P8BE: blr +; P8LE: vspltisw v2, 4 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromRegsConvdtoi(double %a, double %b, double %c, double %d) { +entry: + %conv = fptosi double %a to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %conv1 = fptosi double %b to i32 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %conv1, i32 1 + %conv3 = fptosi double %c to i32 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %conv3, i32 2 + %conv5 = fptosi double %d to i32 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %conv5, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromRegsConvdtoi +; P9LE-LABEL: fromRegsConvdtoi +; P8BE-LABEL: fromRegsConvdtoi +; P8LE-LABEL: fromRegsConvdtoi +; P9BE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs1, vs3 +; P9BE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs2, vs4 +; P9BE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P9BE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P9BE: vmrgew v2, [[REG3]], [[REG4]] +; P9BE: xvcvspsxws v2, v2 +; P9LE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs3, vs1 +; P9LE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs4, vs2 +; P9LE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P9LE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P9LE: vmrgew v2, [[REG4]], [[REG3]] +; P9LE: xvcvspsxws v2, v2 +; P8BE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs1, vs3 +; P8BE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs2, vs4 +; P8BE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P8BE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P8BE: vmrgew v2, [[REG3]], [[REG4]] +; P8BE: xvcvspsxws v2, v2 +; P8LE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs3, vs1 +; P8LE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs4, vs2 +; P8LE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P8LE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P8LE: vmrgew v2, [[REG4]], [[REG3]] +; P8LE: xvcvspsxws v2, v2 +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromDiffConstsConvdtoi() { +entry: + ret <4 x i32> +; P9BE-LABEL: fromDiffConstsConvdtoi +; P9LE-LABEL: fromDiffConstsConvdtoi +; P8BE-LABEL: fromDiffConstsConvdtoi +; P8LE-LABEL: fromDiffConstsConvdtoi +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvw4x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsAConvdtoi(double* nocapture readonly %ptr) { +entry: + %0 = bitcast double* %ptr to <2 x double>* + %1 = load <2 x double>, <2 x double>* %0, align 8 + %2 = fptosi <2 x double> %1 to <2 x i32> + %arrayidx4 = getelementptr inbounds double, double* %ptr, i64 2 + %3 = bitcast double* %arrayidx4 to <2 x double>* + %4 = load <2 x double>, <2 x double>* %3, align 8 + %5 = fptosi <2 x double> %4 to <2 x i32> + %vecinit9 = shufflevector <2 x i32> %2, <2 x i32> %5, <4 x i32> + ret <4 x i32> %vecinit9 +; P9BE-LABEL: fromDiffMemConsAConvdtoi +; P9LE-LABEL: fromDiffMemConsAConvdtoi +; P8BE-LABEL: fromDiffMemConsAConvdtoi +; P8LE-LABEL: fromDiffMemConsAConvdtoi +; P9BE: lxvx [[REG1:[vs0-9]+]], 0, r3 +; P9BE: lxvx [[REG2:[vs0-9]+]], r3, r4 +; P9BE-DAG: xxmrgld [[REG3:[vs0-9]+]], [[REG1]], [[REG2]] +; P9BE-DAG: xxmrghd [[REG4:[vs0-9]+]], [[REG1]], [[REG2]] +; P9BE-DAG: xvcvdpsp [[REG5:[vs0-9]+]], [[REG3]] +; P9BE-DAG: xvcvdpsp [[REG6:[vs0-9]+]], [[REG4]] +; P9BE: vmrgew v2, [[REG6]], [[REG5]] +; P9BE: xvcvspsxws v2, v2 +; P9LE: lxvx [[REG1:[vs0-9]+]], 0, r3 +; P9LE: lxvx [[REG2:[vs0-9]+]], r3, r4 +; P9LE-DAG: xxmrgld [[REG3:[vs0-9]+]], [[REG2]], [[REG1]] +; P9LE-DAG: xxmrghd [[REG4:[vs0-9]+]], [[REG2]], [[REG1]] +; P9LE-DAG: xvcvdpsp [[REG5:[vs0-9]+]], [[REG3]] +; P9LE-DAG: xvcvdpsp [[REG6:[vs0-9]+]], [[REG4]] +; P9LE: vmrgew v2, [[REG6]], [[REG5]] +; P9LE: xvcvspsxws v2, v2 +; P8BE: lxvd2x [[REG1:[vs0-9]+]], 0, r3 +; P8BE: lxvd2x [[REG2:[vs0-9]+]], r3, r4 +; P8BE-DAG: xxmrgld [[REG3:[vs0-9]+]], [[REG1]], [[REG2]] +; P8BE-DAG: xxmrghd [[REG4:[vs0-9]+]], [[REG1]], [[REG2]] +; P8BE-DAG: xvcvdpsp [[REG5:[vs0-9]+]], [[REG3]] +; P8BE-DAG: xvcvdpsp [[REG6:[vs0-9]+]], [[REG4]] +; P8BE: vmrgew v2, [[REG6]], [[REG5]] +; P8BE: xvcvspsxws v2, v2 +; P8LE: lxvd2x [[REG1:[vs0-9]+]], 0, r3 +; P8LE: lxvd2x [[REG2:[vs0-9]+]], r3, r4 +; P8LE-DAG: xxswapd [[REG3:[vs0-9]+]], [[REG1]] +; P8LE-DAG: xxswapd [[REG4:[vs0-9]+]], [[REG2]] +; P8LE-DAG: xxmrgld [[REG5:[vs0-9]+]], [[REG4]], [[REG3]] +; P8LE-DAG: xxmrghd [[REG6:[vs0-9]+]], [[REG4]], [[REG3]] +; P8LE-DAG: xvcvdpsp [[REG7:[vs0-9]+]], [[REG5]] +; P8LE-DAG: xvcvdpsp [[REG8:[vs0-9]+]], [[REG6]] +; P8LE: vmrgew v2, [[REG8]], [[REG7]] +; P8LE: xvcvspsxws v2, v2 +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsDConvdtoi(double* nocapture readonly %ptr) { +entry: + %arrayidx = getelementptr inbounds double, double* %ptr, i64 3 + %0 = load double, double* %arrayidx, align 8 + %conv = fptosi double %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %arrayidx1 = getelementptr inbounds double, double* %ptr, i64 2 + %1 = load double, double* %arrayidx1, align 8 + %conv2 = fptosi double %1 to i32 + %vecinit3 = insertelement <4 x i32> %vecinit, i32 %conv2, i32 1 + %arrayidx4 = getelementptr inbounds double, double* %ptr, i64 1 + %2 = load double, double* %arrayidx4, align 8 + %conv5 = fptosi double %2 to i32 + %vecinit6 = insertelement <4 x i32> %vecinit3, i32 %conv5, i32 2 + %3 = load double, double* %ptr, align 8 + %conv8 = fptosi double %3 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit6, i32 %conv8, i32 3 + ret <4 x i32> %vecinit9 +; P9BE-LABEL: fromDiffMemConsDConvdtoi +; P9LE-LABEL: fromDiffMemConsDConvdtoi +; P8BE-LABEL: fromDiffMemConsDConvdtoi +; P8LE-LABEL: fromDiffMemConsDConvdtoi +; P9BE: lfd +; P9BE: lfd +; P9BE: lfd +; P9BE: lfd +; P9BE: xxmrghd +; P9BE: xxmrghd +; P9BE: xvcvdpsp +; P9BE: xvcvdpsp +; P9BE: vmrgew +; P9BE: xvcvspsxws v2 +; P9LE: lfd +; P9LE: lfd +; P9LE: lfd +; P9LE: lfd +; P9LE: xxmrghd +; P9LE: xxmrghd +; P9LE: xvcvdpsp +; P9LE: xvcvdpsp +; P9LE: vmrgew +; P9LE: xvcvspsxws v2 +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: xvcvdpsp +; P8BE: xvcvdpsp +; P8BE: vmrgew +; P8BE: xvcvspsxws v2 +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: xvcvdpsp +; P8LE: xvcvdpsp +; P8LE: vmrgew +; P8LE: xvcvspsxws v2 +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarAConvdtoi(double* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds double, double* %arr, i64 %idxprom + %0 = load double, double* %arrayidx, align 8 + %conv = fptosi double %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds double, double* %arr, i64 %idxprom1 + %1 = load double, double* %arrayidx2, align 8 + %conv3 = fptosi double %1 to i32 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %conv3, i32 1 + %add5 = add nsw i32 %elem, 2 + %idxprom6 = sext i32 %add5 to i64 + %arrayidx7 = getelementptr inbounds double, double* %arr, i64 %idxprom6 + %2 = load double, double* %arrayidx7, align 8 + %conv8 = fptosi double %2 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit4, i32 %conv8, i32 2 + %add10 = add nsw i32 %elem, 3 + %idxprom11 = sext i32 %add10 to i64 + %arrayidx12 = getelementptr inbounds double, double* %arr, i64 %idxprom11 + %3 = load double, double* %arrayidx12, align 8 + %conv13 = fptosi double %3 to i32 + %vecinit14 = insertelement <4 x i32> %vecinit9, i32 %conv13, i32 3 + ret <4 x i32> %vecinit14 +; P9BE-LABEL: fromDiffMemVarAConvdtoi +; P9LE-LABEL: fromDiffMemVarAConvdtoi +; P8BE-LABEL: fromDiffMemVarAConvdtoi +; P8LE-LABEL: fromDiffMemVarAConvdtoi +; P9BE: lfdux +; P9BE: lfd +; P9BE: lfd +; P9BE: lfd +; P9BE: xxmrghd +; P9BE: xxmrghd +; P9BE: xvcvdpsp +; P9BE: xvcvdpsp +; P9BE: vmrgew +; P9BE: xvcvspsxws v2 +; P9LE: lfdux +; P9LE: lfd +; P9LE: lfd +; P9LE: lfd +; P9LE: xxmrghd +; P9LE: xxmrghd +; P9LE: xvcvdpsp +; P9LE: xvcvdpsp +; P9LE: vmrgew +; P9LE: xvcvspsxws v2 +; P8BE: lfdux +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: xvcvdpsp +; P8BE: xvcvdpsp +; P8BE: vmrgew +; P8BE: xvcvspsxws v2 +; P8LE: lfdux +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: xvcvdpsp +; P8LE: xvcvdpsp +; P8LE: vmrgew +; P8LE: xvcvspsxws v2 +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarDConvdtoi(double* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds double, double* %arr, i64 %idxprom + %0 = load double, double* %arrayidx, align 8 + %conv = fptosi double %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds double, double* %arr, i64 %idxprom1 + %1 = load double, double* %arrayidx2, align 8 + %conv3 = fptosi double %1 to i32 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %conv3, i32 1 + %sub5 = add nsw i32 %elem, -2 + %idxprom6 = sext i32 %sub5 to i64 + %arrayidx7 = getelementptr inbounds double, double* %arr, i64 %idxprom6 + %2 = load double, double* %arrayidx7, align 8 + %conv8 = fptosi double %2 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit4, i32 %conv8, i32 2 + %sub10 = add nsw i32 %elem, -3 + %idxprom11 = sext i32 %sub10 to i64 + %arrayidx12 = getelementptr inbounds double, double* %arr, i64 %idxprom11 + %3 = load double, double* %arrayidx12, align 8 + %conv13 = fptosi double %3 to i32 + %vecinit14 = insertelement <4 x i32> %vecinit9, i32 %conv13, i32 3 + ret <4 x i32> %vecinit14 +; P9BE-LABEL: fromDiffMemVarDConvdtoi +; P9LE-LABEL: fromDiffMemVarDConvdtoi +; P8BE-LABEL: fromDiffMemVarDConvdtoi +; P8LE-LABEL: fromDiffMemVarDConvdtoi +; P9BE: lfdux +; P9BE: lfd +; P9BE: lfd +; P9BE: lfd +; P9BE: xxmrghd +; P9BE: xxmrghd +; P9BE: xvcvdpsp +; P9BE: xvcvdpsp +; P9BE: vmrgew +; P9BE: xvcvspsxws v2 +; P9LE: lfdux +; P9LE: lfd +; P9LE: lfd +; P9LE: lfd +; P9LE: xxmrghd +; P9LE: xxmrghd +; P9LE: xvcvdpsp +; P9LE: xvcvdpsp +; P9LE: vmrgew +; P9LE: xvcvspsxws v2 +; P8BE: lfdux +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: xvcvdpsp +; P8BE: xvcvdpsp +; P8BE: vmrgew +; P8BE: xvcvspsxws v2 +; P8LE: lfdux +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: xvcvdpsp +; P8LE: xvcvdpsp +; P8LE: vmrgew +; P8LE: xvcvspsxws v2 +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltRegValConvdtoi(double %val) { +entry: + %conv = fptosi double %val to i32 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltRegValConvdtoi +; P9LE-LABEL: spltRegValConvdtoi +; P8BE-LABEL: spltRegValConvdtoi +; P8LE-LABEL: spltRegValConvdtoi +; P9BE: xscvdpsxws +; P9BE: xxspltw +; P9BE: blr +; P9LE: xscvdpsxws +; P9LE: xxspltw +; P9LE: blr +; P8BE: xscvdpsxws +; P8BE: xxspltw +; P8BE: blr +; P8LE: xscvdpsxws +; P8LE: xxspltw +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @spltMemValConvdtoi(double* nocapture readonly %ptr) { +entry: + %0 = load double, double* %ptr, align 8 + %conv = fptosi double %0 to i32 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltMemValConvdtoi +; P9LE-LABEL: spltMemValConvdtoi +; P8BE-LABEL: spltMemValConvdtoi +; P8LE-LABEL: spltMemValConvdtoi +; P9BE: lfd +; P9BE: xscvdpsxws +; P9BE: xxspltw +; P9BE: blr +; P9LE: lfd +; P9LE: xscvdpsxws +; P9LE: xxspltw +; P9LE: blr +; P8BE: lxsdx +; P8BE: xscvdpsxws +; P8BE: xxspltw +; P8BE: blr +; P8LE: lxsdx +; P8LE: xscvdpsxws +; P8LE: xxspltw +; P8LE: blr +} +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @allZeroui() { +entry: + ret <4 x i32> zeroinitializer +; P9BE-LABEL: allZeroui +; P9LE-LABEL: allZeroui +; P8BE-LABEL: allZeroui +; P8LE-LABEL: allZeroui +; P9BE: xxlxor v2, v2, v2 +; P9BE: blr +; P9LE: xxlxor v2, v2, v2 +; P9LE: blr +; P8BE: xxlxor v2, v2, v2 +; P8BE: blr +; P8LE: xxlxor v2, v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @allOneui() { +entry: + ret <4 x i32> +; P9BE-LABEL: allOneui +; P9LE-LABEL: allOneui +; P8BE-LABEL: allOneui +; P8LE-LABEL: allOneui +; P9BE: xxspltib v2, 255 +; P9BE: blr +; P9LE: xxspltib v2, 255 +; P9LE: blr +; P8BE: vspltisb v2, -1 +; P8BE: blr +; P8LE: vspltisb v2, -1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltConst1ui() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltConst1ui +; P9LE-LABEL: spltConst1ui +; P8BE-LABEL: spltConst1ui +; P8LE-LABEL: spltConst1ui +; P9BE: vspltisw v2, 1 +; P9BE: blr +; P9LE: vspltisw v2, 1 +; P9LE: blr +; P8BE: vspltisw v2, 1 +; P8BE: blr +; P8LE: vspltisw v2, 1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltConst16kui() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltConst16kui +; P9LE-LABEL: spltConst16kui +; P8BE-LABEL: spltConst16kui +; P8LE-LABEL: spltConst16kui +; P9BE: vspltisw v2, -15 +; P9BE: vsrw v2, v2, v2 +; P9BE: blr +; P9LE: vspltisw v2, -15 +; P9LE: vsrw v2, v2, v2 +; P9LE: blr +; P8BE: vspltisw v2, -15 +; P8BE: vsrw v2, v2, v2 +; P8BE: blr +; P8LE: vspltisw v2, -15 +; P8LE: vsrw v2, v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltConst32kui() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltConst32kui +; P9LE-LABEL: spltConst32kui +; P8BE-LABEL: spltConst32kui +; P8LE-LABEL: spltConst32kui +; P9BE: vspltisw v2, -16 +; P9BE: vsrw v2, v2, v2 +; P9BE: blr +; P9LE: vspltisw v2, -16 +; P9LE: vsrw v2, v2, v2 +; P9LE: blr +; P8BE: vspltisw v2, -16 +; P8BE: vsrw v2, v2, v2 +; P8BE: blr +; P8LE: vspltisw v2, -16 +; P8LE: vsrw v2, v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromRegsui(i32 zeroext %a, i32 zeroext %b, i32 zeroext %c, i32 zeroext %d) { +entry: + %vecinit = insertelement <4 x i32> undef, i32 %a, i32 0 + %vecinit1 = insertelement <4 x i32> %vecinit, i32 %b, i32 1 + %vecinit2 = insertelement <4 x i32> %vecinit1, i32 %c, i32 2 + %vecinit3 = insertelement <4 x i32> %vecinit2, i32 %d, i32 3 + ret <4 x i32> %vecinit3 +; P9BE-LABEL: fromRegsui +; P9LE-LABEL: fromRegsui +; P8BE-LABEL: fromRegsui +; P8LE-LABEL: fromRegsui +; P9BE-DAG: mtvsrdd [[REG1:v[0-9]+]], r3, r5 +; P9BE-DAG: mtvsrdd [[REG2:v[0-9]+]], r4, r6 +; P9BE: vmrgow v2, [[REG1]], [[REG2]] +; P9BE: blr +; P9LE-DAG: mtvsrdd [[REG1:v[0-9]+]], r5, r3 +; P9LE-DAG: mtvsrdd [[REG2:v[0-9]+]], r6, r4 +; P9LE: vmrgow v2, [[REG2]], [[REG1]] +; P9LE: blr +; P8BE-DAG: mtvsrwz {{[vf]}}[[REG1:[0-9]+]], r3 +; P8BE-DAG: mtvsrwz {{[vf]}}[[REG2:[0-9]+]], r4 +; P8BE-DAG: mtvsrwz {{[vf]}}[[REG3:[0-9]+]], r5 +; P8BE-DAG: mtvsrwz {{[vf]}}[[REG4:[0-9]+]], r6 +; P8BE-DAG: xxmrghd [[REG5:v[0-9]+]], {{[v][s]*}}[[REG1]], {{[v][s]*}}[[REG3]] +; P8BE-DAG: xxmrghd [[REG6:v[0-9]+]], {{[v][s]*}}[[REG2]], {{[v][s]*}}[[REG4]] +; P8BE: vmrgow v2, [[REG5]], [[REG6]] +; P8LE-DAG: mtvsrwz {{[vf]}}[[REG1:[0-9]+]], r3 +; P8LE-DAG: mtvsrwz {{[vf]}}[[REG2:[0-9]+]], r4 +; P8LE-DAG: mtvsrwz {{[vf]}}[[REG3:[0-9]+]], r5 +; P8LE-DAG: mtvsrwz {{[vf]}}[[REG4:[0-9]+]], r6 +; P8LE: xxmrghd [[REG5:v[0-9]+]], {{[v][s]*}}[[REG3]], {{[v][s]*}}[[REG1]] +; P8LE: xxmrghd [[REG6:v[0-9]+]], {{[v][s]*}}[[REG4]], {{[v][s]*}}[[REG2]] +; P8LE: vmrgow v2, [[REG6]], [[REG5]] +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromDiffConstsui() { +entry: + ret <4 x i32> +; P9BE-LABEL: fromDiffConstsui +; P9LE-LABEL: fromDiffConstsui +; P8BE-LABEL: fromDiffConstsui +; P8LE-LABEL: fromDiffConstsui +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvw4x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsAui(i32* nocapture readonly %arr) { +entry: + %0 = load i32, i32* %arr, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %arrayidx1 = getelementptr inbounds i32, i32* %arr, i64 1 + %1 = load i32, i32* %arrayidx1, align 4 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %arrayidx3 = getelementptr inbounds i32, i32* %arr, i64 2 + %2 = load i32, i32* %arrayidx3, align 4 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %2, i32 2 + %arrayidx5 = getelementptr inbounds i32, i32* %arr, i64 3 + %3 = load i32, i32* %arrayidx5, align 4 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %3, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromDiffMemConsAui +; P9LE-LABEL: fromDiffMemConsAui +; P8BE-LABEL: fromDiffMemConsAui +; P8LE-LABEL: fromDiffMemConsAui +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvw4x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsDui(i32* nocapture readonly %arr) { +entry: + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 3 + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %arrayidx1 = getelementptr inbounds i32, i32* %arr, i64 2 + %1 = load i32, i32* %arrayidx1, align 4 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %arrayidx3 = getelementptr inbounds i32, i32* %arr, i64 1 + %2 = load i32, i32* %arrayidx3, align 4 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %2, i32 2 + %3 = load i32, i32* %arr, align 4 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %3, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromDiffMemConsDui +; P9LE-LABEL: fromDiffMemConsDui +; P8BE-LABEL: fromDiffMemConsDui +; P8LE-LABEL: fromDiffMemConsDui +; P9BE: lxvx +; P9BE: lxvx +; P9BE: vperm +; P9BE: blr +; P9LE: lxvx +; P9LE: lxvx +; P9LE: vperm +; P9LE: blr +; P8BE: lxvw4x +; P8BE: lxvw4x +; P8BE: vperm +; P8BE: blr +; P8LE: lxvd2x +; P8LE-DAG: lxvd2x +; P8LE-DAG: xxswapd +; P8LE: xxswapd +; P8LE: vperm +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarAui(i32* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 %idxprom + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds i32, i32* %arr, i64 %idxprom1 + %1 = load i32, i32* %arrayidx2, align 4 + %vecinit3 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %add4 = add nsw i32 %elem, 2 + %idxprom5 = sext i32 %add4 to i64 + %arrayidx6 = getelementptr inbounds i32, i32* %arr, i64 %idxprom5 + %2 = load i32, i32* %arrayidx6, align 4 + %vecinit7 = insertelement <4 x i32> %vecinit3, i32 %2, i32 2 + %add8 = add nsw i32 %elem, 3 + %idxprom9 = sext i32 %add8 to i64 + %arrayidx10 = getelementptr inbounds i32, i32* %arr, i64 %idxprom9 + %3 = load i32, i32* %arrayidx10, align 4 + %vecinit11 = insertelement <4 x i32> %vecinit7, i32 %3, i32 3 + ret <4 x i32> %vecinit11 +; P9BE-LABEL: fromDiffMemVarAui +; P9LE-LABEL: fromDiffMemVarAui +; P8BE-LABEL: fromDiffMemVarAui +; P8LE-LABEL: fromDiffMemVarAui +; P9BE: sldi r4, r4, 2 +; P9BE: lxvx v2, r3, r4 +; P9BE: blr +; P9LE: sldi r4, r4, 2 +; P9LE: lxvx v2, r3, r4 +; P9LE: blr +; P8BE: sldi r4, r4, 2 +; P8BE: lxvw4x {{[vs0-9]+}}, r3, r4 +; P8BE: blr +; P8LE: sldi r4, r4, 2 +; P8LE: lxvd2x {{[vs0-9]+}}, r3, r4 +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarDui(i32* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 %idxprom + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds i32, i32* %arr, i64 %idxprom1 + %1 = load i32, i32* %arrayidx2, align 4 + %vecinit3 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %sub4 = add nsw i32 %elem, -2 + %idxprom5 = sext i32 %sub4 to i64 + %arrayidx6 = getelementptr inbounds i32, i32* %arr, i64 %idxprom5 + %2 = load i32, i32* %arrayidx6, align 4 + %vecinit7 = insertelement <4 x i32> %vecinit3, i32 %2, i32 2 + %sub8 = add nsw i32 %elem, -3 + %idxprom9 = sext i32 %sub8 to i64 + %arrayidx10 = getelementptr inbounds i32, i32* %arr, i64 %idxprom9 + %3 = load i32, i32* %arrayidx10, align 4 + %vecinit11 = insertelement <4 x i32> %vecinit7, i32 %3, i32 3 + ret <4 x i32> %vecinit11 +; P9BE-LABEL: fromDiffMemVarDui +; P9LE-LABEL: fromDiffMemVarDui +; P8BE-LABEL: fromDiffMemVarDui +; P8LE-LABEL: fromDiffMemVarDui +; P9BE: sldi r4, r4, 2 +; P9BE-DAG: lxvx {{[vs0-9]+}}, r3, r4 +; P9BE-DAG: lxvx +; P9BE: vperm +; P9BE: blr +; P9LE: sldi r4, r4, 2 +; P9LE-DAG: lxvx {{[vs0-9]+}}, r3, r4 +; P9LE-DAG: lxvx +; P9LE: vperm +; P9LE: blr +; P8BE: sldi r4, r4, 2 +; P8BE-DAG: lxvw4x {{[vs0-9]+}}, r3, r4 +; P8BE-DAG: lxvw4x +; P8BE: vperm +; P8BE: blr +; P8LE: sldi r4, r4, 2 +; P8LE-DAG: lxvd2x +; P8LE-DAG: lxvd2x +; P8LE-DAG: xxswapd +; P8LE: xxswapd +; P8LE: vperm +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromRandMemConsui(i32* nocapture readonly %arr) { +entry: + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 4 + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %arrayidx1 = getelementptr inbounds i32, i32* %arr, i64 18 + %1 = load i32, i32* %arrayidx1, align 4 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %arrayidx3 = getelementptr inbounds i32, i32* %arr, i64 2 + %2 = load i32, i32* %arrayidx3, align 4 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %2, i32 2 + %arrayidx5 = getelementptr inbounds i32, i32* %arr, i64 88 + %3 = load i32, i32* %arrayidx5, align 4 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %3, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromRandMemConsui +; P9LE-LABEL: fromRandMemConsui +; P8BE-LABEL: fromRandMemConsui +; P8LE-LABEL: fromRandMemConsui +; P9BE: lwz +; P9BE: lwz +; P9BE: lwz +; P9BE: lwz +; P9BE: mtvsrdd +; P9BE: mtvsrdd +; P9BE: vmrgow +; P9LE: lwz +; P9LE: lwz +; P9LE: lwz +; P9LE: lwz +; P9LE: mtvsrdd +; P9LE: mtvsrdd +; P9LE: vmrgow +; P8BE: lwz +; P8BE: lwz +; P8BE: lwz +; P8BE: lwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: vmrgow +; P8LE: lwz +; P8LE: lwz +; P8LE: lwz +; P8LE: lwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: vmrgow +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromRandMemVarui(i32* nocapture readonly %arr, i32 signext %elem) { +entry: + %add = add nsw i32 %elem, 4 + %idxprom = sext i32 %add to i64 + %arrayidx = getelementptr inbounds i32, i32* %arr, i64 %idxprom + %0 = load i32, i32* %arrayidx, align 4 + %vecinit = insertelement <4 x i32> undef, i32 %0, i32 0 + %add1 = add nsw i32 %elem, 1 + %idxprom2 = sext i32 %add1 to i64 + %arrayidx3 = getelementptr inbounds i32, i32* %arr, i64 %idxprom2 + %1 = load i32, i32* %arrayidx3, align 4 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %1, i32 1 + %add5 = add nsw i32 %elem, 2 + %idxprom6 = sext i32 %add5 to i64 + %arrayidx7 = getelementptr inbounds i32, i32* %arr, i64 %idxprom6 + %2 = load i32, i32* %arrayidx7, align 4 + %vecinit8 = insertelement <4 x i32> %vecinit4, i32 %2, i32 2 + %add9 = add nsw i32 %elem, 8 + %idxprom10 = sext i32 %add9 to i64 + %arrayidx11 = getelementptr inbounds i32, i32* %arr, i64 %idxprom10 + %3 = load i32, i32* %arrayidx11, align 4 + %vecinit12 = insertelement <4 x i32> %vecinit8, i32 %3, i32 3 + ret <4 x i32> %vecinit12 +; P9BE-LABEL: fromRandMemVarui +; P9LE-LABEL: fromRandMemVarui +; P8BE-LABEL: fromRandMemVarui +; P8LE-LABEL: fromRandMemVarui +; P9BE: sldi r4, r4, 2 +; P9BE: lwz +; P9BE: lwz +; P9BE: lwz +; P9BE: lwz +; P9BE: mtvsrdd +; P9BE: mtvsrdd +; P9BE: vmrgow +; P9LE: sldi r4, r4, 2 +; P9LE: lwz +; P9LE: lwz +; P9LE: lwz +; P9LE: lwz +; P9LE: mtvsrdd +; P9LE: mtvsrdd +; P9LE: vmrgow +; P8BE: sldi r4, r4, 2 +; P8BE: lwz +; P8BE: lwz +; P8BE: lwz +; P8BE: lwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: mtvsrwz +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: vmrgow +; P8LE: sldi r4, r4, 2 +; P8LE: lwz +; P8LE: lwz +; P8LE: lwz +; P8LE: lwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: mtvsrwz +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: vmrgow +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltRegValui(i32 zeroext %val) { +entry: + %splat.splatinsert = insertelement <4 x i32> undef, i32 %val, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltRegValui +; P9LE-LABEL: spltRegValui +; P8BE-LABEL: spltRegValui +; P8LE-LABEL: spltRegValui +; P9BE: mtvsrws v2, r3 +; P9BE: blr +; P9LE: mtvsrws v2, r3 +; P9LE: blr +; P8BE: mtvsrwz {{[vsf0-9]+}}, r3 +; P8BE: xxspltw v2, {{[vsf0-9]+}}, 1 +; P8BE: blr +; P8LE: mtvsrwz {{[vsf0-9]+}}, r3 +; P8LE: xxspltw v2, {{[vsf0-9]+}}, 1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @spltMemValui(i32* nocapture readonly %ptr) { +entry: + %0 = load i32, i32* %ptr, align 4 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %0, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltMemValui +; P9LE-LABEL: spltMemValui +; P8BE-LABEL: spltMemValui +; P8LE-LABEL: spltMemValui +; P9BE: lxvwsx v2, 0, r3 +; P9BE: blr +; P9LE: lxvwsx v2, 0, r3 +; P9LE: blr +; P8BE: lxsiwax {{[vsf0-9]+}}, 0, r3 +; P8BE: xxspltw v2, {{[vsf0-9]+}}, 1 +; P8BE: blr +; P8LE: lxsiwax {{[vsf0-9]+}}, 0, r3 +; P8LE: xxspltw v2, {{[vsf0-9]+}}, 1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltCnstConvftoui() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltCnstConvftoui +; P9LE-LABEL: spltCnstConvftoui +; P8BE-LABEL: spltCnstConvftoui +; P8LE-LABEL: spltCnstConvftoui +; P9BE: vspltisw v2, 4 +; P9BE: blr +; P9LE: vspltisw v2, 4 +; P9LE: blr +; P8BE: vspltisw v2, 4 +; P8BE: blr +; P8LE: vspltisw v2, 4 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromRegsConvftoui(float %a, float %b, float %c, float %d) { +entry: + %conv = fptoui float %a to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %conv1 = fptoui float %b to i32 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %conv1, i32 1 + %conv3 = fptoui float %c to i32 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %conv3, i32 2 + %conv5 = fptoui float %d to i32 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %conv5, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromRegsConvftoui +; P9LE-LABEL: fromRegsConvftoui +; P8BE-LABEL: fromRegsConvftoui +; P8LE-LABEL: fromRegsConvftoui +; P9BE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs1, vs3 +; P9BE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs2, vs4 +; P9BE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P9BE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P9BE: vmrgew v2, [[REG3]], [[REG4]] +; P9BE: xvcvspuxws v2, v2 +; P9LE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs3, vs1 +; P9LE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs4, vs2 +; P9LE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P9LE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P9LE: vmrgew v2, [[REG4]], [[REG3]] +; P9LE: xvcvspuxws v2, v2 +; P8BE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs1, vs3 +; P8BE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs2, vs4 +; P8BE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P8BE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P8BE: vmrgew v2, [[REG3]], [[REG4]] +; P8BE: xvcvspuxws v2, v2 +; P8LE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs3, vs1 +; P8LE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs4, vs2 +; P8LE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P8LE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P8LE: vmrgew v2, [[REG4]], [[REG3]] +; P8LE: xvcvspuxws v2, v2 +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromDiffConstsConvftoui() { +entry: + ret <4 x i32> +; P9BE-LABEL: fromDiffConstsConvftoui +; P9LE-LABEL: fromDiffConstsConvftoui +; P8BE-LABEL: fromDiffConstsConvftoui +; P8LE-LABEL: fromDiffConstsConvftoui +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvw4x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsAConvftoui(float* nocapture readonly %ptr) { +entry: + %0 = bitcast float* %ptr to <4 x float>* + %1 = load <4 x float>, <4 x float>* %0, align 4 + %2 = fptoui <4 x float> %1 to <4 x i32> + ret <4 x i32> %2 +; P9BE-LABEL: fromDiffMemConsAConvftoui +; P9LE-LABEL: fromDiffMemConsAConvftoui +; P8BE-LABEL: fromDiffMemConsAConvftoui +; P8LE-LABEL: fromDiffMemConsAConvftoui +; P9BE: lxvx [[REG1:[vs0-9]+]], 0, r3 +; P9BE: xvcvspuxws v2, [[REG1]] +; P9BE: blr +; P9LE: lxvx [[REG1:[vs0-9]+]], 0, r3 +; P9LE: xvcvspuxws v2, [[REG1]] +; P9LE: blr +; P8BE: lxvw4x [[REG1:[vs0-9]+]], 0, r3 +; P8BE: xvcvspuxws v2, [[REG1]] +; P8BE: blr +; P8LE: lxvd2x [[REG1:[vs0-9]+]], 0, r3 +; P8LE: xxswapd v2, [[REG1]] +; P8LE: xvcvspuxws v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsDConvftoui(float* nocapture readonly %ptr) { +entry: + %arrayidx = getelementptr inbounds float, float* %ptr, i64 3 + %0 = load float, float* %arrayidx, align 4 + %conv = fptoui float %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %arrayidx1 = getelementptr inbounds float, float* %ptr, i64 2 + %1 = load float, float* %arrayidx1, align 4 + %conv2 = fptoui float %1 to i32 + %vecinit3 = insertelement <4 x i32> %vecinit, i32 %conv2, i32 1 + %arrayidx4 = getelementptr inbounds float, float* %ptr, i64 1 + %2 = load float, float* %arrayidx4, align 4 + %conv5 = fptoui float %2 to i32 + %vecinit6 = insertelement <4 x i32> %vecinit3, i32 %conv5, i32 2 + %3 = load float, float* %ptr, align 4 + %conv8 = fptoui float %3 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit6, i32 %conv8, i32 3 + ret <4 x i32> %vecinit9 +; P9BE-LABEL: fromDiffMemConsDConvftoui +; P9LE-LABEL: fromDiffMemConsDConvftoui +; P8BE-LABEL: fromDiffMemConsDConvftoui +; P8LE-LABEL: fromDiffMemConsDConvftoui +; P9BE: lxvx +; P9BE: lxvx +; P9BE: vperm +; P9BE: xvcvspuxws +; P9BE: blr +; P9LE: lxvx +; P9LE: lxvx +; P9LE: vperm +; P9LE: xvcvspuxws +; P9LE: blr +; P8BE: lxvw4x +; P8BE: lxvw4x +; P8BE: vperm +; P8BE: xvcvspuxws +; P8BE: blr +; P8LE: lxvd2x +; P8LE-DAG: lxvd2x +; P8LE-DAG: xxswapd +; P8LE: xxswapd +; P8LE: vperm +; P8LE: xvcvspuxws +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarAConvftoui(float* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds float, float* %arr, i64 %idxprom + %0 = load float, float* %arrayidx, align 4 + %conv = fptoui float %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds float, float* %arr, i64 %idxprom1 + %1 = load float, float* %arrayidx2, align 4 + %conv3 = fptoui float %1 to i32 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %conv3, i32 1 + %add5 = add nsw i32 %elem, 2 + %idxprom6 = sext i32 %add5 to i64 + %arrayidx7 = getelementptr inbounds float, float* %arr, i64 %idxprom6 + %2 = load float, float* %arrayidx7, align 4 + %conv8 = fptoui float %2 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit4, i32 %conv8, i32 2 + %add10 = add nsw i32 %elem, 3 + %idxprom11 = sext i32 %add10 to i64 + %arrayidx12 = getelementptr inbounds float, float* %arr, i64 %idxprom11 + %3 = load float, float* %arrayidx12, align 4 + %conv13 = fptoui float %3 to i32 + %vecinit14 = insertelement <4 x i32> %vecinit9, i32 %conv13, i32 3 + ret <4 x i32> %vecinit14 +; P9BE-LABEL: fromDiffMemVarAConvftoui +; P9LE-LABEL: fromDiffMemVarAConvftoui +; P8BE-LABEL: fromDiffMemVarAConvftoui +; P8LE-LABEL: fromDiffMemVarAConvftoui +; FIXME: implement finding consecutive loads with pre-inc +; P9BE: lfsux +; P9LE: lfsux +; P8BE: lfsux +; P8LE: lfsux +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarDConvftoui(float* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds float, float* %arr, i64 %idxprom + %0 = load float, float* %arrayidx, align 4 + %conv = fptoui float %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds float, float* %arr, i64 %idxprom1 + %1 = load float, float* %arrayidx2, align 4 + %conv3 = fptoui float %1 to i32 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %conv3, i32 1 + %sub5 = add nsw i32 %elem, -2 + %idxprom6 = sext i32 %sub5 to i64 + %arrayidx7 = getelementptr inbounds float, float* %arr, i64 %idxprom6 + %2 = load float, float* %arrayidx7, align 4 + %conv8 = fptoui float %2 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit4, i32 %conv8, i32 2 + %sub10 = add nsw i32 %elem, -3 + %idxprom11 = sext i32 %sub10 to i64 + %arrayidx12 = getelementptr inbounds float, float* %arr, i64 %idxprom11 + %3 = load float, float* %arrayidx12, align 4 + %conv13 = fptoui float %3 to i32 + %vecinit14 = insertelement <4 x i32> %vecinit9, i32 %conv13, i32 3 + ret <4 x i32> %vecinit14 +; P9BE-LABEL: fromDiffMemVarDConvftoui +; P9LE-LABEL: fromDiffMemVarDConvftoui +; P8BE-LABEL: fromDiffMemVarDConvftoui +; P8LE-LABEL: fromDiffMemVarDConvftoui +; FIXME: implement finding consecutive loads with pre-inc +; P9BE: lfsux +; P9LE: lfsux +; P8BE: lfsux +; P8LE: lfsux +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltRegValConvftoui(float %val) { +entry: + %conv = fptoui float %val to i32 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltRegValConvftoui +; P9LE-LABEL: spltRegValConvftoui +; P8BE-LABEL: spltRegValConvftoui +; P8LE-LABEL: spltRegValConvftoui +; P9BE: xscvdpuxws f[[REG1:[0-9]+]], f1 +; P9BE: xxspltw v2, vs[[REG1]], 1 +; P9BE: blr +; P9LE: xscvdpuxws f[[REG1:[0-9]+]], f1 +; P9LE: xxspltw v2, vs[[REG1]], 1 +; P9LE: blr +; P8BE: xscvdpuxws f[[REG1:[0-9]+]], f1 +; P8BE: xxspltw v2, vs[[REG1]], 1 +; P8BE: blr +; P8LE: xscvdpuxws f[[REG1:[0-9]+]], f1 +; P8LE: xxspltw v2, vs[[REG1]], 1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @spltMemValConvftoui(float* nocapture readonly %ptr) { +entry: + %0 = load float, float* %ptr, align 4 + %conv = fptoui float %0 to i32 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltMemValConvftoui +; P9LE-LABEL: spltMemValConvftoui +; P8BE-LABEL: spltMemValConvftoui +; P8LE-LABEL: spltMemValConvftoui +; P9BE: lxvwsx [[REG1:[vs0-9]+]], 0, r3 +; P9BE: xvcvspuxws v2, [[REG1]] +; P9LE: [[REG1:[vs0-9]+]], 0, r3 +; P9LE: xvcvspuxws v2, [[REG1]] +; P8BE: lxsspx [[REG1:f[0-9]+]], 0, r3 +; P8BE: xscvdpuxws f[[REG2:[0-9]+]], [[REG1]] +; P8BE: xxspltw v2, vs[[REG2]], 1 +; P8LE: lxsspx [[REG1:f[0-9]+]], 0, r3 +; P8LE: xscvdpuxws f[[REG2:[vs0-9]+]], [[REG1]] +; P8LE: xxspltw v2, vs[[REG2]], 1 +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltCnstConvdtoui() { +entry: + ret <4 x i32> +; P9BE-LABEL: spltCnstConvdtoui +; P9LE-LABEL: spltCnstConvdtoui +; P8BE-LABEL: spltCnstConvdtoui +; P8LE-LABEL: spltCnstConvdtoui +; P9BE: vspltisw v2, 4 +; P9BE: blr +; P9LE: vspltisw v2, 4 +; P9LE: blr +; P8BE: vspltisw v2, 4 +; P8BE: blr +; P8LE: vspltisw v2, 4 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromRegsConvdtoui(double %a, double %b, double %c, double %d) { +entry: + %conv = fptoui double %a to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %conv1 = fptoui double %b to i32 + %vecinit2 = insertelement <4 x i32> %vecinit, i32 %conv1, i32 1 + %conv3 = fptoui double %c to i32 + %vecinit4 = insertelement <4 x i32> %vecinit2, i32 %conv3, i32 2 + %conv5 = fptoui double %d to i32 + %vecinit6 = insertelement <4 x i32> %vecinit4, i32 %conv5, i32 3 + ret <4 x i32> %vecinit6 +; P9BE-LABEL: fromRegsConvdtoui +; P9LE-LABEL: fromRegsConvdtoui +; P8BE-LABEL: fromRegsConvdtoui +; P8LE-LABEL: fromRegsConvdtoui +; P9BE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs1, vs3 +; P9BE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs2, vs4 +; P9BE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P9BE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P9BE: vmrgew v2, [[REG3]], [[REG4]] +; P9BE: xvcvspuxws v2, v2 +; P9LE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs3, vs1 +; P9LE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs4, vs2 +; P9LE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P9LE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P9LE: vmrgew v2, [[REG4]], [[REG3]] +; P9LE: xvcvspuxws v2, v2 +; P8BE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs1, vs3 +; P8BE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs2, vs4 +; P8BE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P8BE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P8BE: vmrgew v2, [[REG3]], [[REG4]] +; P8BE: xvcvspuxws v2, v2 +; P8LE-DAG: xxmrghd {{[vs]+}}[[REG1:[0-9]+]], vs3, vs1 +; P8LE-DAG: xxmrghd {{[vs]+}}[[REG2:[0-9]+]], vs4, vs2 +; P8LE-DAG: xvcvdpsp [[REG3:v[0-9]+]], {{[vs]+}}[[REG1]] +; P8LE-DAG: xvcvdpsp [[REG4:v[0-9]+]], {{[vs]+}}[[REG2]] +; P8LE: vmrgew v2, [[REG4]], [[REG3]] +; P8LE: xvcvspuxws v2, v2 +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @fromDiffConstsConvdtoui() { +entry: + ret <4 x i32> +; P9BE-LABEL: fromDiffConstsConvdtoui +; P9LE-LABEL: fromDiffConstsConvdtoui +; P8BE-LABEL: fromDiffConstsConvdtoui +; P8LE-LABEL: fromDiffConstsConvdtoui +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvw4x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsAConvdtoui(double* nocapture readonly %ptr) { +entry: + %0 = bitcast double* %ptr to <2 x double>* + %1 = load <2 x double>, <2 x double>* %0, align 8 + %2 = fptoui <2 x double> %1 to <2 x i32> + %arrayidx4 = getelementptr inbounds double, double* %ptr, i64 2 + %3 = bitcast double* %arrayidx4 to <2 x double>* + %4 = load <2 x double>, <2 x double>* %3, align 8 + %5 = fptoui <2 x double> %4 to <2 x i32> + %vecinit9 = shufflevector <2 x i32> %2, <2 x i32> %5, <4 x i32> + ret <4 x i32> %vecinit9 +; P9BE-LABEL: fromDiffMemConsAConvdtoui +; P9LE-LABEL: fromDiffMemConsAConvdtoui +; P8BE-LABEL: fromDiffMemConsAConvdtoui +; P8LE-LABEL: fromDiffMemConsAConvdtoui +; P9BE: lxvx [[REG1:[vs0-9]+]], 0, r3 +; P9BE: lxvx [[REG2:[vs0-9]+]], r3, r4 +; P9BE-DAG: xxmrgld [[REG3:[vs0-9]+]], [[REG1]], [[REG2]] +; P9BE-DAG: xxmrghd [[REG4:[vs0-9]+]], [[REG1]], [[REG2]] +; P9BE-DAG: xvcvdpsp [[REG5:[vs0-9]+]], [[REG3]] +; P9BE-DAG: xvcvdpsp [[REG6:[vs0-9]+]], [[REG4]] +; P9BE: vmrgew v2, [[REG6]], [[REG5]] +; P9BE: xvcvspuxws v2, v2 +; P9LE: lxvx [[REG1:[vs0-9]+]], 0, r3 +; P9LE: lxvx [[REG2:[vs0-9]+]], r3, r4 +; P9LE-DAG: xxmrgld [[REG3:[vs0-9]+]], [[REG2]], [[REG1]] +; P9LE-DAG: xxmrghd [[REG4:[vs0-9]+]], [[REG2]], [[REG1]] +; P9LE-DAG: xvcvdpsp [[REG5:[vs0-9]+]], [[REG3]] +; P9LE-DAG: xvcvdpsp [[REG6:[vs0-9]+]], [[REG4]] +; P9LE: vmrgew v2, [[REG6]], [[REG5]] +; P9LE: xvcvspuxws v2, v2 +; P8BE: lxvd2x [[REG1:[vs0-9]+]], 0, r3 +; P8BE: lxvd2x [[REG2:[vs0-9]+]], r3, r4 +; P8BE-DAG: xxmrgld [[REG3:[vs0-9]+]], [[REG1]], [[REG2]] +; P8BE-DAG: xxmrghd [[REG4:[vs0-9]+]], [[REG1]], [[REG2]] +; P8BE-DAG: xvcvdpsp [[REG5:[vs0-9]+]], [[REG3]] +; P8BE-DAG: xvcvdpsp [[REG6:[vs0-9]+]], [[REG4]] +; P8BE: vmrgew v2, [[REG6]], [[REG5]] +; P8BE: xvcvspuxws v2, v2 +; P8LE: lxvd2x [[REG1:[vs0-9]+]], 0, r3 +; P8LE: lxvd2x [[REG2:[vs0-9]+]], r3, r4 +; P8LE-DAG: xxswapd [[REG3:[vs0-9]+]], [[REG1]] +; P8LE-DAG: xxswapd [[REG4:[vs0-9]+]], [[REG2]] +; P8LE-DAG: xxmrgld [[REG5:[vs0-9]+]], [[REG4]], [[REG3]] +; P8LE-DAG: xxmrghd [[REG6:[vs0-9]+]], [[REG4]], [[REG3]] +; P8LE-DAG: xvcvdpsp [[REG7:[vs0-9]+]], [[REG5]] +; P8LE-DAG: xvcvdpsp [[REG8:[vs0-9]+]], [[REG6]] +; P8LE: vmrgew v2, [[REG8]], [[REG7]] +; P8LE: xvcvspuxws v2, v2 +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemConsDConvdtoui(double* nocapture readonly %ptr) { +entry: + %arrayidx = getelementptr inbounds double, double* %ptr, i64 3 + %0 = load double, double* %arrayidx, align 8 + %conv = fptoui double %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %arrayidx1 = getelementptr inbounds double, double* %ptr, i64 2 + %1 = load double, double* %arrayidx1, align 8 + %conv2 = fptoui double %1 to i32 + %vecinit3 = insertelement <4 x i32> %vecinit, i32 %conv2, i32 1 + %arrayidx4 = getelementptr inbounds double, double* %ptr, i64 1 + %2 = load double, double* %arrayidx4, align 8 + %conv5 = fptoui double %2 to i32 + %vecinit6 = insertelement <4 x i32> %vecinit3, i32 %conv5, i32 2 + %3 = load double, double* %ptr, align 8 + %conv8 = fptoui double %3 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit6, i32 %conv8, i32 3 + ret <4 x i32> %vecinit9 +; P9BE-LABEL: fromDiffMemConsDConvdtoui +; P9LE-LABEL: fromDiffMemConsDConvdtoui +; P8BE-LABEL: fromDiffMemConsDConvdtoui +; P8LE-LABEL: fromDiffMemConsDConvdtoui +; P9BE: lfd +; P9BE: lfd +; P9BE: lfd +; P9BE: lfd +; P9BE: xxmrghd +; P9BE: xxmrghd +; P9BE: xvcvdpsp +; P9BE: xvcvdpsp +; P9BE: vmrgew +; P9BE: xvcvspuxws v2 +; P9LE: lfd +; P9LE: lfd +; P9LE: lfd +; P9LE: lfd +; P9LE: xxmrghd +; P9LE: xxmrghd +; P9LE: xvcvdpsp +; P9LE: xvcvdpsp +; P9LE: vmrgew +; P9LE: xvcvspuxws v2 +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: xvcvdpsp +; P8BE: xvcvdpsp +; P8BE: vmrgew +; P8BE: xvcvspuxws v2 +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: xvcvdpsp +; P8LE: xvcvdpsp +; P8LE: vmrgew +; P8LE: xvcvspuxws v2 +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarAConvdtoui(double* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds double, double* %arr, i64 %idxprom + %0 = load double, double* %arrayidx, align 8 + %conv = fptoui double %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds double, double* %arr, i64 %idxprom1 + %1 = load double, double* %arrayidx2, align 8 + %conv3 = fptoui double %1 to i32 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %conv3, i32 1 + %add5 = add nsw i32 %elem, 2 + %idxprom6 = sext i32 %add5 to i64 + %arrayidx7 = getelementptr inbounds double, double* %arr, i64 %idxprom6 + %2 = load double, double* %arrayidx7, align 8 + %conv8 = fptoui double %2 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit4, i32 %conv8, i32 2 + %add10 = add nsw i32 %elem, 3 + %idxprom11 = sext i32 %add10 to i64 + %arrayidx12 = getelementptr inbounds double, double* %arr, i64 %idxprom11 + %3 = load double, double* %arrayidx12, align 8 + %conv13 = fptoui double %3 to i32 + %vecinit14 = insertelement <4 x i32> %vecinit9, i32 %conv13, i32 3 + ret <4 x i32> %vecinit14 +; P9BE-LABEL: fromDiffMemVarAConvdtoui +; P9LE-LABEL: fromDiffMemVarAConvdtoui +; P8BE-LABEL: fromDiffMemVarAConvdtoui +; P8LE-LABEL: fromDiffMemVarAConvdtoui +; P9BE: lfdux +; P9BE: lfd +; P9BE: lfd +; P9BE: lfd +; P9BE: xxmrghd +; P9BE: xxmrghd +; P9BE: xvcvdpsp +; P9BE: xvcvdpsp +; P9BE: vmrgew +; P9BE: xvcvspuxws v2 +; P9LE: lfdux +; P9LE: lfd +; P9LE: lfd +; P9LE: lfd +; P9LE: xxmrghd +; P9LE: xxmrghd +; P9LE: xvcvdpsp +; P9LE: xvcvdpsp +; P9LE: vmrgew +; P9LE: xvcvspuxws v2 +; P8BE: lfdux +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: xvcvdpsp +; P8BE: xvcvdpsp +; P8BE: vmrgew +; P8BE: xvcvspuxws v2 +; P8LE: lfdux +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: xvcvdpsp +; P8LE: xvcvdpsp +; P8LE: vmrgew +; P8LE: xvcvspuxws v2 +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @fromDiffMemVarDConvdtoui(double* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds double, double* %arr, i64 %idxprom + %0 = load double, double* %arrayidx, align 8 + %conv = fptoui double %0 to i32 + %vecinit = insertelement <4 x i32> undef, i32 %conv, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds double, double* %arr, i64 %idxprom1 + %1 = load double, double* %arrayidx2, align 8 + %conv3 = fptoui double %1 to i32 + %vecinit4 = insertelement <4 x i32> %vecinit, i32 %conv3, i32 1 + %sub5 = add nsw i32 %elem, -2 + %idxprom6 = sext i32 %sub5 to i64 + %arrayidx7 = getelementptr inbounds double, double* %arr, i64 %idxprom6 + %2 = load double, double* %arrayidx7, align 8 + %conv8 = fptoui double %2 to i32 + %vecinit9 = insertelement <4 x i32> %vecinit4, i32 %conv8, i32 2 + %sub10 = add nsw i32 %elem, -3 + %idxprom11 = sext i32 %sub10 to i64 + %arrayidx12 = getelementptr inbounds double, double* %arr, i64 %idxprom11 + %3 = load double, double* %arrayidx12, align 8 + %conv13 = fptoui double %3 to i32 + %vecinit14 = insertelement <4 x i32> %vecinit9, i32 %conv13, i32 3 + ret <4 x i32> %vecinit14 +; P9BE-LABEL: fromDiffMemVarDConvdtoui +; P9LE-LABEL: fromDiffMemVarDConvdtoui +; P8BE-LABEL: fromDiffMemVarDConvdtoui +; P8LE-LABEL: fromDiffMemVarDConvdtoui +; P9BE: lfdux +; P9BE: lfd +; P9BE: lfd +; P9BE: lfd +; P9BE: xxmrghd +; P9BE: xxmrghd +; P9BE: xvcvdpsp +; P9BE: xvcvdpsp +; P9BE: vmrgew +; P9BE: xvcvspuxws v2 +; P9LE: lfdux +; P9LE: lfd +; P9LE: lfd +; P9LE: lfd +; P9LE: xxmrghd +; P9LE: xxmrghd +; P9LE: xvcvdpsp +; P9LE: xvcvdpsp +; P9LE: vmrgew +; P9LE: xvcvspuxws v2 +; P8BE: lfdux +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: lxsdx +; P8BE: xxmrghd +; P8BE: xxmrghd +; P8BE: xvcvdpsp +; P8BE: xvcvdpsp +; P8BE: vmrgew +; P8BE: xvcvspuxws v2 +; P8LE: lfdux +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: lxsdx +; P8LE: xxmrghd +; P8LE: xxmrghd +; P8LE: xvcvdpsp +; P8LE: xvcvdpsp +; P8LE: vmrgew +; P8LE: xvcvspuxws v2 +} + +; Function Attrs: norecurse nounwind readnone +define <4 x i32> @spltRegValConvdtoui(double %val) { +entry: + %conv = fptoui double %val to i32 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltRegValConvdtoui +; P9LE-LABEL: spltRegValConvdtoui +; P8BE-LABEL: spltRegValConvdtoui +; P8LE-LABEL: spltRegValConvdtoui +; P9BE: xscvdpuxws +; P9BE: xxspltw +; P9BE: blr +; P9LE: xscvdpuxws +; P9LE: xxspltw +; P9LE: blr +; P8BE: xscvdpuxws +; P8BE: xxspltw +; P8BE: blr +; P8LE: xscvdpuxws +; P8LE: xxspltw +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <4 x i32> @spltMemValConvdtoui(double* nocapture readonly %ptr) { +entry: + %0 = load double, double* %ptr, align 8 + %conv = fptoui double %0 to i32 + %splat.splatinsert = insertelement <4 x i32> undef, i32 %conv, i32 0 + %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer + ret <4 x i32> %splat.splat +; P9BE-LABEL: spltMemValConvdtoui +; P9LE-LABEL: spltMemValConvdtoui +; P8BE-LABEL: spltMemValConvdtoui +; P8LE-LABEL: spltMemValConvdtoui +; P9BE: lfd +; P9BE: xscvdpuxws +; P9BE: xxspltw +; P9BE: blr +; P9LE: lfd +; P9LE: xscvdpuxws +; P9LE: xxspltw +; P9LE: blr +; P8BE: lxsdx +; P8BE: xscvdpuxws +; P8BE: xxspltw +; P8BE: blr +; P8LE: lxsdx +; P8LE: xscvdpuxws +; P8LE: xxspltw +; P8LE: blr +} +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @allZeroll() { +entry: + ret <2 x i64> zeroinitializer +; P9BE-LABEL: allZeroll +; P9LE-LABEL: allZeroll +; P8BE-LABEL: allZeroll +; P8LE-LABEL: allZeroll +; P9BE: xxlxor v2, v2, v2 +; P9BE: blr +; P9LE: xxlxor v2, v2, v2 +; P9LE: blr +; P8BE: xxlxor v2, v2, v2 +; P8BE: blr +; P8LE: xxlxor v2, v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @allOnell() { +entry: + ret <2 x i64> +; P9BE-LABEL: allOnell +; P9LE-LABEL: allOnell +; P8BE-LABEL: allOnell +; P8LE-LABEL: allOnell +; P9BE: xxspltib v2, 255 +; P9BE: blr +; P9LE: xxspltib v2, 255 +; P9LE: blr +; P8BE: vspltisb v2, -1 +; P8BE: blr +; P8LE: vspltisb v2, -1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltConst1ll() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltConst1ll +; P9LE-LABEL: spltConst1ll +; P8BE-LABEL: spltConst1ll +; P8LE-LABEL: spltConst1ll +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltConst16kll() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltConst16kll +; P9LE-LABEL: spltConst16kll +; P8BE-LABEL: spltConst16kll +; P8LE-LABEL: spltConst16kll +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltConst32kll() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltConst32kll +; P9LE-LABEL: spltConst32kll +; P8BE-LABEL: spltConst32kll +; P8LE-LABEL: spltConst32kll +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromRegsll(i64 %a, i64 %b) { +entry: + %vecinit = insertelement <2 x i64> undef, i64 %a, i32 0 + %vecinit1 = insertelement <2 x i64> %vecinit, i64 %b, i32 1 + ret <2 x i64> %vecinit1 +; P9BE-LABEL: fromRegsll +; P9LE-LABEL: fromRegsll +; P8BE-LABEL: fromRegsll +; P8LE-LABEL: fromRegsll +; P9BE: mtvsrdd v2, r3, r4 +; P9BE: blr +; P9LE: mtvsrdd v2, r4, r3 +; P9LE: blr +; P8BE-DAG: mtvsrd {{[vsf0-9]+}}, r3 +; P8BE-DAG: mtvsrd {{[vsf0-9]+}}, r4 +; P8BE: xxmrghd v2 +; P8BE: blr +; P8LE-DAG: mtvsrd {{[vsf0-9]+}}, r3 +; P8LE-DAG: mtvsrd {{[vsf0-9]+}}, r4 +; P8LE: xxmrghd v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromDiffConstsll() { +entry: + ret <2 x i64> +; P9BE-LABEL: fromDiffConstsll +; P9LE-LABEL: fromDiffConstsll +; P8BE-LABEL: fromDiffConstsll +; P8LE-LABEL: fromDiffConstsll +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsAll(i64* nocapture readonly %arr) { +entry: + %0 = load i64, i64* %arr, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %arrayidx1 = getelementptr inbounds i64, i64* %arr, i64 1 + %1 = load i64, i64* %arrayidx1, align 8 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromDiffMemConsAll +; P9LE-LABEL: fromDiffMemConsAll +; P8BE-LABEL: fromDiffMemConsAll +; P8LE-LABEL: fromDiffMemConsAll +; P9BE: lxvx v2 +; P9BE: blr +; P9LE: lxvx v2 +; P9LE: blr +; P8BE: lxvd2x v2 +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsDll(i64* nocapture readonly %arr) { +entry: + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 3 + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %arrayidx1 = getelementptr inbounds i64, i64* %arr, i64 2 + %1 = load i64, i64* %arrayidx1, align 8 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromDiffMemConsDll +; P9LE-LABEL: fromDiffMemConsDll +; P8BE-LABEL: fromDiffMemConsDll +; P8LE-LABEL: fromDiffMemConsDll +; P9BE: lxvx v2 +; P9BE: blr +; P9LE: lxvx +; P9LE: xxswapd v2 +; P9LE: blr +; P8BE: lxvd2x +; P8BE: xxswapd v2 +; P8BE-NEXT: blr +; P8LE: lxvd2x v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarAll(i64* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 %idxprom + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds i64, i64* %arr, i64 %idxprom1 + %1 = load i64, i64* %arrayidx2, align 8 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemVarAll +; P9LE-LABEL: fromDiffMemVarAll +; P8BE-LABEL: fromDiffMemVarAll +; P8LE-LABEL: fromDiffMemVarAll +; P9BE: sldi +; P9BE: lxvx v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lxvx v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lxvd2x v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lxvd2x +; P8LE: xxswapd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarDll(i64* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 %idxprom + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds i64, i64* %arr, i64 %idxprom1 + %1 = load i64, i64* %arrayidx2, align 8 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemVarDll +; P9LE-LABEL: fromDiffMemVarDll +; P8BE-LABEL: fromDiffMemVarDll +; P8LE-LABEL: fromDiffMemVarDll +; P9BE: sldi +; P9BE: lxvx +; P9BE: xxswapd v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lxvx +; P9LE: xxswapd v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lxvd2x +; P8BE: xxswapd v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lxvd2x v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromRandMemConsll(i64* nocapture readonly %arr) { +entry: + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 4 + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %arrayidx1 = getelementptr inbounds i64, i64* %arr, i64 18 + %1 = load i64, i64* %arrayidx1, align 8 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromRandMemConsll +; P9LE-LABEL: fromRandMemConsll +; P8BE-LABEL: fromRandMemConsll +; P8LE-LABEL: fromRandMemConsll +; P9BE: ld +; P9BE: ld +; P9BE: mtvsrdd v2 +; P9BE-NEXT: blr +; P9LE: ld +; P9LE: ld +; P9LE: mtvsrdd v2 +; P9LE-NEXT: blr +; P8BE: ld +; P8BE: ld +; P8BE-DAG: mtvsrd +; P8BE-DAG: mtvsrd +; P8BE: xxmrghd v2 +; P8BE-NEXT: blr +; P8LE: ld +; P8LE: ld +; P8LE-DAG: mtvsrd +; P8LE-DAG: mtvsrd +; P8LE: xxmrghd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromRandMemVarll(i64* nocapture readonly %arr, i32 signext %elem) { +entry: + %add = add nsw i32 %elem, 4 + %idxprom = sext i32 %add to i64 + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 %idxprom + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %add1 = add nsw i32 %elem, 1 + %idxprom2 = sext i32 %add1 to i64 + %arrayidx3 = getelementptr inbounds i64, i64* %arr, i64 %idxprom2 + %1 = load i64, i64* %arrayidx3, align 8 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromRandMemVarll +; P9LE-LABEL: fromRandMemVarll +; P8BE-LABEL: fromRandMemVarll +; P8LE-LABEL: fromRandMemVarll +; P9BE: sldi +; P9BE: ld +; P9BE: ld +; P9BE: mtvsrdd v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: ld +; P9LE: ld +; P9LE: mtvsrdd v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: ld +; P8BE: ld +; P8BE: mtvsrd +; P8BE: mtvsrd +; P8BE: xxmrghd v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: ld +; P8LE: ld +; P8LE: mtvsrd +; P8LE: mtvsrd +; P8LE: xxmrghd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltRegValll(i64 %val) { +entry: + %splat.splatinsert = insertelement <2 x i64> undef, i64 %val, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltRegValll +; P9LE-LABEL: spltRegValll +; P8BE-LABEL: spltRegValll +; P8LE-LABEL: spltRegValll +; P9BE: mtvsrdd v2, r3, r3 +; P9BE-NEXT: blr +; P9LE: mtvsrdd v2, r3, r3 +; P9LE-NEXT: blr +; P8BE: mtvsrd {{[vsf]+}}[[REG1:[0-9]+]], r3 +; P8BE: xxspltd v2, {{[vsf]+}}[[REG1]], 0 +; P8BE-NEXT: blr +; P8LE: mtvsrd {{[vsf]+}}[[REG1:[0-9]+]], r3 +; P8LE: xxspltd v2, {{[vsf]+}}[[REG1]], 0 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @spltMemValll(i64* nocapture readonly %ptr) { +entry: + %0 = load i64, i64* %ptr, align 8 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %0, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltMemValll +; P9LE-LABEL: spltMemValll +; P8BE-LABEL: spltMemValll +; P8LE-LABEL: spltMemValll +; P9BE: lxvdsx v2 +; P9BE-NEXT: blr +; P9LE: lxvdsx v2 +; P9LE-NEXT: blr +; P8BE: lxvdsx v2 +; P8BE-NEXT: blr +; P8LE: lxvdsx v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltCnstConvftoll() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltCnstConvftoll +; P9LE-LABEL: spltCnstConvftoll +; P8BE-LABEL: spltCnstConvftoll +; P8LE-LABEL: spltCnstConvftoll +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromRegsConvftoll(float %a, float %b) { +entry: + %conv = fptosi float %a to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %conv1 = fptosi float %b to i64 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %conv1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromRegsConvftoll +; P9LE-LABEL: fromRegsConvftoll +; P8BE-LABEL: fromRegsConvftoll +; P8LE-LABEL: fromRegsConvftoll +; P9BE: xxmrghd +; P9BE: xvcvdpsxds v2 +; P9BE-NEXT: blr +; P9LE: xxmrghd +; P9LE: xvcvdpsxds v2 +; P9LE-NEXT: blr +; P8BE: xxmrghd +; P8BE: xvcvdpsxds v2 +; P8BE-NEXT: blr +; P8LE: xxmrghd +; P8LE: xvcvdpsxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromDiffConstsConvftoll() { +entry: + ret <2 x i64> +; P9BE-LABEL: fromDiffConstsConvftoll +; P9LE-LABEL: fromDiffConstsConvftoll +; P8BE-LABEL: fromDiffConstsConvftoll +; P8LE-LABEL: fromDiffConstsConvftoll +; P9BE: lxvx v2 +; P9BE: blr +; P9LE: lxvx v2 +; P9LE: blr +; P8BE: lxvd2x v2 +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsAConvftoll(float* nocapture readonly %ptr) { +entry: + %0 = load float, float* %ptr, align 4 + %conv = fptosi float %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %arrayidx1 = getelementptr inbounds float, float* %ptr, i64 1 + %1 = load float, float* %arrayidx1, align 4 + %conv2 = fptosi float %1 to i64 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %conv2, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemConsAConvftoll +; P9LE-LABEL: fromDiffMemConsAConvftoll +; P8BE-LABEL: fromDiffMemConsAConvftoll +; P8LE-LABEL: fromDiffMemConsAConvftoll +; P9BE: lfs +; P9BE: lfs +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpsxds v2 +; P9BE-NEXT: blr +; P9LE: lfs +; P9LE: lfs +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpsxds v2 +; P9LE-NEXT: blr +; P8BE: lxsspx +; P8BE: lxsspx +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpsxds v2 +; P8BE-NEXT: blr +; P8LE: lxsspx +; P8LE: lxsspx +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpsxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsDConvftoll(float* nocapture readonly %ptr) { +entry: + %arrayidx = getelementptr inbounds float, float* %ptr, i64 3 + %0 = load float, float* %arrayidx, align 4 + %conv = fptosi float %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %arrayidx1 = getelementptr inbounds float, float* %ptr, i64 2 + %1 = load float, float* %arrayidx1, align 4 + %conv2 = fptosi float %1 to i64 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %conv2, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemConsDConvftoll +; P9LE-LABEL: fromDiffMemConsDConvftoll +; P8BE-LABEL: fromDiffMemConsDConvftoll +; P8LE-LABEL: fromDiffMemConsDConvftoll +; P9BE: lfs +; P9BE: lfs +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpsxds v2 +; P9BE-NEXT: blr +; P9LE: lfs +; P9LE: lfs +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpsxds v2 +; P9LE-NEXT: blr +; P8BE: lxsspx +; P8BE: lxsspx +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpsxds v2 +; P8BE-NEXT: blr +; P8LE: lxsspx +; P8LE: lxsspx +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpsxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarAConvftoll(float* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds float, float* %arr, i64 %idxprom + %0 = load float, float* %arrayidx, align 4 + %conv = fptosi float %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds float, float* %arr, i64 %idxprom1 + %1 = load float, float* %arrayidx2, align 4 + %conv3 = fptosi float %1 to i64 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %conv3, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromDiffMemVarAConvftoll +; P9LE-LABEL: fromDiffMemVarAConvftoll +; P8BE-LABEL: fromDiffMemVarAConvftoll +; P8LE-LABEL: fromDiffMemVarAConvftoll +; P9BE: sldi +; P9BE: lfsux +; P9BE: lfs +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpsxds v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lfsux +; P9LE: lfs +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpsxds v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lfsux +; P8BE: lxsspx +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpsxds v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lfsux +; P8LE: lxsspx +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpsxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarDConvftoll(float* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds float, float* %arr, i64 %idxprom + %0 = load float, float* %arrayidx, align 4 + %conv = fptosi float %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds float, float* %arr, i64 %idxprom1 + %1 = load float, float* %arrayidx2, align 4 + %conv3 = fptosi float %1 to i64 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %conv3, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromDiffMemVarDConvftoll +; P9LE-LABEL: fromDiffMemVarDConvftoll +; P8BE-LABEL: fromDiffMemVarDConvftoll +; P8LE-LABEL: fromDiffMemVarDConvftoll +; P9BE: sldi +; P9BE: lfsux +; P9BE: lfs +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpsxds v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lfsux +; P9LE: lfs +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpsxds v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lfsux +; P8BE: lxsspx +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpsxds v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lfsux +; P8LE: lxsspx +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpsxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltRegValConvftoll(float %val) { +entry: + %conv = fptosi float %val to i64 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltRegValConvftoll +; P9LE-LABEL: spltRegValConvftoll +; P8BE-LABEL: spltRegValConvftoll +; P8LE-LABEL: spltRegValConvftoll +; P9BE: xscvdpsxds +; P9BE-NEXT: xxspltd v2 +; P9BE-NEXT: blr +; P9LE: xscvdpsxds +; P9LE-NEXT: xxspltd v2 +; P9LE-NEXT: blr +; P8BE: xscvdpsxds +; P8BE-NEXT: xxspltd v2 +; P8BE-NEXT: blr +; P8LE: xscvdpsxds +; P8LE-NEXT: xxspltd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @spltMemValConvftoll(float* nocapture readonly %ptr) { +entry: + %0 = load float, float* %ptr, align 4 + %conv = fptosi float %0 to i64 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltMemValConvftoll +; P9LE-LABEL: spltMemValConvftoll +; P8BE-LABEL: spltMemValConvftoll +; P8LE-LABEL: spltMemValConvftoll +; P9BE: lfs +; P9BE-NEXT: xscvdpsxds +; P9BE-NEXT: xxspltd v2 +; P9BE-NEXT: blr +; P9LE: lfs +; P9LE-NEXT: xscvdpsxds +; P9LE-NEXT: xxspltd v2 +; P9LE-NEXT: blr +; P8BE: lxsspx +; P8BE-NEXT: xscvdpsxds +; P8BE-NEXT: xxspltd v2 +; P8BE-NEXT: blr +; P8LE: lxsspx +; P8LE-NEXT: xscvdpsxds +; P8LE-NEXT: xxspltd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltCnstConvdtoll() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltCnstConvdtoll +; P9LE-LABEL: spltCnstConvdtoll +; P8BE-LABEL: spltCnstConvdtoll +; P8LE-LABEL: spltCnstConvdtoll +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromRegsConvdtoll(double %a, double %b) { +entry: + %conv = fptosi double %a to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %conv1 = fptosi double %b to i64 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %conv1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromRegsConvdtoll +; P9LE-LABEL: fromRegsConvdtoll +; P8BE-LABEL: fromRegsConvdtoll +; P8LE-LABEL: fromRegsConvdtoll +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpsxds +; P9BE-NEXT: blr +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpsxds +; P9LE-NEXT: blr +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpsxds +; P8BE-NEXT: blr +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpsxds +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromDiffConstsConvdtoll() { +entry: + ret <2 x i64> +; P9BE-LABEL: fromDiffConstsConvdtoll +; P9LE-LABEL: fromDiffConstsConvdtoll +; P8BE-LABEL: fromDiffConstsConvdtoll +; P8LE-LABEL: fromDiffConstsConvdtoll +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsAConvdtoll(double* nocapture readonly %ptr) { +entry: + %0 = bitcast double* %ptr to <2 x double>* + %1 = load <2 x double>, <2 x double>* %0, align 8 + %2 = fptosi <2 x double> %1 to <2 x i64> + ret <2 x i64> %2 +; P9BE-LABEL: fromDiffMemConsAConvdtoll +; P9LE-LABEL: fromDiffMemConsAConvdtoll +; P8BE-LABEL: fromDiffMemConsAConvdtoll +; P8LE-LABEL: fromDiffMemConsAConvdtoll +; P9BE: lxvx +; P9BE-NEXT: xvcvdpsxds v2 +; P9BE-NEXT: blr +; P9LE: lxvx +; P9LE-NEXT: xvcvdpsxds v2 +; P9LE-NEXT: blr +; P8BE: lxvd2x +; P8BE-NEXT: xvcvdpsxds v2 +; P8BE-NEXT: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE-NEXT: xvcvdpsxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsDConvdtoll(double* nocapture readonly %ptr) { +entry: + %arrayidx = getelementptr inbounds double, double* %ptr, i64 3 + %0 = load double, double* %arrayidx, align 8 + %conv = fptosi double %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %arrayidx1 = getelementptr inbounds double, double* %ptr, i64 2 + %1 = load double, double* %arrayidx1, align 8 + %conv2 = fptosi double %1 to i64 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %conv2, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemConsDConvdtoll +; P9LE-LABEL: fromDiffMemConsDConvdtoll +; P8BE-LABEL: fromDiffMemConsDConvdtoll +; P8LE-LABEL: fromDiffMemConsDConvdtoll +; P9BE: lxvx +; P9BE-NEXT: xxswapd +; P9BE-NEXT: xvcvdpsxds v2 +; P9BE-NEXT: blr +; P9LE: lxvx +; P9LE-NEXT: xxswapd +; P9LE-NEXT: xvcvdpsxds v2 +; P9LE-NEXT: blr +; P8BE: lxvd2x +; P8BE-NEXT: xxswapd +; P8BE-NEXT: xvcvdpsxds v2 +; P8BE-NEXT: blr +; P8LE: lxvd2x +; P8LE-NEXT: xvcvdpsxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarAConvdtoll(double* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds double, double* %arr, i64 %idxprom + %0 = load double, double* %arrayidx, align 8 + %conv = fptosi double %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds double, double* %arr, i64 %idxprom1 + %1 = load double, double* %arrayidx2, align 8 + %conv3 = fptosi double %1 to i64 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %conv3, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromDiffMemVarAConvdtoll +; P9LE-LABEL: fromDiffMemVarAConvdtoll +; P8BE-LABEL: fromDiffMemVarAConvdtoll +; P8LE-LABEL: fromDiffMemVarAConvdtoll +; P9BE: sldi +; P9BE: lxvx +; P9BE-NEXT: xvcvdpsxds v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lxvx +; P9LE-NEXT: xvcvdpsxds v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lxvd2x +; P8BE-NEXT: xvcvdpsxds v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lxvd2x +; P8LE-NEXT: xxswapd +; P8LE-NEXT: xvcvdpsxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarDConvdtoll(double* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds double, double* %arr, i64 %idxprom + %0 = load double, double* %arrayidx, align 8 + %conv = fptosi double %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds double, double* %arr, i64 %idxprom1 + %1 = load double, double* %arrayidx2, align 8 + %conv3 = fptosi double %1 to i64 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %conv3, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromDiffMemVarDConvdtoll +; P9LE-LABEL: fromDiffMemVarDConvdtoll +; P8BE-LABEL: fromDiffMemVarDConvdtoll +; P8LE-LABEL: fromDiffMemVarDConvdtoll +; P9BE: sldi +; P9BE: lxvx +; P9BE-NEXT: xxswapd +; P9BE-NEXT: xvcvdpsxds v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lxvx +; P9LE-NEXT: xxswapd +; P9LE-NEXT: xvcvdpsxds v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lxvd2x +; P8BE-NEXT: xxswapd +; P8BE-NEXT: xvcvdpsxds v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lxvd2x +; P8LE-NEXT: xvcvdpsxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltRegValConvdtoll(double %val) { +entry: + %conv = fptosi double %val to i64 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltRegValConvdtoll +; P9LE-LABEL: spltRegValConvdtoll +; P8BE-LABEL: spltRegValConvdtoll +; P8LE-LABEL: spltRegValConvdtoll +; P9BE: xscvdpsxds +; P9BE-NEXT: xxspltd v2 +; P9BE-NEXT: blr +; P9LE: xscvdpsxds +; P9LE-NEXT: xxspltd v2 +; P9LE-NEXT: blr +; P8BE: xscvdpsxds +; P8BE-NEXT: xxspltd v2 +; P8BE-NEXT: blr +; P8LE: xscvdpsxds +; P8LE-NEXT: xxspltd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @spltMemValConvdtoll(double* nocapture readonly %ptr) { +entry: + %0 = load double, double* %ptr, align 8 + %conv = fptosi double %0 to i64 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltMemValConvdtoll +; P9LE-LABEL: spltMemValConvdtoll +; P8BE-LABEL: spltMemValConvdtoll +; P8LE-LABEL: spltMemValConvdtoll +; P9BE: lxvdsx +; P9BE-NEXT: xvcvdpsxds +; P9BE-NEXT: blr +; P9LE: lxvdsx +; P9LE-NEXT: xvcvdpsxds +; P9LE-NEXT: blr +; P8BE: lxvdsx +; P8BE-NEXT: xvcvdpsxds +; P8BE-NEXT: blr +; P8LE: lxvdsx +; P8LE-NEXT: xvcvdpsxds +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @allZeroull() { +entry: + ret <2 x i64> zeroinitializer +; P9BE-LABEL: allZeroull +; P9LE-LABEL: allZeroull +; P8BE-LABEL: allZeroull +; P8LE-LABEL: allZeroull +; P9BE: xxlxor v2, v2, v2 +; P9BE: blr +; P9LE: xxlxor v2, v2, v2 +; P9LE: blr +; P8BE: xxlxor v2, v2, v2 +; P8BE: blr +; P8LE: xxlxor v2, v2, v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @allOneull() { +entry: + ret <2 x i64> +; P9BE-LABEL: allOneull +; P9LE-LABEL: allOneull +; P8BE-LABEL: allOneull +; P8LE-LABEL: allOneull +; P9BE: xxspltib v2, 255 +; P9BE: blr +; P9LE: xxspltib v2, 255 +; P9LE: blr +; P8BE: vspltisb v2, -1 +; P8BE: blr +; P8LE: vspltisb v2, -1 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltConst1ull() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltConst1ull +; P9LE-LABEL: spltConst1ull +; P8BE-LABEL: spltConst1ull +; P8LE-LABEL: spltConst1ull +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltConst16kull() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltConst16kull +; P9LE-LABEL: spltConst16kull +; P8BE-LABEL: spltConst16kull +; P8LE-LABEL: spltConst16kull +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltConst32kull() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltConst32kull +; P9LE-LABEL: spltConst32kull +; P8BE-LABEL: spltConst32kull +; P8LE-LABEL: spltConst32kull +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromRegsull(i64 %a, i64 %b) { +entry: + %vecinit = insertelement <2 x i64> undef, i64 %a, i32 0 + %vecinit1 = insertelement <2 x i64> %vecinit, i64 %b, i32 1 + ret <2 x i64> %vecinit1 +; P9BE-LABEL: fromRegsull +; P9LE-LABEL: fromRegsull +; P8BE-LABEL: fromRegsull +; P8LE-LABEL: fromRegsull +; P9BE: mtvsrdd v2, r3, r4 +; P9BE: blr +; P9LE: mtvsrdd v2, r4, r3 +; P9LE: blr +; P8BE-DAG: mtvsrd {{[vsf0-9]+}}, r3 +; P8BE-DAG: mtvsrd {{[vsf0-9]+}}, r4 +; P8BE: xxmrghd v2 +; P8BE: blr +; P8LE-DAG: mtvsrd {{[vsf0-9]+}}, r3 +; P8LE-DAG: mtvsrd {{[vsf0-9]+}}, r4 +; P8LE: xxmrghd v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromDiffConstsull() { +entry: + ret <2 x i64> +; P9BE-LABEL: fromDiffConstsull +; P9LE-LABEL: fromDiffConstsull +; P8BE-LABEL: fromDiffConstsull +; P8LE-LABEL: fromDiffConstsull +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsAull(i64* nocapture readonly %arr) { +entry: + %0 = load i64, i64* %arr, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %arrayidx1 = getelementptr inbounds i64, i64* %arr, i64 1 + %1 = load i64, i64* %arrayidx1, align 8 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromDiffMemConsAull +; P9LE-LABEL: fromDiffMemConsAull +; P8BE-LABEL: fromDiffMemConsAull +; P8LE-LABEL: fromDiffMemConsAull +; P9BE: lxvx v2 +; P9BE: blr +; P9LE: lxvx v2 +; P9LE: blr +; P8BE: lxvd2x v2 +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsDull(i64* nocapture readonly %arr) { +entry: + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 3 + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %arrayidx1 = getelementptr inbounds i64, i64* %arr, i64 2 + %1 = load i64, i64* %arrayidx1, align 8 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromDiffMemConsDull +; P9LE-LABEL: fromDiffMemConsDull +; P8BE-LABEL: fromDiffMemConsDull +; P8LE-LABEL: fromDiffMemConsDull +; P9BE: lxvx v2 +; P9BE: blr +; P9LE: lxvx +; P9LE: xxswapd v2 +; P9LE: blr +; P8BE: lxvd2x +; P8BE: xxswapd v2 +; P8BE-NEXT: blr +; P8LE: lxvd2x v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarAull(i64* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 %idxprom + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds i64, i64* %arr, i64 %idxprom1 + %1 = load i64, i64* %arrayidx2, align 8 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemVarAull +; P9LE-LABEL: fromDiffMemVarAull +; P8BE-LABEL: fromDiffMemVarAull +; P8LE-LABEL: fromDiffMemVarAull +; P9BE: sldi +; P9BE: lxvx v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lxvx v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lxvd2x v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lxvd2x +; P8LE: xxswapd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarDull(i64* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 %idxprom + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds i64, i64* %arr, i64 %idxprom1 + %1 = load i64, i64* %arrayidx2, align 8 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemVarDull +; P9LE-LABEL: fromDiffMemVarDull +; P8BE-LABEL: fromDiffMemVarDull +; P8LE-LABEL: fromDiffMemVarDull +; P9BE: sldi +; P9BE: lxvx +; P9BE: xxswapd v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lxvx +; P9LE: xxswapd v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lxvd2x +; P8BE: xxswapd v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lxvd2x v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromRandMemConsull(i64* nocapture readonly %arr) { +entry: + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 4 + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %arrayidx1 = getelementptr inbounds i64, i64* %arr, i64 18 + %1 = load i64, i64* %arrayidx1, align 8 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromRandMemConsull +; P9LE-LABEL: fromRandMemConsull +; P8BE-LABEL: fromRandMemConsull +; P8LE-LABEL: fromRandMemConsull +; P9BE: ld +; P9BE: ld +; P9BE: mtvsrdd v2 +; P9BE-NEXT: blr +; P9LE: ld +; P9LE: ld +; P9LE: mtvsrdd v2 +; P9LE-NEXT: blr +; P8BE: ld +; P8BE: ld +; P8BE-DAG: mtvsrd +; P8BE-DAG: mtvsrd +; P8BE: xxmrghd v2 +; P8BE-NEXT: blr +; P8LE: ld +; P8LE: ld +; P8LE-DAG: mtvsrd +; P8LE-DAG: mtvsrd +; P8LE: xxmrghd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromRandMemVarull(i64* nocapture readonly %arr, i32 signext %elem) { +entry: + %add = add nsw i32 %elem, 4 + %idxprom = sext i32 %add to i64 + %arrayidx = getelementptr inbounds i64, i64* %arr, i64 %idxprom + %0 = load i64, i64* %arrayidx, align 8 + %vecinit = insertelement <2 x i64> undef, i64 %0, i32 0 + %add1 = add nsw i32 %elem, 1 + %idxprom2 = sext i32 %add1 to i64 + %arrayidx3 = getelementptr inbounds i64, i64* %arr, i64 %idxprom2 + %1 = load i64, i64* %arrayidx3, align 8 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %1, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromRandMemVarull +; P9LE-LABEL: fromRandMemVarull +; P8BE-LABEL: fromRandMemVarull +; P8LE-LABEL: fromRandMemVarull +; P9BE: sldi +; P9BE: ld +; P9BE: ld +; P9BE: mtvsrdd v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: ld +; P9LE: ld +; P9LE: mtvsrdd v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: ld +; P8BE: ld +; P8BE: mtvsrd +; P8BE: mtvsrd +; P8BE: xxmrghd v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: ld +; P8LE: ld +; P8LE: mtvsrd +; P8LE: mtvsrd +; P8LE: xxmrghd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltRegValull(i64 %val) { +entry: + %splat.splatinsert = insertelement <2 x i64> undef, i64 %val, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltRegValull +; P9LE-LABEL: spltRegValull +; P8BE-LABEL: spltRegValull +; P8LE-LABEL: spltRegValull +; P9BE: mtvsrdd v2, r3, r3 +; P9BE-NEXT: blr +; P9LE: mtvsrdd v2, r3, r3 +; P9LE-NEXT: blr +; P8BE: mtvsrd {{[vsf]+}}[[REG1:[0-9]+]], r3 +; P8BE: xxspltd v2, {{[vsf]+}}[[REG1]], 0 +; P8BE-NEXT: blr +; P8LE: mtvsrd {{[vsf]+}}[[REG1:[0-9]+]], r3 +; P8LE: xxspltd v2, {{[vsf]+}}[[REG1]], 0 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @spltMemValull(i64* nocapture readonly %ptr) { +entry: + %0 = load i64, i64* %ptr, align 8 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %0, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltMemValull +; P9LE-LABEL: spltMemValull +; P8BE-LABEL: spltMemValull +; P8LE-LABEL: spltMemValull +; P9BE: lxvdsx v2 +; P9BE-NEXT: blr +; P9LE: lxvdsx v2 +; P9LE-NEXT: blr +; P8BE: lxvdsx v2 +; P8BE-NEXT: blr +; P8LE: lxvdsx v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltCnstConvftoull() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltCnstConvftoull +; P9LE-LABEL: spltCnstConvftoull +; P8BE-LABEL: spltCnstConvftoull +; P8LE-LABEL: spltCnstConvftoull +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromRegsConvftoull(float %a, float %b) { +entry: + %conv = fptoui float %a to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %conv1 = fptoui float %b to i64 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %conv1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromRegsConvftoull +; P9LE-LABEL: fromRegsConvftoull +; P8BE-LABEL: fromRegsConvftoull +; P8LE-LABEL: fromRegsConvftoull +; P9BE: xxmrghd +; P9BE: xvcvdpuxds v2 +; P9BE-NEXT: blr +; P9LE: xxmrghd +; P9LE: xvcvdpuxds v2 +; P9LE-NEXT: blr +; P8BE: xxmrghd +; P8BE: xvcvdpuxds v2 +; P8BE-NEXT: blr +; P8LE: xxmrghd +; P8LE: xvcvdpuxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromDiffConstsConvftoull() { +entry: + ret <2 x i64> +; P9BE-LABEL: fromDiffConstsConvftoull +; P9LE-LABEL: fromDiffConstsConvftoull +; P8BE-LABEL: fromDiffConstsConvftoull +; P8LE-LABEL: fromDiffConstsConvftoull +; P9BE: lxvx v2 +; P9BE: blr +; P9LE: lxvx v2 +; P9LE: blr +; P8BE: lxvd2x v2 +; P8BE: blr +; P8LE: lxvd2x +; P8LE: xxswapd v2 +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsAConvftoull(float* nocapture readonly %ptr) { +entry: + %0 = load float, float* %ptr, align 4 + %conv = fptoui float %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %arrayidx1 = getelementptr inbounds float, float* %ptr, i64 1 + %1 = load float, float* %arrayidx1, align 4 + %conv2 = fptoui float %1 to i64 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %conv2, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemConsAConvftoull +; P9LE-LABEL: fromDiffMemConsAConvftoull +; P8BE-LABEL: fromDiffMemConsAConvftoull +; P8LE-LABEL: fromDiffMemConsAConvftoull +; P9BE: lfs +; P9BE: lfs +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpuxds v2 +; P9BE-NEXT: blr +; P9LE: lfs +; P9LE: lfs +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpuxds v2 +; P9LE-NEXT: blr +; P8BE: lxsspx +; P8BE: lxsspx +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpuxds v2 +; P8BE-NEXT: blr +; P8LE: lxsspx +; P8LE: lxsspx +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpuxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsDConvftoull(float* nocapture readonly %ptr) { +entry: + %arrayidx = getelementptr inbounds float, float* %ptr, i64 3 + %0 = load float, float* %arrayidx, align 4 + %conv = fptoui float %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %arrayidx1 = getelementptr inbounds float, float* %ptr, i64 2 + %1 = load float, float* %arrayidx1, align 4 + %conv2 = fptoui float %1 to i64 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %conv2, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemConsDConvftoull +; P9LE-LABEL: fromDiffMemConsDConvftoull +; P8BE-LABEL: fromDiffMemConsDConvftoull +; P8LE-LABEL: fromDiffMemConsDConvftoull +; P9BE: lfs +; P9BE: lfs +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpuxds v2 +; P9BE-NEXT: blr +; P9LE: lfs +; P9LE: lfs +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpuxds v2 +; P9LE-NEXT: blr +; P8BE: lxsspx +; P8BE: lxsspx +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpuxds v2 +; P8BE-NEXT: blr +; P8LE: lxsspx +; P8LE: lxsspx +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpuxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarAConvftoull(float* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds float, float* %arr, i64 %idxprom + %0 = load float, float* %arrayidx, align 4 + %conv = fptoui float %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds float, float* %arr, i64 %idxprom1 + %1 = load float, float* %arrayidx2, align 4 + %conv3 = fptoui float %1 to i64 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %conv3, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromDiffMemVarAConvftoull +; P9LE-LABEL: fromDiffMemVarAConvftoull +; P8BE-LABEL: fromDiffMemVarAConvftoull +; P8LE-LABEL: fromDiffMemVarAConvftoull +; P9BE: sldi +; P9BE: lfsux +; P9BE: lfs +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpuxds v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lfsux +; P9LE: lfs +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpuxds v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lfsux +; P8BE: lxsspx +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpuxds v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lfsux +; P8LE: lxsspx +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpuxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarDConvftoull(float* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds float, float* %arr, i64 %idxprom + %0 = load float, float* %arrayidx, align 4 + %conv = fptoui float %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds float, float* %arr, i64 %idxprom1 + %1 = load float, float* %arrayidx2, align 4 + %conv3 = fptoui float %1 to i64 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %conv3, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromDiffMemVarDConvftoull +; P9LE-LABEL: fromDiffMemVarDConvftoull +; P8BE-LABEL: fromDiffMemVarDConvftoull +; P8LE-LABEL: fromDiffMemVarDConvftoull +; P9BE: sldi +; P9BE: lfsux +; P9BE: lfs +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpuxds v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lfsux +; P9LE: lfs +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpuxds v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lfsux +; P8BE: lxsspx +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpuxds v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lfsux +; P8LE: lxsspx +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpuxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltRegValConvftoull(float %val) { +entry: + %conv = fptoui float %val to i64 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltRegValConvftoull +; P9LE-LABEL: spltRegValConvftoull +; P8BE-LABEL: spltRegValConvftoull +; P8LE-LABEL: spltRegValConvftoull +; P9BE: xscvdpuxds +; P9BE-NEXT: xxspltd v2 +; P9BE-NEXT: blr +; P9LE: xscvdpuxds +; P9LE-NEXT: xxspltd v2 +; P9LE-NEXT: blr +; P8BE: xscvdpuxds +; P8BE-NEXT: xxspltd v2 +; P8BE-NEXT: blr +; P8LE: xscvdpuxds +; P8LE-NEXT: xxspltd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @spltMemValConvftoull(float* nocapture readonly %ptr) { +entry: + %0 = load float, float* %ptr, align 4 + %conv = fptoui float %0 to i64 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltMemValConvftoull +; P9LE-LABEL: spltMemValConvftoull +; P8BE-LABEL: spltMemValConvftoull +; P8LE-LABEL: spltMemValConvftoull +; P9BE: lfs +; P9BE-NEXT: xscvdpuxds +; P9BE-NEXT: xxspltd v2 +; P9BE-NEXT: blr +; P9LE: lfs +; P9LE-NEXT: xscvdpuxds +; P9LE-NEXT: xxspltd v2 +; P9LE-NEXT: blr +; P8BE: lxsspx +; P8BE-NEXT: xscvdpuxds +; P8BE-NEXT: xxspltd v2 +; P8BE-NEXT: blr +; P8LE: lxsspx +; P8LE-NEXT: xscvdpuxds +; P8LE-NEXT: xxspltd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltCnstConvdtoull() { +entry: + ret <2 x i64> +; P9BE-LABEL: spltCnstConvdtoull +; P9LE-LABEL: spltCnstConvdtoull +; P8BE-LABEL: spltCnstConvdtoull +; P8LE-LABEL: spltCnstConvdtoull +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromRegsConvdtoull(double %a, double %b) { +entry: + %conv = fptoui double %a to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %conv1 = fptoui double %b to i64 + %vecinit2 = insertelement <2 x i64> %vecinit, i64 %conv1, i32 1 + ret <2 x i64> %vecinit2 +; P9BE-LABEL: fromRegsConvdtoull +; P9LE-LABEL: fromRegsConvdtoull +; P8BE-LABEL: fromRegsConvdtoull +; P8LE-LABEL: fromRegsConvdtoull +; P9BE: xxmrghd +; P9BE-NEXT: xvcvdpuxds +; P9BE-NEXT: blr +; P9LE: xxmrghd +; P9LE-NEXT: xvcvdpuxds +; P9LE-NEXT: blr +; P8BE: xxmrghd +; P8BE-NEXT: xvcvdpuxds +; P8BE-NEXT: blr +; P8LE: xxmrghd +; P8LE-NEXT: xvcvdpuxds +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @fromDiffConstsConvdtoull() { +entry: + ret <2 x i64> +; P9BE-LABEL: fromDiffConstsConvdtoull +; P9LE-LABEL: fromDiffConstsConvdtoull +; P8BE-LABEL: fromDiffConstsConvdtoull +; P8LE-LABEL: fromDiffConstsConvdtoull +; P9BE: lxvx +; P9BE: blr +; P9LE: lxvx +; P9LE: blr +; P8BE: lxvd2x +; P8BE: blr +; P8LE: lxvd2x +; P8LE: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsAConvdtoull(double* nocapture readonly %ptr) { +entry: + %0 = bitcast double* %ptr to <2 x double>* + %1 = load <2 x double>, <2 x double>* %0, align 8 + %2 = fptoui <2 x double> %1 to <2 x i64> + ret <2 x i64> %2 +; P9BE-LABEL: fromDiffMemConsAConvdtoull +; P9LE-LABEL: fromDiffMemConsAConvdtoull +; P8BE-LABEL: fromDiffMemConsAConvdtoull +; P8LE-LABEL: fromDiffMemConsAConvdtoull +; P9BE: lxvx +; P9BE-NEXT: xvcvdpuxds v2 +; P9BE-NEXT: blr +; P9LE: lxvx +; P9LE-NEXT: xvcvdpuxds v2 +; P9LE-NEXT: blr +; P8BE: lxvd2x +; P8BE-NEXT: xvcvdpuxds v2 +; P8BE-NEXT: blr +; P8LE: lxvd2x +; P8LE: xxswapd +; P8LE-NEXT: xvcvdpuxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemConsDConvdtoull(double* nocapture readonly %ptr) { +entry: + %arrayidx = getelementptr inbounds double, double* %ptr, i64 3 + %0 = load double, double* %arrayidx, align 8 + %conv = fptoui double %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %arrayidx1 = getelementptr inbounds double, double* %ptr, i64 2 + %1 = load double, double* %arrayidx1, align 8 + %conv2 = fptoui double %1 to i64 + %vecinit3 = insertelement <2 x i64> %vecinit, i64 %conv2, i32 1 + ret <2 x i64> %vecinit3 +; P9BE-LABEL: fromDiffMemConsDConvdtoull +; P9LE-LABEL: fromDiffMemConsDConvdtoull +; P8BE-LABEL: fromDiffMemConsDConvdtoull +; P8LE-LABEL: fromDiffMemConsDConvdtoull +; P9BE: lxvx +; P9BE-NEXT: xxswapd +; P9BE-NEXT: xvcvdpuxds v2 +; P9BE-NEXT: blr +; P9LE: lxvx +; P9LE-NEXT: xxswapd +; P9LE-NEXT: xvcvdpuxds v2 +; P9LE-NEXT: blr +; P8BE: lxvd2x +; P8BE-NEXT: xxswapd +; P8BE-NEXT: xvcvdpuxds v2 +; P8BE-NEXT: blr +; P8LE: lxvd2x +; P8LE-NEXT: xvcvdpuxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarAConvdtoull(double* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds double, double* %arr, i64 %idxprom + %0 = load double, double* %arrayidx, align 8 + %conv = fptoui double %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %add = add nsw i32 %elem, 1 + %idxprom1 = sext i32 %add to i64 + %arrayidx2 = getelementptr inbounds double, double* %arr, i64 %idxprom1 + %1 = load double, double* %arrayidx2, align 8 + %conv3 = fptoui double %1 to i64 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %conv3, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromDiffMemVarAConvdtoull +; P9LE-LABEL: fromDiffMemVarAConvdtoull +; P8BE-LABEL: fromDiffMemVarAConvdtoull +; P8LE-LABEL: fromDiffMemVarAConvdtoull +; P9BE: sldi +; P9BE: lxvx +; P9BE-NEXT: xvcvdpuxds v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lxvx +; P9LE-NEXT: xvcvdpuxds v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lxvd2x +; P8BE-NEXT: xvcvdpuxds v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lxvd2x +; P8LE-NEXT: xxswapd +; P8LE-NEXT: xvcvdpuxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @fromDiffMemVarDConvdtoull(double* nocapture readonly %arr, i32 signext %elem) { +entry: + %idxprom = sext i32 %elem to i64 + %arrayidx = getelementptr inbounds double, double* %arr, i64 %idxprom + %0 = load double, double* %arrayidx, align 8 + %conv = fptoui double %0 to i64 + %vecinit = insertelement <2 x i64> undef, i64 %conv, i32 0 + %sub = add nsw i32 %elem, -1 + %idxprom1 = sext i32 %sub to i64 + %arrayidx2 = getelementptr inbounds double, double* %arr, i64 %idxprom1 + %1 = load double, double* %arrayidx2, align 8 + %conv3 = fptoui double %1 to i64 + %vecinit4 = insertelement <2 x i64> %vecinit, i64 %conv3, i32 1 + ret <2 x i64> %vecinit4 +; P9BE-LABEL: fromDiffMemVarDConvdtoull +; P9LE-LABEL: fromDiffMemVarDConvdtoull +; P8BE-LABEL: fromDiffMemVarDConvdtoull +; P8LE-LABEL: fromDiffMemVarDConvdtoull +; P9BE: sldi +; P9BE: lxvx +; P9BE-NEXT: xxswapd +; P9BE-NEXT: xvcvdpuxds v2 +; P9BE-NEXT: blr +; P9LE: sldi +; P9LE: lxvx +; P9LE-NEXT: xxswapd +; P9LE-NEXT: xvcvdpuxds v2 +; P9LE-NEXT: blr +; P8BE: sldi +; P8BE: lxvd2x +; P8BE-NEXT: xxswapd +; P8BE-NEXT: xvcvdpuxds v2 +; P8BE-NEXT: blr +; P8LE: sldi +; P8LE: lxvd2x +; P8LE-NEXT: xvcvdpuxds v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readnone +define <2 x i64> @spltRegValConvdtoull(double %val) { +entry: + %conv = fptoui double %val to i64 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltRegValConvdtoull +; P9LE-LABEL: spltRegValConvdtoull +; P8BE-LABEL: spltRegValConvdtoull +; P8LE-LABEL: spltRegValConvdtoull +; P9BE: xscvdpuxds +; P9BE-NEXT: xxspltd v2 +; P9BE-NEXT: blr +; P9LE: xscvdpuxds +; P9LE-NEXT: xxspltd v2 +; P9LE-NEXT: blr +; P8BE: xscvdpuxds +; P8BE-NEXT: xxspltd v2 +; P8BE-NEXT: blr +; P8LE: xscvdpuxds +; P8LE-NEXT: xxspltd v2 +; P8LE-NEXT: blr +} + +; Function Attrs: norecurse nounwind readonly +define <2 x i64> @spltMemValConvdtoull(double* nocapture readonly %ptr) { +entry: + %0 = load double, double* %ptr, align 8 + %conv = fptoui double %0 to i64 + %splat.splatinsert = insertelement <2 x i64> undef, i64 %conv, i32 0 + %splat.splat = shufflevector <2 x i64> %splat.splatinsert, <2 x i64> undef, <2 x i32> zeroinitializer + ret <2 x i64> %splat.splat +; P9BE-LABEL: spltMemValConvdtoull +; P9LE-LABEL: spltMemValConvdtoull +; P8BE-LABEL: spltMemValConvdtoull +; P8LE-LABEL: spltMemValConvdtoull +; P9BE: lxvdsx +; P9BE-NEXT: xvcvdpuxds +; P9BE-NEXT: blr +; P9LE: lxvdsx +; P9LE-NEXT: xvcvdpuxds +; P9LE-NEXT: blr +; P8BE: lxvdsx +; P8BE-NEXT: xvcvdpuxds +; P8BE-NEXT: blr +; P8LE: lxvdsx +; P8LE-NEXT: xvcvdpuxds +; P8LE-NEXT: blr +} Index: test/CodeGen/PowerPC/power9-moves-and-splats.ll =================================================================== --- test/CodeGen/PowerPC/power9-moves-and-splats.ll +++ test/CodeGen/PowerPC/power9-moves-and-splats.ll @@ -156,14 +156,10 @@ entry: ; CHECK-LABEL: test14 ; CHECK: lwz [[LD:[0-9]+]], -; FIXME: mtvsrws 34, [[LD]] -; CHECK: mtvsrws [[SPLT:[0-9]+]], [[LD]] -; CHECK: xxspltw 34, [[SPLT]], 3 +; CHECK: mtvsrws 34, [[LD]] ; CHECK-BE-LABEL: test14 ; CHECK-BE: lwz [[LD:[0-9]+]], -; FIXME: mtvsrws 34, [[LD]] -; CHECK-BE: mtvsrws [[SPLT:[0-9]+]], [[LD]] -; CHECK-BE: xxspltw 34, [[SPLT]], 0 +; CHECK-BE: mtvsrws 34, [[LD]] %0 = load i32, i32* %b, align 4 %splat.splatinsert = insertelement <4 x i32> undef, i32 %0, i32 0 %splat.splat = shufflevector <4 x i32> %splat.splatinsert, <4 x i32> undef, <4 x i32> zeroinitializer