llvm/llvm/test/CodeGen/PowerPC/srem-vector-lkk.ll

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -mcpu=pwr9 -verify-machineinstrs -ppc-vsr-nums-as-vr -ppc-asm-full-reg-names \
; RUN:		-mtriple=powerpc64le-unknown-linux-gnu < %s | FileCheck %s --check-prefix=P9LE
; RUN: llc -mcpu=pwr9 -verify-machineinstrs -ppc-vsr-nums-as-vr -ppc-asm-full-reg-names \
; RUN:    -mtriple=powerpc64-unknown-linux-gnu < %s | FileCheck %s --check-prefix=P9BE
; RUN: llc -mcpu=pwr8 -verify-machineinstrs -ppc-vsr-nums-as-vr -ppc-asm-full-reg-names \
; RUN:    -mtriple=powerpc64le-unknown-linux-gnu < %s | FileCheck %s --check-prefix=P8LE
; RUN: llc -mcpu=pwr8 -verify-machineinstrs -ppc-vsr-nums-as-vr -ppc-asm-full-reg-names \
; RUN:    -mtriple=powerpc64-unknown-linux-gnu < %s | FileCheck %s --check-prefix=P8BE

define <4 x i16> @fold_srem_vec_1(<4 x i16> %x) {
; P9LE-LABEL: fold_srem_vec_1:
; P9LE:       # %bb.0:
; P9LE-NEXT:    li r3, 0
; P9LE-NEXT:    lis r4, -21386
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    ori r4, r4, 37253
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    add r4, r4, r3
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 6
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 95
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    lis r4, 31710
; P9LE-NEXT:    mtvsrd v3, r3
; P9LE-NEXT:    li r3, 2
; P9LE-NEXT:    ori r4, r4, 63421
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    sub r4, r4, r3
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 6
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, -124
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    lis r4, 21399
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 4
; P9LE-NEXT:    ori r4, r4, 33437
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    vmrghh v3, v4, v3
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 5
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 98
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    lis r4, -16728
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 6
; P9LE-NEXT:    ori r4, r4, 63249
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 8
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, -1003
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    mtvsrd v2, r3
; P9LE-NEXT:    vmrghh v2, v2, v4
; P9LE-NEXT:    xxmrglw v2, v2, v3
; P9LE-NEXT:    blr
;
; P9BE-LABEL: fold_srem_vec_1:
; P9BE:       # %bb.0:
; P9BE-NEXT:    li r3, 2
; P9BE-NEXT:    lis r4, 31710
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    ori r4, r4, 63421
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    sub r4, r4, r3
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 6
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, -124
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    lis r4, -21386
; P9BE-NEXT:    mtfprwz f0, r3
; P9BE-NEXT:    li r3, 0
; P9BE-NEXT:    ori r4, r4, 37253
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    add r4, r4, r3
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 6
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 95
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    lis r4, -16728
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    addis r3, r2, .LCPI0_0@toc@ha
; P9BE-NEXT:    ori r4, r4, 63249
; P9BE-NEXT:    addi r3, r3, .LCPI0_0@toc@l
; P9BE-NEXT:    lxv vs2, 0(r3)
; P9BE-NEXT:    li r3, 6
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    xxperm vs0, vs1, vs2
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 8
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, -1003
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    lis r4, 21399
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    li r3, 4
; P9BE-NEXT:    ori r4, r4, 33437
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 5
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 98
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mtfprwz f3, r3
; P9BE-NEXT:    xxperm vs1, vs3, vs2
; P9BE-NEXT:    xxmrghw v2, vs0, vs1
; P9BE-NEXT:    blr
;
; P8LE-LABEL: fold_srem_vec_1:
; P8LE:       # %bb.0:
; P8LE-NEXT:    xxswapd vs0, v2
; P8LE-NEXT:    lis r4, 21399
; P8LE-NEXT:    lis r5, -16728
; P8LE-NEXT:    lis r6, -21386
; P8LE-NEXT:    mffprd r3, f0
; P8LE-NEXT:    ori r4, r4, 33437
; P8LE-NEXT:    ori r5, r5, 63249
; P8LE-NEXT:    ori r6, r6, 37253
; P8LE-NEXT:    rldicl r7, r3, 32, 48
; P8LE-NEXT:    rldicl r8, r3, 16, 48
; P8LE-NEXT:    clrldi r9, r3, 48
; P8LE-NEXT:    rldicl r3, r3, 48, 48
; P8LE-NEXT:    extsh r7, r7
; P8LE-NEXT:    extsh r8, r8
; P8LE-NEXT:    extsh r9, r9
; P8LE-NEXT:    extsh r3, r3
; P8LE-NEXT:    mulhw r4, r7, r4
; P8LE-NEXT:    mulhw r5, r8, r5
; P8LE-NEXT:    mulhw r6, r9, r6
; P8LE-NEXT:    srwi r10, r4, 31
; P8LE-NEXT:    srawi r4, r4, 5
; P8LE-NEXT:    add r6, r6, r9
; P8LE-NEXT:    add r4, r4, r10
; P8LE-NEXT:    srwi r10, r5, 31
; P8LE-NEXT:    srawi r5, r5, 8
; P8LE-NEXT:    mulli r4, r4, 98
; P8LE-NEXT:    add r5, r5, r10
; P8LE-NEXT:    srwi r10, r6, 31
; P8LE-NEXT:    srawi r6, r6, 6
; P8LE-NEXT:    add r6, r6, r10
; P8LE-NEXT:    mulli r5, r5, -1003
; P8LE-NEXT:    sub r4, r7, r4
; P8LE-NEXT:    mtvsrd v2, r4
; P8LE-NEXT:    mulli r4, r6, 95
; P8LE-NEXT:    sub r5, r8, r5
; P8LE-NEXT:    mtvsrd v3, r5
; P8LE-NEXT:    sub r4, r9, r4
; P8LE-NEXT:    mtvsrd v4, r4
; P8LE-NEXT:    lis r4, 31710
; P8LE-NEXT:    ori r4, r4, 63421
; P8LE-NEXT:    mulhw r4, r3, r4
; P8LE-NEXT:    sub r4, r4, r3
; P8LE-NEXT:    srwi r5, r4, 31
; P8LE-NEXT:    srawi r4, r4, 6
; P8LE-NEXT:    add r4, r4, r5
; P8LE-NEXT:    mulli r4, r4, -124
; P8LE-NEXT:    sub r3, r3, r4
; P8LE-NEXT:    vmrghh v2, v3, v2
; P8LE-NEXT:    mtvsrd v3, r3
; P8LE-NEXT:    vmrghh v3, v3, v4
; P8LE-NEXT:    xxmrglw v2, v2, v3
; P8LE-NEXT:    blr
;
; P8BE-LABEL: fold_srem_vec_1:
; P8BE:       # %bb.0:
; P8BE-NEXT:    mfvsrd r3, v2
; P8BE-NEXT:    addis r6, r2, .LCPI0_0@toc@ha
; P8BE-NEXT:    lis r4, -16728
; P8BE-NEXT:    lis r5, 21399
; P8BE-NEXT:    lis r7, 31710
; P8BE-NEXT:    addi r6, r6, .LCPI0_0@toc@l
; P8BE-NEXT:    ori r4, r4, 63249
; P8BE-NEXT:    ori r5, r5, 33437
; P8BE-NEXT:    ori r7, r7, 63421
; P8BE-NEXT:    lxvw4x v2, 0, r6
; P8BE-NEXT:    clrldi r6, r3, 48
; P8BE-NEXT:    rldicl r8, r3, 48, 48
; P8BE-NEXT:    rldicl r9, r3, 32, 48
; P8BE-NEXT:    rldicl r3, r3, 16, 48
; P8BE-NEXT:    extsh r6, r6
; P8BE-NEXT:    extsh r8, r8
; P8BE-NEXT:    extsh r9, r9
; P8BE-NEXT:    extsh r3, r3
; P8BE-NEXT:    mulhw r4, r6, r4
; P8BE-NEXT:    mulhw r5, r8, r5
; P8BE-NEXT:    mulhw r7, r9, r7
; P8BE-NEXT:    srwi r10, r4, 31
; P8BE-NEXT:    srawi r4, r4, 8
; P8BE-NEXT:    sub r7, r7, r9
; P8BE-NEXT:    add r4, r4, r10
; P8BE-NEXT:    srwi r10, r5, 31
; P8BE-NEXT:    srawi r5, r5, 5
; P8BE-NEXT:    mulli r4, r4, -1003
; P8BE-NEXT:    add r5, r5, r10
; P8BE-NEXT:    srwi r10, r7, 31
; P8BE-NEXT:    srawi r7, r7, 6
; P8BE-NEXT:    add r7, r7, r10
; P8BE-NEXT:    mulli r5, r5, 98
; P8BE-NEXT:    sub r4, r6, r4
; P8BE-NEXT:    mtvsrwz v3, r4
; P8BE-NEXT:    mulli r4, r7, -124
; P8BE-NEXT:    sub r5, r8, r5
; P8BE-NEXT:    mtvsrwz v4, r5
; P8BE-NEXT:    sub r4, r9, r4
; P8BE-NEXT:    mtvsrwz v5, r4
; P8BE-NEXT:    lis r4, -21386
; P8BE-NEXT:    ori r4, r4, 37253
; P8BE-NEXT:    mulhw r4, r3, r4
; P8BE-NEXT:    add r4, r4, r3
; P8BE-NEXT:    srwi r5, r4, 31
; P8BE-NEXT:    srawi r4, r4, 6
; P8BE-NEXT:    add r4, r4, r5
; P8BE-NEXT:    mulli r4, r4, 95
; P8BE-NEXT:    sub r3, r3, r4
; P8BE-NEXT:    vperm v3, v4, v3, v2
; P8BE-NEXT:    mtvsrwz v4, r3
; P8BE-NEXT:    vperm v2, v4, v5, v2
; P8BE-NEXT:    xxmrghw v2, v2, v3
; P8BE-NEXT:    blr
  %1 = srem <4 x i16> %x, <i16 95, i16 -124, i16 98, i16 -1003>
  ret <4 x i16> %1
}

define <4 x i16> @fold_srem_vec_2(<4 x i16> %x) {
; P9LE-LABEL: fold_srem_vec_2:
; P9LE:       # %bb.0:
; P9LE-NEXT:    li r3, 0
; P9LE-NEXT:    lis r4, -21386
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    ori r4, r4, 37253
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r5, r3, r4
; P9LE-NEXT:    add r5, r5, r3
; P9LE-NEXT:    srwi r6, r5, 31
; P9LE-NEXT:    srawi r5, r5, 6
; P9LE-NEXT:    add r5, r5, r6
; P9LE-NEXT:    mulli r5, r5, 95
; P9LE-NEXT:    sub r3, r3, r5
; P9LE-NEXT:    mtvsrd v3, r3
; P9LE-NEXT:    li r3, 2
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r5, r3, r4
; P9LE-NEXT:    add r5, r5, r3
; P9LE-NEXT:    srwi r6, r5, 31
; P9LE-NEXT:    srawi r5, r5, 6
; P9LE-NEXT:    add r5, r5, r6
; P9LE-NEXT:    mulli r5, r5, 95
; P9LE-NEXT:    sub r3, r3, r5
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 4
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    vmrghh v3, v4, v3
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r5, r3, r4
; P9LE-NEXT:    add r5, r5, r3
; P9LE-NEXT:    srwi r6, r5, 31
; P9LE-NEXT:    srawi r5, r5, 6
; P9LE-NEXT:    add r5, r5, r6
; P9LE-NEXT:    mulli r5, r5, 95
; P9LE-NEXT:    sub r3, r3, r5
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 6
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    add r4, r4, r3
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 6
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 95
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    mtvsrd v2, r3
; P9LE-NEXT:    vmrghh v2, v2, v4
; P9LE-NEXT:    xxmrglw v2, v2, v3
; P9LE-NEXT:    blr
;
; P9BE-LABEL: fold_srem_vec_2:
; P9BE:       # %bb.0:
; P9BE-NEXT:    li r3, 6
; P9BE-NEXT:    lis r4, -21386
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    ori r4, r4, 37253
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r5, r3, r4
; P9BE-NEXT:    add r5, r5, r3
; P9BE-NEXT:    srwi r6, r5, 31
; P9BE-NEXT:    srawi r5, r5, 6
; P9BE-NEXT:    add r5, r5, r6
; P9BE-NEXT:    mulli r5, r5, 95
; P9BE-NEXT:    sub r3, r3, r5
; P9BE-NEXT:    mtfprwz f0, r3
; P9BE-NEXT:    li r3, 4
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r5, r3, r4
; P9BE-NEXT:    add r5, r5, r3
; P9BE-NEXT:    srwi r6, r5, 31
; P9BE-NEXT:    srawi r5, r5, 6
; P9BE-NEXT:    add r5, r5, r6
; P9BE-NEXT:    mulli r5, r5, 95
; P9BE-NEXT:    sub r3, r3, r5
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    addis r3, r2, .LCPI1_0@toc@ha
; P9BE-NEXT:    addi r3, r3, .LCPI1_0@toc@l
; P9BE-NEXT:    lxv vs2, 0(r3)
; P9BE-NEXT:    li r3, 2
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    xxperm vs0, vs1, vs2
; P9BE-NEXT:    mulhw r5, r3, r4
; P9BE-NEXT:    add r5, r5, r3
; P9BE-NEXT:    srwi r6, r5, 31
; P9BE-NEXT:    srawi r5, r5, 6
; P9BE-NEXT:    add r5, r5, r6
; P9BE-NEXT:    mulli r5, r5, 95
; P9BE-NEXT:    sub r3, r3, r5
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    li r3, 0
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    add r4, r4, r3
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 6
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 95
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mtfprwz f3, r3
; P9BE-NEXT:    xxperm vs1, vs3, vs2
; P9BE-NEXT:    xxmrghw v2, vs1, vs0
; P9BE-NEXT:    blr
;
; P8LE-LABEL: fold_srem_vec_2:
; P8LE:       # %bb.0:
; P8LE-NEXT:    xxswapd vs0, v2
; P8LE-NEXT:    lis r4, -21386
; P8LE-NEXT:    mffprd r3, f0
; P8LE-NEXT:    ori r4, r4, 37253
; P8LE-NEXT:    clrldi r5, r3, 48
; P8LE-NEXT:    rldicl r6, r3, 48, 48
; P8LE-NEXT:    rldicl r7, r3, 32, 48
; P8LE-NEXT:    rldicl r3, r3, 16, 48
; P8LE-NEXT:    extsh r5, r5
; P8LE-NEXT:    extsh r6, r6
; P8LE-NEXT:    extsh r7, r7
; P8LE-NEXT:    extsh r3, r3
; P8LE-NEXT:    mulhw r8, r5, r4
; P8LE-NEXT:    mulhw r9, r6, r4
; P8LE-NEXT:    mulhw r10, r7, r4
; P8LE-NEXT:    mulhw r4, r3, r4
; P8LE-NEXT:    add r8, r8, r5
; P8LE-NEXT:    add r9, r9, r6
; P8LE-NEXT:    add r10, r10, r7
; P8LE-NEXT:    add r4, r4, r3
; P8LE-NEXT:    srwi r11, r8, 31
; P8LE-NEXT:    srawi r8, r8, 6
; P8LE-NEXT:    add r8, r8, r11
; P8LE-NEXT:    srwi r11, r9, 31
; P8LE-NEXT:    srawi r9, r9, 6
; P8LE-NEXT:    mulli r8, r8, 95
; P8LE-NEXT:    add r9, r9, r11
; P8LE-NEXT:    srwi r11, r10, 31
; P8LE-NEXT:    srawi r10, r10, 6
; P8LE-NEXT:    add r10, r10, r11
; P8LE-NEXT:    srwi r11, r4, 31
; P8LE-NEXT:    srawi r4, r4, 6
; P8LE-NEXT:    add r4, r4, r11
; P8LE-NEXT:    sub r5, r5, r8
; P8LE-NEXT:    mulli r8, r9, 95
; P8LE-NEXT:    mulli r4, r4, 95
; P8LE-NEXT:    mtvsrd v2, r5
; P8LE-NEXT:    sub r6, r6, r8
; P8LE-NEXT:    mulli r8, r10, 95
; P8LE-NEXT:    sub r3, r3, r4
; P8LE-NEXT:    mtvsrd v3, r6
; P8LE-NEXT:    sub r7, r7, r8
; P8LE-NEXT:    mtvsrd v4, r7
; P8LE-NEXT:    vmrghh v2, v3, v2
; P8LE-NEXT:    mtvsrd v3, r3
; P8LE-NEXT:    vmrghh v3, v3, v4
; P8LE-NEXT:    xxmrglw v2, v3, v2
; P8LE-NEXT:    blr
;
; P8BE-LABEL: fold_srem_vec_2:
; P8BE:       # %bb.0:
; P8BE-NEXT:    mfvsrd r3, v2
; P8BE-NEXT:    lis r4, -21386
; P8BE-NEXT:    ori r4, r4, 37253
; P8BE-NEXT:    clrldi r5, r3, 48
; P8BE-NEXT:    rldicl r6, r3, 48, 48
; P8BE-NEXT:    rldicl r7, r3, 32, 48
; P8BE-NEXT:    rldicl r3, r3, 16, 48
; P8BE-NEXT:    extsh r5, r5
; P8BE-NEXT:    extsh r6, r6
; P8BE-NEXT:    extsh r7, r7
; P8BE-NEXT:    extsh r3, r3
; P8BE-NEXT:    mulhw r8, r5, r4
; P8BE-NEXT:    mulhw r9, r6, r4
; P8BE-NEXT:    mulhw r10, r7, r4
; P8BE-NEXT:    mulhw r4, r3, r4
; P8BE-NEXT:    add r8, r8, r5
; P8BE-NEXT:    add r9, r9, r6
; P8BE-NEXT:    add r10, r10, r7
; P8BE-NEXT:    add r4, r4, r3
; P8BE-NEXT:    srwi r11, r8, 31
; P8BE-NEXT:    srawi r8, r8, 6
; P8BE-NEXT:    add r8, r8, r11
; P8BE-NEXT:    srwi r11, r9, 31
; P8BE-NEXT:    srawi r9, r9, 6
; P8BE-NEXT:    mulli r8, r8, 95
; P8BE-NEXT:    add r9, r9, r11
; P8BE-NEXT:    srwi r11, r10, 31
; P8BE-NEXT:    srawi r10, r10, 6
; P8BE-NEXT:    add r10, r10, r11
; P8BE-NEXT:    srwi r11, r4, 31
; P8BE-NEXT:    srawi r4, r4, 6
; P8BE-NEXT:    add r4, r4, r11
; P8BE-NEXT:    addis r11, r2, .LCPI1_0@toc@ha
; P8BE-NEXT:    sub r5, r5, r8
; P8BE-NEXT:    mulli r8, r9, 95
; P8BE-NEXT:    addi r11, r11, .LCPI1_0@toc@l
; P8BE-NEXT:    mulli r4, r4, 95
; P8BE-NEXT:    mtvsrwz v3, r5
; P8BE-NEXT:    lxvw4x v2, 0, r11
; P8BE-NEXT:    sub r6, r6, r8
; P8BE-NEXT:    mulli r8, r10, 95
; P8BE-NEXT:    sub r3, r3, r4
; P8BE-NEXT:    mtvsrwz v4, r6
; P8BE-NEXT:    sub r7, r7, r8
; P8BE-NEXT:    mtvsrwz v5, r7
; P8BE-NEXT:    vperm v3, v4, v3, v2
; P8BE-NEXT:    mtvsrwz v4, r3
; P8BE-NEXT:    vperm v2, v4, v5, v2
; P8BE-NEXT:    xxmrghw v2, v2, v3
; P8BE-NEXT:    blr
  %1 = srem <4 x i16> %x, <i16 95, i16 95, i16 95, i16 95>
  ret <4 x i16> %1
}


; Don't fold if we can combine srem with sdiv.
define <4 x i16> @combine_srem_sdiv(<4 x i16> %x) {
; P9LE-LABEL: combine_srem_sdiv:
; P9LE:       # %bb.0:
; P9LE-NEXT:    li r3, 0
; P9LE-NEXT:    lis r4, -21386
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    ori r4, r4, 37253
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r5, r3, r4
; P9LE-NEXT:    add r5, r5, r3
; P9LE-NEXT:    srwi r6, r5, 31
; P9LE-NEXT:    srawi r5, r5, 6
; P9LE-NEXT:    add r5, r5, r6
; P9LE-NEXT:    mulli r6, r5, 95
; P9LE-NEXT:    sub r3, r3, r6
; P9LE-NEXT:    mtvsrd v3, r3
; P9LE-NEXT:    li r3, 2
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r6, r3
; P9LE-NEXT:    mulhw r7, r6, r4
; P9LE-NEXT:    add r6, r7, r6
; P9LE-NEXT:    srwi r7, r6, 31
; P9LE-NEXT:    srawi r6, r6, 6
; P9LE-NEXT:    add r6, r6, r7
; P9LE-NEXT:    mulli r7, r6, 95
; P9LE-NEXT:    sub r3, r3, r7
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 4
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    vmrghh v3, v4, v3
; P9LE-NEXT:    extsh r7, r3
; P9LE-NEXT:    mulhw r8, r7, r4
; P9LE-NEXT:    add r7, r8, r7
; P9LE-NEXT:    srwi r8, r7, 31
; P9LE-NEXT:    srawi r7, r7, 6
; P9LE-NEXT:    add r7, r7, r8
; P9LE-NEXT:    mulli r8, r7, 95
; P9LE-NEXT:    sub r3, r3, r8
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 6
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r8, r3
; P9LE-NEXT:    mulhw r4, r8, r4
; P9LE-NEXT:    add r4, r4, r8
; P9LE-NEXT:    srwi r8, r4, 31
; P9LE-NEXT:    srawi r4, r4, 6
; P9LE-NEXT:    add r4, r4, r8
; P9LE-NEXT:    mulli r8, r4, 95
; P9LE-NEXT:    mtvsrd v5, r4
; P9LE-NEXT:    sub r3, r3, r8
; P9LE-NEXT:    mtvsrd v2, r3
; P9LE-NEXT:    vmrghh v2, v2, v4
; P9LE-NEXT:    mtvsrd v4, r6
; P9LE-NEXT:    xxmrglw v2, v2, v3
; P9LE-NEXT:    mtvsrd v3, r5
; P9LE-NEXT:    vmrghh v3, v4, v3
; P9LE-NEXT:    mtvsrd v4, r7
; P9LE-NEXT:    vmrghh v4, v5, v4
; P9LE-NEXT:    xxmrglw v3, v4, v3
; P9LE-NEXT:    vadduhm v2, v2, v3
; P9LE-NEXT:    blr
;
; P9BE-LABEL: combine_srem_sdiv:
; P9BE:       # %bb.0:
; P9BE-NEXT:    li r3, 6
; P9BE-NEXT:    lis r5, -21386
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    ori r5, r5, 37253
; P9BE-NEXT:    extsh r4, r3
; P9BE-NEXT:    mulhw r6, r4, r5
; P9BE-NEXT:    add r4, r6, r4
; P9BE-NEXT:    srwi r6, r4, 31
; P9BE-NEXT:    srawi r4, r4, 6
; P9BE-NEXT:    add r4, r4, r6
; P9BE-NEXT:    mulli r6, r4, 95
; P9BE-NEXT:    sub r3, r3, r6
; P9BE-NEXT:    mtfprwz f0, r3
; P9BE-NEXT:    li r3, 4
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r6, r3
; P9BE-NEXT:    mulhw r7, r6, r5
; P9BE-NEXT:    add r6, r7, r6
; P9BE-NEXT:    srwi r7, r6, 31
; P9BE-NEXT:    srawi r6, r6, 6
; P9BE-NEXT:    add r6, r6, r7
; P9BE-NEXT:    mulli r7, r6, 95
; P9BE-NEXT:    sub r3, r3, r7
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    addis r3, r2, .LCPI2_0@toc@ha
; P9BE-NEXT:    addi r3, r3, .LCPI2_0@toc@l
; P9BE-NEXT:    lxv vs2, 0(r3)
; P9BE-NEXT:    li r3, 2
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r7, r3
; P9BE-NEXT:    xxperm vs0, vs1, vs2
; P9BE-NEXT:    mulhw r8, r7, r5
; P9BE-NEXT:    add r7, r8, r7
; P9BE-NEXT:    srwi r8, r7, 31
; P9BE-NEXT:    srawi r7, r7, 6
; P9BE-NEXT:    add r7, r7, r8
; P9BE-NEXT:    mulli r8, r7, 95
; P9BE-NEXT:    sub r3, r3, r8
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    li r3, 0
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r5, r3, r5
; P9BE-NEXT:    add r5, r5, r3
; P9BE-NEXT:    srwi r8, r5, 31
; P9BE-NEXT:    srawi r5, r5, 6
; P9BE-NEXT:    add r5, r5, r8
; P9BE-NEXT:    mulli r8, r5, 95
; P9BE-NEXT:    sub r3, r3, r8
; P9BE-NEXT:    mtfprwz f3, r3
; P9BE-NEXT:    xxperm vs1, vs3, vs2
; P9BE-NEXT:    mtfprwz f3, r5
; P9BE-NEXT:    xxmrghw v2, vs1, vs0
; P9BE-NEXT:    mtfprwz f0, r4
; P9BE-NEXT:    mtfprwz f1, r6
; P9BE-NEXT:    xxperm vs0, vs1, vs2
; P9BE-NEXT:    mtfprwz f1, r7
; P9BE-NEXT:    xxperm vs1, vs3, vs2
; P9BE-NEXT:    xxmrghw v3, vs1, vs0
; P9BE-NEXT:    vadduhm v2, v2, v3
; P9BE-NEXT:    blr
;
; P8LE-LABEL: combine_srem_sdiv:
; P8LE:       # %bb.0:
; P8LE-NEXT:    xxswapd vs0, v2
; P8LE-NEXT:    lis r4, -21386
; P8LE-NEXT:    mffprd r3, f0
; P8LE-NEXT:    ori r4, r4, 37253
; P8LE-NEXT:    rldicl r6, r3, 48, 48
; P8LE-NEXT:    rldicl r7, r3, 32, 48
; P8LE-NEXT:    clrldi r5, r3, 48
; P8LE-NEXT:    rldicl r3, r3, 16, 48
; P8LE-NEXT:    extsh r8, r6
; P8LE-NEXT:    extsh r9, r7
; P8LE-NEXT:    extsh r5, r5
; P8LE-NEXT:    extsh r10, r3
; P8LE-NEXT:    mulhw r11, r8, r4
; P8LE-NEXT:    add r8, r11, r8
; P8LE-NEXT:    mulhw r11, r9, r4
; P8LE-NEXT:    add r9, r11, r9
; P8LE-NEXT:    mulhw r11, r5, r4
; P8LE-NEXT:    mulhw r4, r10, r4
; P8LE-NEXT:    add r11, r11, r5
; P8LE-NEXT:    add r4, r4, r10
; P8LE-NEXT:    srwi r10, r11, 31
; P8LE-NEXT:    srawi r11, r11, 6
; P8LE-NEXT:    add r10, r11, r10
; P8LE-NEXT:    srwi r11, r8, 31
; P8LE-NEXT:    srawi r8, r8, 6
; P8LE-NEXT:    add r8, r8, r11
; P8LE-NEXT:    srwi r11, r9, 31
; P8LE-NEXT:    srawi r9, r9, 6
; P8LE-NEXT:    mtvsrd v2, r10
; P8LE-NEXT:    add r9, r9, r11
; P8LE-NEXT:    srwi r11, r4, 31
; P8LE-NEXT:    srawi r4, r4, 6
; P8LE-NEXT:    mtvsrd v3, r8
; P8LE-NEXT:    add r4, r4, r11
; P8LE-NEXT:    mulli r11, r10, 95
; P8LE-NEXT:    sub r5, r5, r11
; P8LE-NEXT:    mulli r11, r8, 95
; P8LE-NEXT:    mtvsrd v4, r5
; P8LE-NEXT:    sub r6, r6, r11
; P8LE-NEXT:    mulli r11, r9, 95
; P8LE-NEXT:    mtvsrd v5, r6
; P8LE-NEXT:    sub r7, r7, r11
; P8LE-NEXT:    mulli r11, r4, 95
; P8LE-NEXT:    mtvsrd v0, r7
; P8LE-NEXT:    sub r3, r3, r11
; P8LE-NEXT:    vmrghh v2, v3, v2
; P8LE-NEXT:    mtvsrd v3, r9
; P8LE-NEXT:    vmrghh v4, v5, v4
; P8LE-NEXT:    mtvsrd v5, r3
; P8LE-NEXT:    vmrghh v5, v5, v0
; P8LE-NEXT:    mtvsrd v0, r4
; P8LE-NEXT:    xxmrglw v4, v5, v4
; P8LE-NEXT:    vmrghh v3, v0, v3
; P8LE-NEXT:    xxmrglw v2, v3, v2
; P8LE-NEXT:    vadduhm v2, v4, v2
; P8LE-NEXT:    blr
;
; P8BE-LABEL: combine_srem_sdiv:
; P8BE:       # %bb.0:
; P8BE-NEXT:    mfvsrd r4, v2
; P8BE-NEXT:    lis r5, -21386
; P8BE-NEXT:    ori r5, r5, 37253
; P8BE-NEXT:    clrldi r3, r4, 48
; P8BE-NEXT:    rldicl r6, r4, 48, 48
; P8BE-NEXT:    rldicl r7, r4, 32, 48
; P8BE-NEXT:    rldicl r4, r4, 16, 48
; P8BE-NEXT:    extsh r8, r3
; P8BE-NEXT:    extsh r9, r6
; P8BE-NEXT:    extsh r10, r7
; P8BE-NEXT:    extsh r4, r4
; P8BE-NEXT:    mulhw r11, r8, r5
; P8BE-NEXT:    add r8, r11, r8
; P8BE-NEXT:    mulhw r11, r9, r5
; P8BE-NEXT:    add r9, r11, r9
; P8BE-NEXT:    mulhw r11, r10, r5
; P8BE-NEXT:    mulhw r5, r4, r5
; P8BE-NEXT:    add r10, r11, r10
; P8BE-NEXT:    srwi r11, r8, 31
; P8BE-NEXT:    srawi r8, r8, 6
; P8BE-NEXT:    add r5, r5, r4
; P8BE-NEXT:    add r8, r8, r11
; P8BE-NEXT:    srwi r11, r9, 31
; P8BE-NEXT:    srawi r9, r9, 6
; P8BE-NEXT:    add r9, r9, r11
; P8BE-NEXT:    srwi r11, r10, 31
; P8BE-NEXT:    srawi r10, r10, 6
; P8BE-NEXT:    mtvsrwz v3, r8
; P8BE-NEXT:    add r10, r10, r11
; P8BE-NEXT:    srwi r11, r5, 31
; P8BE-NEXT:    srawi r5, r5, 6
; P8BE-NEXT:    mtvsrwz v4, r9
; P8BE-NEXT:    add r5, r5, r11
; P8BE-NEXT:    mulli r11, r8, 95
; P8BE-NEXT:    sub r3, r3, r11
; P8BE-NEXT:    mulli r11, r9, 95
; P8BE-NEXT:    mtvsrwz v5, r3
; P8BE-NEXT:    sub r6, r6, r11
; P8BE-NEXT:    mulli r11, r10, 95
; P8BE-NEXT:    mtvsrwz v0, r6
; P8BE-NEXT:    sub r7, r7, r11
; P8BE-NEXT:    mulli r11, r5, 95
; P8BE-NEXT:    mtvsrwz v1, r7
; P8BE-NEXT:    sub r4, r4, r11
; P8BE-NEXT:    addis r11, r2, .LCPI2_0@toc@ha
; P8BE-NEXT:    addi r11, r11, .LCPI2_0@toc@l
; P8BE-NEXT:    lxvw4x v2, 0, r11
; P8BE-NEXT:    vperm v5, v0, v5, v2
; P8BE-NEXT:    mtvsrwz v0, r4
; P8BE-NEXT:    vperm v3, v4, v3, v2
; P8BE-NEXT:    mtvsrwz v4, r10
; P8BE-NEXT:    vperm v0, v0, v1, v2
; P8BE-NEXT:    mtvsrwz v1, r5
; P8BE-NEXT:    vperm v2, v1, v4, v2
; P8BE-NEXT:    xxmrghw v4, v0, v5
; P8BE-NEXT:    xxmrghw v2, v2, v3
; P8BE-NEXT:    vadduhm v2, v4, v2
; P8BE-NEXT:    blr
  %1 = srem <4 x i16> %x, <i16 95, i16 95, i16 95, i16 95>
  %2 = sdiv <4 x i16> %x, <i16 95, i16 95, i16 95, i16 95>
  %3 = add <4 x i16> %1, %2
  ret <4 x i16> %3
}

; Don't fold for divisors that are a power of two.
define <4 x i16> @dont_fold_srem_power_of_two(<4 x i16> %x) {
; P9LE-LABEL: dont_fold_srem_power_of_two:
; P9LE:       # %bb.0:
; P9LE-NEXT:    li r3, 0
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    srawi r4, r3, 6
; P9LE-NEXT:    addze r4, r4
; P9LE-NEXT:    slwi r4, r4, 6
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    mtvsrd v3, r3
; P9LE-NEXT:    li r3, 2
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    srawi r4, r3, 5
; P9LE-NEXT:    addze r4, r4
; P9LE-NEXT:    slwi r4, r4, 5
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    lis r4, -21386
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 6
; P9LE-NEXT:    ori r4, r4, 37253
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    vmrghh v3, v4, v3
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    add r4, r4, r3
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 6
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 95
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 4
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    srawi r4, r3, 3
; P9LE-NEXT:    addze r4, r4
; P9LE-NEXT:    slwi r4, r4, 3
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    mtvsrd v2, r3
; P9LE-NEXT:    vmrghh v2, v4, v2
; P9LE-NEXT:    xxmrglw v2, v2, v3
; P9LE-NEXT:    blr
;
; P9BE-LABEL: dont_fold_srem_power_of_two:
; P9BE:       # %bb.0:
; P9BE-NEXT:    li r3, 2
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    srawi r4, r3, 5
; P9BE-NEXT:    addze r4, r4
; P9BE-NEXT:    slwi r4, r4, 5
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mtfprwz f0, r3
; P9BE-NEXT:    li r3, 0
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    srawi r4, r3, 6
; P9BE-NEXT:    addze r4, r4
; P9BE-NEXT:    slwi r4, r4, 6
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    lis r4, -21386
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    addis r3, r2, .LCPI3_0@toc@ha
; P9BE-NEXT:    ori r4, r4, 37253
; P9BE-NEXT:    addi r3, r3, .LCPI3_0@toc@l
; P9BE-NEXT:    lxv vs2, 0(r3)
; P9BE-NEXT:    li r3, 6
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    xxperm vs0, vs1, vs2
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    add r4, r4, r3
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 6
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 95
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    li r3, 4
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    srawi r4, r3, 3
; P9BE-NEXT:    addze r4, r4
; P9BE-NEXT:    slwi r4, r4, 3
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mtfprwz f3, r3
; P9BE-NEXT:    xxperm vs1, vs3, vs2
; P9BE-NEXT:    xxmrghw v2, vs0, vs1
; P9BE-NEXT:    blr
;
; P8LE-LABEL: dont_fold_srem_power_of_two:
; P8LE:       # %bb.0:
; P8LE-NEXT:    xxswapd vs0, v2
; P8LE-NEXT:    mffprd r3, f0
; P8LE-NEXT:    clrldi r4, r3, 48
; P8LE-NEXT:    extsh r4, r4
; P8LE-NEXT:    srawi r5, r4, 6
; P8LE-NEXT:    addze r5, r5
; P8LE-NEXT:    slwi r5, r5, 6
; P8LE-NEXT:    sub r4, r4, r5
; P8LE-NEXT:    mtvsrd v2, r4
; P8LE-NEXT:    rldicl r4, r3, 48, 48
; P8LE-NEXT:    extsh r4, r4
; P8LE-NEXT:    srawi r5, r4, 5
; P8LE-NEXT:    addze r5, r5
; P8LE-NEXT:    slwi r5, r5, 5
; P8LE-NEXT:    sub r4, r4, r5
; P8LE-NEXT:    lis r5, -21386
; P8LE-NEXT:    mtvsrd v3, r4
; P8LE-NEXT:    rldicl r4, r3, 16, 48
; P8LE-NEXT:    ori r5, r5, 37253
; P8LE-NEXT:    rldicl r3, r3, 32, 48
; P8LE-NEXT:    extsh r4, r4
; P8LE-NEXT:    extsh r3, r3
; P8LE-NEXT:    mulhw r5, r4, r5
; P8LE-NEXT:    add r5, r5, r4
; P8LE-NEXT:    srwi r6, r5, 31
; P8LE-NEXT:    srawi r5, r5, 6
; P8LE-NEXT:    add r5, r5, r6
; P8LE-NEXT:    mulli r5, r5, 95
; P8LE-NEXT:    sub r4, r4, r5
; P8LE-NEXT:    vmrghh v2, v3, v2
; P8LE-NEXT:    mtvsrd v3, r4
; P8LE-NEXT:    srawi r4, r3, 3
; P8LE-NEXT:    addze r4, r4
; P8LE-NEXT:    slwi r4, r4, 3
; P8LE-NEXT:    sub r3, r3, r4
; P8LE-NEXT:    mtvsrd v4, r3
; P8LE-NEXT:    vmrghh v3, v3, v4
; P8LE-NEXT:    xxmrglw v2, v3, v2
; P8LE-NEXT:    blr
;
; P8BE-LABEL: dont_fold_srem_power_of_two:
; P8BE:       # %bb.0:
; P8BE-NEXT:    mfvsrd r3, v2
; P8BE-NEXT:    rldicl r4, r3, 32, 48
; P8BE-NEXT:    extsh r4, r4
; P8BE-NEXT:    srawi r5, r4, 5
; P8BE-NEXT:    addze r5, r5
; P8BE-NEXT:    slwi r5, r5, 5
; P8BE-NEXT:    sub r4, r4, r5
; P8BE-NEXT:    mtvsrwz v2, r4
; P8BE-NEXT:    rldicl r4, r3, 16, 48
; P8BE-NEXT:    extsh r4, r4
; P8BE-NEXT:    srawi r5, r4, 6
; P8BE-NEXT:    addze r5, r5
; P8BE-NEXT:    slwi r5, r5, 6
; P8BE-NEXT:    sub r4, r4, r5
; P8BE-NEXT:    lis r5, -21386
; P8BE-NEXT:    mtvsrwz v3, r4
; P8BE-NEXT:    addis r4, r2, .LCPI3_0@toc@ha
; P8BE-NEXT:    ori r5, r5, 37253
; P8BE-NEXT:    addi r4, r4, .LCPI3_0@toc@l
; P8BE-NEXT:    lxvw4x v4, 0, r4
; P8BE-NEXT:    clrldi r4, r3, 48
; P8BE-NEXT:    rldicl r3, r3, 48, 48
; P8BE-NEXT:    extsh r4, r4
; P8BE-NEXT:    extsh r3, r3
; P8BE-NEXT:    mulhw r5, r4, r5
; P8BE-NEXT:    add r5, r5, r4
; P8BE-NEXT:    srwi r6, r5, 31
; P8BE-NEXT:    srawi r5, r5, 6
; P8BE-NEXT:    add r5, r5, r6
; P8BE-NEXT:    mulli r5, r5, 95
; P8BE-NEXT:    sub r4, r4, r5
; P8BE-NEXT:    vperm v2, v3, v2, v4
; P8BE-NEXT:    mtvsrwz v3, r4
; P8BE-NEXT:    srawi r4, r3, 3
; P8BE-NEXT:    addze r4, r4
; P8BE-NEXT:    slwi r4, r4, 3
; P8BE-NEXT:    sub r3, r3, r4
; P8BE-NEXT:    mtvsrwz v5, r3
; P8BE-NEXT:    vperm v3, v5, v3, v4
; P8BE-NEXT:    xxmrghw v2, v2, v3
; P8BE-NEXT:    blr
  %1 = srem <4 x i16> %x, <i16 64, i16 32, i16 8, i16 95>
  ret <4 x i16> %1
}

; Don't fold if the divisor is one.
define <4 x i16> @dont_fold_srem_one(<4 x i16> %x) {
; P9LE-LABEL: dont_fold_srem_one:
; P9LE:       # %bb.0:
; P9LE-NEXT:    li r3, 2
; P9LE-NEXT:    lis r4, -14230
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    ori r4, r4, 30865
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    add r4, r4, r3
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 9
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 654
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    lis r4, -19946
; P9LE-NEXT:    mtvsrd v3, r3
; P9LE-NEXT:    li r3, 0
; P9LE-NEXT:    ori r4, r4, 17097
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 4
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    vmrghh v3, v3, v4
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    add r4, r4, r3
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 4
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 23
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    lis r4, 24749
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 6
; P9LE-NEXT:    ori r4, r4, 47143
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 11
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 5423
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    mtvsrd v2, r3
; P9LE-NEXT:    vmrghh v2, v2, v4
; P9LE-NEXT:    xxmrglw v2, v2, v3
; P9LE-NEXT:    blr
;
; P9BE-LABEL: dont_fold_srem_one:
; P9BE:       # %bb.0:
; P9BE-NEXT:    li r3, 4
; P9BE-NEXT:    lis r4, -19946
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    ori r4, r4, 17097
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    add r4, r4, r3
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 4
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 23
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    lis r4, 24749
; P9BE-NEXT:    mtfprwz f0, r3
; P9BE-NEXT:    li r3, 6
; P9BE-NEXT:    ori r4, r4, 47143
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 11
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 5423
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    lis r4, -14230
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    addis r3, r2, .LCPI4_0@toc@ha
; P9BE-NEXT:    ori r4, r4, 30865
; P9BE-NEXT:    addi r3, r3, .LCPI4_0@toc@l
; P9BE-NEXT:    lxv vs2, 0(r3)
; P9BE-NEXT:    li r3, 2
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    xxperm vs1, vs0, vs2
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    add r4, r4, r3
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 9
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 654
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mtfprwz f0, r3
; P9BE-NEXT:    li r3, 0
; P9BE-NEXT:    mtfprwz f3, r3
; P9BE-NEXT:    xxperm vs0, vs3, vs2
; P9BE-NEXT:    xxmrghw v2, vs0, vs1
; P9BE-NEXT:    blr
;
; P8LE-LABEL: dont_fold_srem_one:
; P8LE:       # %bb.0:
; P8LE-NEXT:    xxswapd vs0, v2
; P8LE-NEXT:    lis r8, 24749
; P8LE-NEXT:    lis r4, -19946
; P8LE-NEXT:    lis r5, -14230
; P8LE-NEXT:    mffprd r3, f0
; P8LE-NEXT:    ori r8, r8, 47143
; P8LE-NEXT:    ori r4, r4, 17097
; P8LE-NEXT:    ori r5, r5, 30865
; P8LE-NEXT:    rldicl r6, r3, 32, 48
; P8LE-NEXT:    rldicl r7, r3, 48, 48
; P8LE-NEXT:    rldicl r3, r3, 16, 48
; P8LE-NEXT:    extsh r3, r3
; P8LE-NEXT:    extsh r6, r6
; P8LE-NEXT:    extsh r7, r7
; P8LE-NEXT:    mulhw r8, r3, r8
; P8LE-NEXT:    mulhw r4, r6, r4
; P8LE-NEXT:    mulhw r5, r7, r5
; P8LE-NEXT:    srwi r9, r8, 31
; P8LE-NEXT:    srawi r8, r8, 11
; P8LE-NEXT:    add r4, r4, r6
; P8LE-NEXT:    add r5, r5, r7
; P8LE-NEXT:    add r8, r8, r9
; P8LE-NEXT:    srwi r9, r4, 31
; P8LE-NEXT:    srawi r4, r4, 4
; P8LE-NEXT:    mulli r8, r8, 5423
; P8LE-NEXT:    add r4, r4, r9
; P8LE-NEXT:    srwi r9, r5, 31
; P8LE-NEXT:    srawi r5, r5, 9
; P8LE-NEXT:    add r5, r5, r9
; P8LE-NEXT:    sub r3, r3, r8
; P8LE-NEXT:    mtvsrd v2, r3
; P8LE-NEXT:    mulli r3, r4, 23
; P8LE-NEXT:    mulli r4, r5, 654
; P8LE-NEXT:    sub r3, r6, r3
; P8LE-NEXT:    sub r4, r7, r4
; P8LE-NEXT:    mtvsrd v3, r3
; P8LE-NEXT:    li r3, 0
; P8LE-NEXT:    mtvsrd v4, r3
; P8LE-NEXT:    vmrghh v2, v2, v3
; P8LE-NEXT:    mtvsrd v3, r4
; P8LE-NEXT:    vmrghh v3, v3, v4
; P8LE-NEXT:    xxmrglw v2, v2, v3
; P8LE-NEXT:    blr
;
; P8BE-LABEL: dont_fold_srem_one:
; P8BE:       # %bb.0:
; P8BE-NEXT:    mfvsrd r3, v2
; P8BE-NEXT:    lis r4, -19946
; P8BE-NEXT:    lis r8, 24749
; P8BE-NEXT:    lis r5, -14230
; P8BE-NEXT:    ori r4, r4, 17097
; P8BE-NEXT:    ori r8, r8, 47143
; P8BE-NEXT:    ori r5, r5, 30865
; P8BE-NEXT:    rldicl r6, r3, 48, 48
; P8BE-NEXT:    rldicl r7, r3, 32, 48
; P8BE-NEXT:    clrldi r3, r3, 48
; P8BE-NEXT:    extsh r6, r6
; P8BE-NEXT:    extsh r3, r3
; P8BE-NEXT:    extsh r7, r7
; P8BE-NEXT:    mulhw r4, r6, r4
; P8BE-NEXT:    mulhw r8, r3, r8
; P8BE-NEXT:    mulhw r5, r7, r5
; P8BE-NEXT:    add r4, r4, r6
; P8BE-NEXT:    srwi r9, r8, 31
; P8BE-NEXT:    srawi r8, r8, 11
; P8BE-NEXT:    add r5, r5, r7
; P8BE-NEXT:    add r8, r8, r9
; P8BE-NEXT:    srwi r9, r4, 31
; P8BE-NEXT:    srawi r4, r4, 4
; P8BE-NEXT:    add r4, r4, r9
; P8BE-NEXT:    mulli r8, r8, 5423
; P8BE-NEXT:    srwi r9, r5, 31
; P8BE-NEXT:    srawi r5, r5, 9
; P8BE-NEXT:    mulli r4, r4, 23
; P8BE-NEXT:    add r5, r5, r9
; P8BE-NEXT:    addis r9, r2, .LCPI4_0@toc@ha
; P8BE-NEXT:    addi r9, r9, .LCPI4_0@toc@l
; P8BE-NEXT:    mulli r5, r5, 654
; P8BE-NEXT:    sub r3, r3, r8
; P8BE-NEXT:    lxvw4x v2, 0, r9
; P8BE-NEXT:    sub r4, r6, r4
; P8BE-NEXT:    mtvsrwz v3, r3
; P8BE-NEXT:    mtvsrwz v4, r4
; P8BE-NEXT:    sub r3, r7, r5
; P8BE-NEXT:    vperm v3, v4, v3, v2
; P8BE-NEXT:    mtvsrwz v4, r3
; P8BE-NEXT:    li r3, 0
; P8BE-NEXT:    mtvsrwz v5, r3
; P8BE-NEXT:    vperm v2, v5, v4, v2
; P8BE-NEXT:    xxmrghw v2, v2, v3
; P8BE-NEXT:    blr
  %1 = srem <4 x i16> %x, <i16 1, i16 654, i16 23, i16 5423>
  ret <4 x i16> %1
}

; Don't fold if the divisor is 2^15.
define <4 x i16> @dont_fold_urem_i16_smax(<4 x i16> %x) {
; P9LE-LABEL: dont_fold_urem_i16_smax:
; P9LE:       # %bb.0:
; P9LE-NEXT:    li r3, 4
; P9LE-NEXT:    lis r4, -19946
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    ori r4, r4, 17097
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    add r4, r4, r3
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 4
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 23
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    lis r4, 24749
; P9LE-NEXT:    mtvsrd v3, r3
; P9LE-NEXT:    li r3, 6
; P9LE-NEXT:    ori r4, r4, 47143
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    mulhw r4, r3, r4
; P9LE-NEXT:    srwi r5, r4, 31
; P9LE-NEXT:    srawi r4, r4, 11
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 5423
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    li r3, 2
; P9LE-NEXT:    vextuhrx r3, r3, v2
; P9LE-NEXT:    vmrghh v3, v4, v3
; P9LE-NEXT:    extsh r3, r3
; P9LE-NEXT:    srawi r4, r3, 15
; P9LE-NEXT:    addze r4, r4
; P9LE-NEXT:    slwi r4, r4, 15
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    mtvsrd v2, r3
; P9LE-NEXT:    li r3, 0
; P9LE-NEXT:    mtvsrd v4, r3
; P9LE-NEXT:    vmrghh v2, v2, v4
; P9LE-NEXT:    xxmrglw v2, v3, v2
; P9LE-NEXT:    blr
;
; P9BE-LABEL: dont_fold_urem_i16_smax:
; P9BE:       # %bb.0:
; P9BE-NEXT:    li r3, 4
; P9BE-NEXT:    lis r4, -19946
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    ori r4, r4, 17097
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    add r4, r4, r3
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 4
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 23
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    lis r4, 24749
; P9BE-NEXT:    mtfprwz f0, r3
; P9BE-NEXT:    li r3, 6
; P9BE-NEXT:    ori r4, r4, 47143
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    mulhw r4, r3, r4
; P9BE-NEXT:    srwi r5, r4, 31
; P9BE-NEXT:    srawi r4, r4, 11
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 5423
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mtfprwz f1, r3
; P9BE-NEXT:    addis r3, r2, .LCPI5_0@toc@ha
; P9BE-NEXT:    addi r3, r3, .LCPI5_0@toc@l
; P9BE-NEXT:    lxv vs2, 0(r3)
; P9BE-NEXT:    li r3, 2
; P9BE-NEXT:    vextuhlx r3, r3, v2
; P9BE-NEXT:    extsh r3, r3
; P9BE-NEXT:    xxperm vs1, vs0, vs2
; P9BE-NEXT:    srawi r4, r3, 15
; P9BE-NEXT:    addze r4, r4
; P9BE-NEXT:    slwi r4, r4, 15
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mtfprwz f0, r3
; P9BE-NEXT:    li r3, 0
; P9BE-NEXT:    mtfprwz f3, r3
; P9BE-NEXT:    xxperm vs0, vs3, vs2
; P9BE-NEXT:    xxmrghw v2, vs0, vs1
; P9BE-NEXT:    blr
;
; P8LE-LABEL: dont_fold_urem_i16_smax:
; P8LE:       # %bb.0:
; P8LE-NEXT:    xxswapd vs0, v2
; P8LE-NEXT:    lis r4, -19946
; P8LE-NEXT:    lis r6, 24749
; P8LE-NEXT:    li r8, 0
; P8LE-NEXT:    mffprd r3, f0
; P8LE-NEXT:    ori r4, r4, 17097
; P8LE-NEXT:    ori r6, r6, 47143
; P8LE-NEXT:    mtvsrd v2, r8
; P8LE-NEXT:    rldicl r5, r3, 32, 48
; P8LE-NEXT:    rldicl r7, r3, 16, 48
; P8LE-NEXT:    rldicl r3, r3, 48, 48
; P8LE-NEXT:    extsh r5, r5
; P8LE-NEXT:    extsh r7, r7
; P8LE-NEXT:    extsh r3, r3
; P8LE-NEXT:    mulhw r4, r5, r4
; P8LE-NEXT:    mulhw r6, r7, r6
; P8LE-NEXT:    add r4, r4, r5
; P8LE-NEXT:    srwi r8, r6, 31
; P8LE-NEXT:    srawi r6, r6, 11
; P8LE-NEXT:    add r6, r6, r8
; P8LE-NEXT:    srwi r8, r4, 31
; P8LE-NEXT:    srawi r4, r4, 4
; P8LE-NEXT:    add r4, r4, r8
; P8LE-NEXT:    mulli r6, r6, 5423
; P8LE-NEXT:    mulli r4, r4, 23
; P8LE-NEXT:    sub r6, r7, r6
; P8LE-NEXT:    sub r4, r5, r4
; P8LE-NEXT:    srawi r5, r3, 15
; P8LE-NEXT:    mtvsrd v3, r6
; P8LE-NEXT:    addze r5, r5
; P8LE-NEXT:    mtvsrd v4, r4
; P8LE-NEXT:    slwi r4, r5, 15
; P8LE-NEXT:    sub r3, r3, r4
; P8LE-NEXT:    vmrghh v3, v3, v4
; P8LE-NEXT:    mtvsrd v4, r3
; P8LE-NEXT:    vmrghh v2, v4, v2
; P8LE-NEXT:    xxmrglw v2, v3, v2
; P8LE-NEXT:    blr
;
; P8BE-LABEL: dont_fold_urem_i16_smax:
; P8BE:       # %bb.0:
; P8BE-NEXT:    mfvsrd r3, v2
; P8BE-NEXT:    lis r4, -19946
; P8BE-NEXT:    lis r6, 24749
; P8BE-NEXT:    ori r4, r4, 17097
; P8BE-NEXT:    ori r6, r6, 47143
; P8BE-NEXT:    rldicl r5, r3, 48, 48
; P8BE-NEXT:    clrldi r7, r3, 48
; P8BE-NEXT:    rldicl r3, r3, 32, 48
; P8BE-NEXT:    extsh r5, r5
; P8BE-NEXT:    extsh r7, r7
; P8BE-NEXT:    extsh r3, r3
; P8BE-NEXT:    mulhw r4, r5, r4
; P8BE-NEXT:    mulhw r6, r7, r6
; P8BE-NEXT:    add r4, r4, r5
; P8BE-NEXT:    srwi r8, r6, 31
; P8BE-NEXT:    srawi r6, r6, 11
; P8BE-NEXT:    add r6, r6, r8
; P8BE-NEXT:    srwi r8, r4, 31
; P8BE-NEXT:    srawi r4, r4, 4
; P8BE-NEXT:    add r4, r4, r8
; P8BE-NEXT:    addis r8, r2, .LCPI5_0@toc@ha
; P8BE-NEXT:    mulli r6, r6, 5423
; P8BE-NEXT:    mulli r4, r4, 23
; P8BE-NEXT:    addi r8, r8, .LCPI5_0@toc@l
; P8BE-NEXT:    lxvw4x v2, 0, r8
; P8BE-NEXT:    srawi r8, r3, 15
; P8BE-NEXT:    sub r6, r7, r6
; P8BE-NEXT:    addze r8, r8
; P8BE-NEXT:    sub r4, r5, r4
; P8BE-NEXT:    mtvsrwz v3, r6
; P8BE-NEXT:    slwi r8, r8, 15
; P8BE-NEXT:    mtvsrwz v4, r4
; P8BE-NEXT:    sub r3, r3, r8
; P8BE-NEXT:    vperm v3, v4, v3, v2
; P8BE-NEXT:    mtvsrwz v4, r3
; P8BE-NEXT:    li r3, 0
; P8BE-NEXT:    mtvsrwz v5, r3
; P8BE-NEXT:    vperm v2, v5, v4, v2
; P8BE-NEXT:    xxmrghw v2, v2, v3
; P8BE-NEXT:    blr
  %1 = srem <4 x i16> %x, <i16 1, i16 32768, i16 23, i16 5423>
  ret <4 x i16> %1
}

; Don't fold i64 srem.
define <4 x i64> @dont_fold_srem_i64(<4 x i64> %x) {
; P9LE-LABEL: dont_fold_srem_i64:
; P9LE:       # %bb.0:
; P9LE-NEXT:    lis r4, 12374
; P9LE-NEXT:    mfvsrd r3, v3
; P9LE-NEXT:    ori r4, r4, 56339
; P9LE-NEXT:    rldic r4, r4, 33, 1
; P9LE-NEXT:    oris r4, r4, 58853
; P9LE-NEXT:    ori r4, r4, 6055
; P9LE-NEXT:    mulhd r4, r3, r4
; P9LE-NEXT:    rldicl r5, r4, 1, 63
; P9LE-NEXT:    sradi r4, r4, 11
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    lis r5, 5698
; P9LE-NEXT:    mulli r4, r4, 5423
; P9LE-NEXT:    ori r5, r5, 51289
; P9LE-NEXT:    rldic r5, r5, 35, 0
; P9LE-NEXT:    oris r5, r5, 22795
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    mfvsrld r4, v3
; P9LE-NEXT:    ori r5, r5, 8549
; P9LE-NEXT:    mulhd r5, r4, r5
; P9LE-NEXT:    add r5, r5, r4
; P9LE-NEXT:    rldicl r6, r5, 1, 63
; P9LE-NEXT:    sradi r5, r5, 4
; P9LE-NEXT:    add r5, r5, r6
; P9LE-NEXT:    mulli r5, r5, 23
; P9LE-NEXT:    sub r4, r4, r5
; P9LE-NEXT:    mtvsrdd v3, r3, r4
; P9LE-NEXT:    lis r4, 3206
; P9LE-NEXT:    mfvsrd r3, v2
; P9LE-NEXT:    ori r4, r4, 42889
; P9LE-NEXT:    rldic r4, r4, 35, 1
; P9LE-NEXT:    oris r4, r4, 1603
; P9LE-NEXT:    ori r4, r4, 21445
; P9LE-NEXT:    mulhd r4, r3, r4
; P9LE-NEXT:    rldicl r5, r4, 1, 63
; P9LE-NEXT:    sradi r4, r4, 8
; P9LE-NEXT:    add r4, r4, r5
; P9LE-NEXT:    mulli r4, r4, 654
; P9LE-NEXT:    sub r3, r3, r4
; P9LE-NEXT:    li r4, 0
; P9LE-NEXT:    mtvsrdd v2, r3, r4
; P9LE-NEXT:    blr
;
; P9BE-LABEL: dont_fold_srem_i64:
; P9BE:       # %bb.0:
; P9BE-NEXT:    lis r4, 12374
; P9BE-NEXT:    mfvsrld r3, v3
; P9BE-NEXT:    ori r4, r4, 56339
; P9BE-NEXT:    rldic r4, r4, 33, 1
; P9BE-NEXT:    oris r4, r4, 58853
; P9BE-NEXT:    ori r4, r4, 6055
; P9BE-NEXT:    mulhd r4, r3, r4
; P9BE-NEXT:    rldicl r5, r4, 1, 63
; P9BE-NEXT:    sradi r4, r4, 11
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    lis r5, 5698
; P9BE-NEXT:    ori r5, r5, 51289
; P9BE-NEXT:    mulli r4, r4, 5423
; P9BE-NEXT:    rldic r5, r5, 35, 0
; P9BE-NEXT:    oris r5, r5, 22795
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mfvsrd r4, v3
; P9BE-NEXT:    ori r5, r5, 8549
; P9BE-NEXT:    mulhd r5, r4, r5
; P9BE-NEXT:    add r5, r5, r4
; P9BE-NEXT:    rldicl r6, r5, 1, 63
; P9BE-NEXT:    sradi r5, r5, 4
; P9BE-NEXT:    add r5, r5, r6
; P9BE-NEXT:    mulli r5, r5, 23
; P9BE-NEXT:    sub r4, r4, r5
; P9BE-NEXT:    mtvsrdd v3, r4, r3
; P9BE-NEXT:    lis r4, 3206
; P9BE-NEXT:    mfvsrld r3, v2
; P9BE-NEXT:    ori r4, r4, 42889
; P9BE-NEXT:    rldic r4, r4, 35, 1
; P9BE-NEXT:    oris r4, r4, 1603
; P9BE-NEXT:    ori r4, r4, 21445
; P9BE-NEXT:    mulhd r4, r3, r4
; P9BE-NEXT:    rldicl r5, r4, 1, 63
; P9BE-NEXT:    sradi r4, r4, 8
; P9BE-NEXT:    add r4, r4, r5
; P9BE-NEXT:    mulli r4, r4, 654
; P9BE-NEXT:    sub r3, r3, r4
; P9BE-NEXT:    mtvsrdd v2, 0, r3
; P9BE-NEXT:    blr
;
; P8LE-LABEL: dont_fold_srem_i64:
; P8LE:       # %bb.0:
; P8LE-NEXT:    lis r4, 12374
; P8LE-NEXT:    lis r3, 5698
; P8LE-NEXT:    lis r5, 3206
; P8LE-NEXT:    xxswapd vs0, v3
; P8LE-NEXT:    mfvsrd r7, v3
; P8LE-NEXT:    mfvsrd r8, v2
; P8LE-NEXT:    ori r4, r4, 56339
; P8LE-NEXT:    ori r3, r3, 51289
; P8LE-NEXT:    ori r5, r5, 42889
; P8LE-NEXT:    mffprd r6, f0
; P8LE-NEXT:    rldic r4, r4, 33, 1
; P8LE-NEXT:    rldic r3, r3, 35, 0
; P8LE-NEXT:    rldic r5, r5, 35, 1
; P8LE-NEXT:    oris r4, r4, 58853
; P8LE-NEXT:    oris r3, r3, 22795
; P8LE-NEXT:    oris r5, r5, 1603
; P8LE-NEXT:    ori r4, r4, 6055
; P8LE-NEXT:    ori r3, r3, 8549
; P8LE-NEXT:    ori r5, r5, 21445
; P8LE-NEXT:    mulhd r4, r7, r4
; P8LE-NEXT:    mulhd r3, r6, r3
; P8LE-NEXT:    mulhd r5, r8, r5
; P8LE-NEXT:    rldicl r9, r4, 1, 63
; P8LE-NEXT:    sradi r4, r4, 11
; P8LE-NEXT:    add r3, r3, r6
; P8LE-NEXT:    add r4, r4, r9
; P8LE-NEXT:    rldicl r9, r5, 1, 63
; P8LE-NEXT:    sradi r5, r5, 8
; P8LE-NEXT:    add r5, r5, r9
; P8LE-NEXT:    rldicl r9, r3, 1, 63
; P8LE-NEXT:    sradi r3, r3, 4
; P8LE-NEXT:    mulli r4, r4, 5423
; P8LE-NEXT:    add r3, r3, r9
; P8LE-NEXT:    mulli r5, r5, 654
; P8LE-NEXT:    mulli r3, r3, 23
; P8LE-NEXT:    sub r4, r7, r4
; P8LE-NEXT:    mtfprd f0, r4
; P8LE-NEXT:    sub r5, r8, r5
; P8LE-NEXT:    sub r3, r6, r3
; P8LE-NEXT:    mtfprd f1, r3
; P8LE-NEXT:    li r3, 0
; P8LE-NEXT:    xxmrghd v3, vs0, vs1
; P8LE-NEXT:    mtfprd f0, r5
; P8LE-NEXT:    mtfprd f1, r3
; P8LE-NEXT:    xxmrghd v2, vs0, vs1
; P8LE-NEXT:    blr
;
; P8BE-LABEL: dont_fold_srem_i64:
; P8BE:       # %bb.0:
; P8BE-NEXT:    lis r4, 12374
; P8BE-NEXT:    lis r3, 5698
; P8BE-NEXT:    lis r5, 3206
; P8BE-NEXT:    xxswapd vs0, v3
; P8BE-NEXT:    xxswapd vs1, v2
; P8BE-NEXT:    mfvsrd r6, v3
; P8BE-NEXT:    ori r4, r4, 56339
; P8BE-NEXT:    ori r3, r3, 51289
; P8BE-NEXT:    ori r5, r5, 42889
; P8BE-NEXT:    mffprd r7, f0
; P8BE-NEXT:    mffprd r8, f1
; P8BE-NEXT:    rldic r4, r4, 33, 1
; P8BE-NEXT:    rldic r3, r3, 35, 0
; P8BE-NEXT:    rldic r5, r5, 35, 1
; P8BE-NEXT:    oris r4, r4, 58853
; P8BE-NEXT:    oris r3, r3, 22795
; P8BE-NEXT:    oris r5, r5, 1603
; P8BE-NEXT:    ori r4, r4, 6055
; P8BE-NEXT:    ori r3, r3, 8549
; P8BE-NEXT:    ori r5, r5, 21445
; P8BE-NEXT:    mulhd r4, r7, r4
; P8BE-NEXT:    mulhd r3, r6, r3
; P8BE-NEXT:    mulhd r5, r8, r5
; P8BE-NEXT:    rldicl r9, r4, 1, 63
; P8BE-NEXT:    sradi r4, r4, 11
; P8BE-NEXT:    add r3, r3, r6
; P8BE-NEXT:    add r4, r4, r9
; P8BE-NEXT:    rldicl r9, r5, 1, 63
; P8BE-NEXT:    sradi r5, r5, 8
; P8BE-NEXT:    add r5, r5, r9
; P8BE-NEXT:    rldicl r9, r3, 1, 63
; P8BE-NEXT:    sradi r3, r3, 4
; P8BE-NEXT:    mulli r4, r4, 5423
; P8BE-NEXT:    add r3, r3, r9
; P8BE-NEXT:    mulli r5, r5, 654
; P8BE-NEXT:    mulli r3, r3, 23
; P8BE-NEXT:    sub r4, r7, r4
; P8BE-NEXT:    mtfprd f0, r4
; P8BE-NEXT:    sub r5, r8, r5
; P8BE-NEXT:    sub r3, r6, r3
; P8BE-NEXT:    mtfprd f1, r3
; P8BE-NEXT:    li r3, 0
; P8BE-NEXT:    xxmrghd v3, vs1, vs0
; P8BE-NEXT:    mtfprd f0, r5
; P8BE-NEXT:    mtfprd f1, r3
; P8BE-NEXT:    xxmrghd v2, vs1, vs0
; P8BE-NEXT:    blr
  %1 = srem <4 x i64> %x, <i64 1, i64 654, i64 23, i64 5423>
  ret <4 x i64> %1
}