[llvm] a51c61e - Run update_llc_test_checks against SPE tests.

Justin Hibbits via llvm-commits llvm-commits at lists.llvm.org
Thu Jan 2 17:32:10 PST 2020


Author: Justin Hibbits
Date: 2020-01-02T19:30:52-06:00
New Revision: a51c61ea332f89dfbb9f3b3498c37b2efc99e13b

URL: https://github.com/llvm/llvm-project/commit/a51c61ea332f89dfbb9f3b3498c37b2efc99e13b
DIFF: https://github.com/llvm/llvm-project/commit/a51c61ea332f89dfbb9f3b3498c37b2efc99e13b.diff

LOG: Run update_llc_test_checks against SPE tests.

This is in preparation for further tests which are better generated with
the script.  No functional change.

Added: 
    

Modified: 
    llvm/test/CodeGen/PowerPC/spe.ll

Removed: 
    


################################################################################
diff  --git a/llvm/test/CodeGen/PowerPC/spe.ll b/llvm/test/CodeGen/PowerPC/spe.ll
index bd03fa30e6a7..aa2dd7e1c449 100644
--- a/llvm/test/CodeGen/PowerPC/spe.ll
+++ b/llvm/test/CodeGen/PowerPC/spe.ll
@@ -1,273 +1,441 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
 ; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc-unknown-linux-gnu \
 ; RUN:          -mattr=+spe |  FileCheck %s
 
 declare float @llvm.fabs.float(float)
 define float @test_float_abs(float %a) #0 {
+; CHECK-LABEL: test_float_abs:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efsabs 3, 3
+; CHECK-NEXT:    blr
   entry:
     %0 = tail call float @llvm.fabs.float(float %a)
     ret float %0
-; CHECK-LABEL: test_float_abs
-; CHECK: efsabs 3, 3
-; CHECK: blr
 }
 
 define float @test_fnabs(float %a) #0 {
+; CHECK-LABEL: test_fnabs:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efsnabs 3, 3
+; CHECK-NEXT:    blr
   entry:
     %0 = tail call float @llvm.fabs.float(float %a)
     %sub = fsub float -0.000000e+00, %0
     ret float %sub
-; CHECK-LABEL: @test_fnabs
-; CHECK: efsnabs
-; CHECK: blr
 }
 
 define float @test_fdiv(float %a, float %b) {
+; CHECK-LABEL: test_fdiv:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efsdiv 3, 3, 4
+; CHECK-NEXT:    blr
 entry:
   %v = fdiv float %a, %b
   ret float %v
 
-; CHECK-LABEL: test_fdiv
-; CHECK: efsdiv
-; CHECK: blr
 }
 
 define float @test_fmul(float %a, float %b) {
+; CHECK-LABEL: test_fmul:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efsmul 3, 3, 4
+; CHECK-NEXT:    blr
   entry:
   %v = fmul float %a, %b
   ret float %v
 ; CHECK-LABEL @test_fmul
-; CHECK: efsmul
-; CHECK: blr
 }
 
 define float @test_fadd(float %a, float %b) {
+; CHECK-LABEL: test_fadd:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efsadd 3, 3, 4
+; CHECK-NEXT:    blr
   entry:
   %v = fadd float %a, %b
   ret float %v
 ; CHECK-LABEL @test_fadd
-; CHECK: efsadd
-; CHECK: blr
 }
 
 define float @test_fsub(float %a, float %b) {
+; CHECK-LABEL: test_fsub:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efssub 3, 3, 4
+; CHECK-NEXT:    blr
   entry:
   %v = fsub float %a, %b
   ret float %v
 ; CHECK-LABEL @test_fsub
-; CHECK: efssub
-; CHECK: blr
 }
 
 define float @test_fneg(float %a) {
+; CHECK-LABEL: test_fneg:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efsneg 3, 3
+; CHECK-NEXT:    blr
   entry:
   %v = fsub float -0.0, %a
   ret float %v
 
 ; CHECK-LABEL @test_fneg
-; CHECK: efsneg
-; CHECK: blr
 }
 
 define float @test_dtos(double %a) {
+; CHECK-LABEL: test_dtos:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    efscfd 3, 3
+; CHECK-NEXT:    blr
   entry:
   %v = fptrunc double %a to float
   ret float %v
-; CHECK-LABEL: test_dtos
-; CHECK: efscfd
-; CHECK: blr
 }
 
 define i1 @test_fcmpgt(float %a, float %b) {
+; CHECK-LABEL: test_fcmpgt:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    li 5, 0
+; CHECK-NEXT:    efscmpgt 0, 3, 4
+; CHECK-NEXT:    li 3, 1
+; CHECK-NEXT:    bclr 12, 1, 0
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ogt float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpgt
-; CHECK: efscmpgt
-; CHECK: blr
 }
 
 define i1 @test_fcmpugt(float %a, float %b) {
+; CHECK-LABEL: test_fcmpugt:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efscmpeq 0, 3, 3
+; CHECK-NEXT:    efscmpeq 1, 4, 4
+; CHECK-NEXT:    crnand 20, 5, 1
+; CHECK-NEXT:    efscmpgt 0, 3, 4
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    crnor 20, 1, 20
+; CHECK-NEXT:    bc 12, 20, .LBB9_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB9_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ugt float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpugt
-; CHECK: efscmpgt
-; CHECK: blr
 }
 
 define i1 @test_fcmple(float %a, float %b) {
+; CHECK-LABEL: test_fcmple:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efscmpeq 0, 4, 4
+; CHECK-NEXT:    efscmpeq 1, 3, 3
+; CHECK-NEXT:    crand 20, 5, 1
+; CHECK-NEXT:    efscmpgt 0, 3, 4
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    crorc 20, 1, 20
+; CHECK-NEXT:    bc 12, 20, .LBB10_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB10_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ole float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmple
-; CHECK: efscmpgt
-; CHECK: blr
 }
 
 define i1 @test_fcmpule(float %a, float %b) {
+; CHECK-LABEL: test_fcmpule:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    efscmpgt 0, 3, 4
+; CHECK-NEXT:    bc 12, 1, .LBB11_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB11_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ule float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpule
-; CHECK: efscmpgt
-; CHECK: blr
 }
 
 define i1 @test_fcmpeq(float %a, float %b) {
+; CHECK-LABEL: test_fcmpeq:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    li 5, 0
+; CHECK-NEXT:    efscmpeq 0, 3, 4
+; CHECK-NEXT:    li 3, 1
+; CHECK-NEXT:    bclr 12, 1, 0
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp oeq float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpeq
-; CHECK: efscmpeq
-; CHECK: blr
 }
 
 ; (un)ordered tests are expanded to une and oeq so verify
 define i1 @test_fcmpuno(float %a, float %b) {
+; CHECK-LABEL: test_fcmpuno:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efscmpeq 0, 3, 3
+; CHECK-NEXT:    efscmpeq 1, 4, 4
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    crand 20, 5, 1
+; CHECK-NEXT:    bc 12, 20, .LBB13_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB13_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp uno float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpuno
-; CHECK: efscmpeq
-; CHECK: efscmpeq
-; CHECK: crand
-; CHECK: blr
 }
 
 define i1 @test_fcmpord(float %a, float %b) {
+; CHECK-LABEL: test_fcmpord:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efscmpeq 0, 4, 4
+; CHECK-NEXT:    efscmpeq 1, 3, 3
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    crnand 20, 5, 1
+; CHECK-NEXT:    bc 12, 20, .LBB14_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB14_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ord float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpord
-; CHECK: efscmpeq
-; CHECK: efscmpeq
-; CHECK: crnand
-; CHECK: blr
 }
 
 define i1 @test_fcmpueq(float %a, float %b) {
+; CHECK-LABEL: test_fcmpueq:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efscmpeq 0, 3, 3
+; CHECK-NEXT:    efscmpeq 1, 4, 4
+; CHECK-NEXT:    crnand 20, 5, 1
+; CHECK-NEXT:    efscmpeq 0, 3, 4
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    crnor 20, 1, 20
+; CHECK-NEXT:    bc 12, 20, .LBB15_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB15_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ueq float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpueq
-; CHECK: efscmpeq
-; CHECK: blr
 }
 
 define i1 @test_fcmpne(float %a, float %b) {
+; CHECK-LABEL: test_fcmpne:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efscmpeq 0, 4, 4
+; CHECK-NEXT:    efscmpeq 1, 3, 3
+; CHECK-NEXT:    crand 20, 5, 1
+; CHECK-NEXT:    efscmpeq 0, 3, 4
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    crorc 20, 1, 20
+; CHECK-NEXT:    bc 12, 20, .LBB16_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB16_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp one float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpne
-; CHECK: efscmpeq
-; CHECK: blr
 }
 
 define i1 @test_fcmpune(float %a, float %b) {
+; CHECK-LABEL: test_fcmpune:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    efscmpeq 0, 3, 4
+; CHECK-NEXT:    bc 12, 1, .LBB17_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB17_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp une float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpune
-; CHECK: efscmpeq
-; CHECK: blr
 }
 
 define i1 @test_fcmplt(float %a, float %b) {
+; CHECK-LABEL: test_fcmplt:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    li 5, 0
+; CHECK-NEXT:    efscmplt 0, 3, 4
+; CHECK-NEXT:    li 3, 1
+; CHECK-NEXT:    bclr 12, 1, 0
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp olt float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmplt
-; CHECK: efscmplt
-; CHECK: blr
 }
 
 define i1 @test_fcmpult(float %a, float %b) {
+; CHECK-LABEL: test_fcmpult:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efscmpeq 0, 3, 3
+; CHECK-NEXT:    efscmpeq 1, 4, 4
+; CHECK-NEXT:    crnand 20, 5, 1
+; CHECK-NEXT:    efscmplt 0, 3, 4
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    crnor 20, 1, 20
+; CHECK-NEXT:    bc 12, 20, .LBB19_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB19_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ult float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpult
-; CHECK: efscmplt
-; CHECK: blr
 }
 
 define i1 @test_fcmpge(float %a, float %b) {
+; CHECK-LABEL: test_fcmpge:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efscmpeq 0, 4, 4
+; CHECK-NEXT:    efscmpeq 1, 3, 3
+; CHECK-NEXT:    crand 20, 5, 1
+; CHECK-NEXT:    efscmplt 0, 3, 4
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    crorc 20, 1, 20
+; CHECK-NEXT:    bc 12, 20, .LBB20_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB20_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp oge float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpge
-; CHECK: efscmplt
-; CHECK: blr
 }
 
 define i1 @test_fcmpuge(float %a, float %b) {
+; CHECK-LABEL: test_fcmpuge:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    li 5, 1
+; CHECK-NEXT:    efscmplt 0, 3, 4
+; CHECK-NEXT:    bc 12, 1, .LBB21_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 5, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB21_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp uge float %a, %b
   ret i1 %r
-; CHECK-LABEL: test_fcmpuge
-; CHECK: efscmplt
-; CHECK: blr
 }
 
 define i32 @test_ftoui(float %a) {
+; CHECK-LABEL: test_ftoui:
+; CHECK:       # %bb.0:
+; CHECK-NEXT:    efsctuiz 3, 3
+; CHECK-NEXT:    blr
   %v = fptoui float %a to i32
   ret i32 %v
-; CHECK-LABEL: test_ftoui
-; CHECK: efsctuiz
 }
 
 define i32 @test_ftosi(float %a) {
+; CHECK-LABEL: test_ftosi:
+; CHECK:       # %bb.0:
+; CHECK-NEXT:    efsctsiz 3, 3
+; CHECK-NEXT:    blr
   %v = fptosi float %a to i32
   ret i32 %v
-; CHECK-LABEL: test_ftosi
-; CHECK: efsctsiz
 }
 
 define float @test_ffromui(i32 %a) {
+; CHECK-LABEL: test_ffromui:
+; CHECK:       # %bb.0:
+; CHECK-NEXT:    efscfui 3, 3
+; CHECK-NEXT:    blr
   %v = uitofp i32 %a to float
   ret float %v
-; CHECK-LABEL: test_ffromui
-; CHECK: efscfui
 }
 
 define float @test_ffromsi(i32 %a) {
+; CHECK-LABEL: test_ffromsi:
+; CHECK:       # %bb.0:
+; CHECK-NEXT:    efscfsi 3, 3
+; CHECK-NEXT:    blr
   %v = sitofp i32 %a to float
   ret float %v
-; CHECK-LABEL: test_ffromsi
-; CHECK: efscfsi
 }
 
 define i32 @test_fasmconst(float %x) {
+; CHECK-LABEL: test_fasmconst:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    stwu 1, -32(1)
+; CHECK-NEXT:    .cfi_def_cfa_offset 32
+; CHECK-NEXT:    stw 3, 20(1)
+; CHECK-NEXT:    stw 3, 24(1)
+; CHECK-NEXT:    lwz 3, 20(1)
+; CHECK-NEXT:    #APP
+; CHECK-NEXT:    efsctsi 3, 3
+; CHECK-NEXT:    #NO_APP
+; CHECK-NEXT:    addi 1, 1, 32
+; CHECK-NEXT:    blr
 entry:
   %x.addr = alloca float, align 8
   store float %x, float* %x.addr, align 8
   %0 = load float, float* %x.addr, align 8
   %1 = call i32 asm sideeffect "efsctsi $0, $1", "=f,f"(float %0)
   ret i32 %1
-; CHECK-LABEL: test_fasmconst
 ; Check that it's not loading a double
-; CHECK-NOT: evldd
-; CHECK: #APP
-; CHECK: efsctsi
-; CHECK: #NO_APP
 }
 
 ; Double tests
 
 define void @test_double_abs(double * %aa) #0 {
+; CHECK-LABEL: test_double_abs:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evldd 4, 0(3)
+; CHECK-NEXT:    efdabs 4, 4
+; CHECK-NEXT:    evstdd 4, 0(3)
+; CHECK-NEXT:    blr
   entry:
     %0 = load double, double * %aa
     %1 = tail call double @llvm.fabs.f64(double %0) #2
     store double %1, double * %aa
     ret void
-; CHECK-LABEL: test_double_abs
-; CHECK: efdabs
-; CHECK: blr
 }
 
 ; Function Attrs: nounwind readnone
 declare double @llvm.fabs.f64(double) #1
 
 define void @test_dnabs(double * %aa) #0 {
+; CHECK-LABEL: test_dnabs:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evldd 4, 0(3)
+; CHECK-NEXT:    efdnabs 4, 4
+; CHECK-NEXT:    evstdd 4, 0(3)
+; CHECK-NEXT:    blr
   entry:
     %0 = load double, double * %aa
     %1 = tail call double @llvm.fabs.f64(double %0) #2
@@ -275,256 +443,476 @@ define void @test_dnabs(double * %aa) #0 {
     store double %sub, double * %aa
     ret void
 }
-; CHECK-LABEL: @test_dnabs
-; CHECK: efdnabs
-; CHECK: blr
 
 define double @test_ddiv(double %a, double %b) {
+; CHECK-LABEL: test_ddiv:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    efddiv 4, 3, 5
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    blr
 entry:
   %v = fdiv double %a, %b
   ret double %v
 
-; CHECK-LABEL: test_ddiv
-; CHECK: efddiv
-; CHECK: blr
 }
 
 define double @test_dmul(double %a, double %b) {
+; CHECK-LABEL: test_dmul:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    efdmul 4, 3, 5
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    blr
   entry:
   %v = fmul double %a, %b
   ret double %v
-; CHECK-LABEL @test_dmul
-; CHECK: efdmul
-; CHECK: blr
 }
 
 define double @test_dadd(double %a, double %b) {
+; CHECK-LABEL: test_dadd:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    efdadd 4, 3, 5
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    blr
   entry:
   %v = fadd double %a, %b
   ret double %v
-; CHECK-LABEL @test_dadd
-; CHECK: efdadd
-; CHECK: blr
 }
 
 define double @test_dsub(double %a, double %b) {
+; CHECK-LABEL: test_dsub:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    efdsub 4, 3, 5
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    blr
   entry:
   %v = fsub double %a, %b
   ret double %v
-; CHECK-LABEL @test_dsub
-; CHECK: efdsub
-; CHECK: blr
 }
 
 define double @test_dneg(double %a) {
+; CHECK-LABEL: test_dneg:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    efdneg 4, 3
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    blr
   entry:
   %v = fsub double -0.0, %a
   ret double %v
-
-; CHECK-LABEL @test_dneg
-; CHECK: blr
 }
 
 define double @test_stod(float %a) {
+; CHECK-LABEL: test_stod:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efdcfs 4, 3
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    blr
   entry:
   %v = fpext float %a to double
   ret double %v
-; CHECK-LABEL: test_stod
-; CHECK: efdcfs
-; CHECK: blr
 }
 
 ; (un)ordered tests are expanded to une and oeq so verify
 define i1 @test_dcmpuno(double %a, double %b) {
+; CHECK-LABEL: test_dcmpuno:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpeq 0, 3, 3
+; CHECK-NEXT:    efdcmpeq 1, 5, 5
+; CHECK-NEXT:    crand 20, 5, 1
+; CHECK-NEXT:    bc 12, 20, .LBB35_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB35_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp uno double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpuno
-; CHECK: efdcmpeq
-; CHECK: efdcmpeq
-; CHECK: crand
-; CHECK: blr
 }
 
 define i1 @test_dcmpord(double %a, double %b) {
+; CHECK-LABEL: test_dcmpord:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    evmergelo 4, 5, 6
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpeq 0, 4, 4
+; CHECK-NEXT:    efdcmpeq 1, 3, 3
+; CHECK-NEXT:    crnand 20, 5, 1
+; CHECK-NEXT:    bc 12, 20, .LBB36_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB36_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ord double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpord
-; CHECK: efdcmpeq
-; CHECK: efdcmpeq
-; CHECK: crnand
-; CHECK: blr
 }
 
 define i1 @test_dcmpgt(double %a, double %b) {
+; CHECK-LABEL: test_dcmpgt:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 0
+; CHECK-NEXT:    efdcmpgt 0, 3, 5
+; CHECK-NEXT:    li 3, 1
+; CHECK-NEXT:    bclr 12, 1, 0
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ogt double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpgt
-; CHECK: efdcmpgt
-; CHECK: blr
 }
 
 define i1 @test_dcmpugt(double %a, double %b) {
+; CHECK-LABEL: test_dcmpugt:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpeq 0, 3, 3
+; CHECK-NEXT:    efdcmpeq 1, 5, 5
+; CHECK-NEXT:    efdcmpgt 5, 3, 5
+; CHECK-NEXT:    crnand 24, 5, 1
+; CHECK-NEXT:    crnor 20, 21, 24
+; CHECK-NEXT:    bc 12, 20, .LBB38_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB38_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ugt double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpugt
-; CHECK: efdcmpgt
-; CHECK: blr
 }
 
 define i1 @test_dcmple(double %a, double %b) {
+; CHECK-LABEL: test_dcmple:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    evmergelo 4, 5, 6
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpeq 0, 4, 4
+; CHECK-NEXT:    efdcmpeq 1, 3, 3
+; CHECK-NEXT:    efdcmpgt 5, 3, 4
+; CHECK-NEXT:    crand 24, 5, 1
+; CHECK-NEXT:    crorc 20, 21, 24
+; CHECK-NEXT:    bc 12, 20, .LBB39_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB39_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ole double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmple
-; CHECK: efdcmpgt
-; CHECK: blr
 }
 
 define i1 @test_dcmpule(double %a, double %b) {
+; CHECK-LABEL: test_dcmpule:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpgt 0, 3, 5
+; CHECK-NEXT:    bc 12, 1, .LBB40_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB40_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ule double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpule
-; CHECK: efdcmpgt
-; CHECK: blr
 }
 
 define i1 @test_dcmpeq(double %a, double %b) {
+; CHECK-LABEL: test_dcmpeq:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 0
+; CHECK-NEXT:    efdcmpeq 0, 3, 5
+; CHECK-NEXT:    li 3, 1
+; CHECK-NEXT:    bclr 12, 1, 0
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp oeq double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpeq
-; CHECK: efdcmpeq
-; CHECK: blr
 }
 
 define i1 @test_dcmpueq(double %a, double %b) {
+; CHECK-LABEL: test_dcmpueq:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpeq 0, 3, 3
+; CHECK-NEXT:    efdcmpeq 1, 5, 5
+; CHECK-NEXT:    efdcmpeq 5, 3, 5
+; CHECK-NEXT:    crnand 24, 5, 1
+; CHECK-NEXT:    crnor 20, 21, 24
+; CHECK-NEXT:    bc 12, 20, .LBB42_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB42_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ueq double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpueq
-; CHECK: efdcmpeq
-; CHECK: blr
 }
 
 define i1 @test_dcmpne(double %a, double %b) {
+; CHECK-LABEL: test_dcmpne:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    evmergelo 4, 5, 6
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpeq 0, 4, 4
+; CHECK-NEXT:    efdcmpeq 1, 3, 3
+; CHECK-NEXT:    efdcmpeq 5, 3, 4
+; CHECK-NEXT:    crand 24, 5, 1
+; CHECK-NEXT:    crorc 20, 21, 24
+; CHECK-NEXT:    bc 12, 20, .LBB43_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB43_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp one double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpne
-; CHECK: efdcmpeq
-; CHECK: blr
 }
 
 define i1 @test_dcmpune(double %a, double %b) {
+; CHECK-LABEL: test_dcmpune:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpeq 0, 3, 5
+; CHECK-NEXT:    bc 12, 1, .LBB44_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB44_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp une double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpune
-; CHECK: efdcmpeq
-; CHECK: blr
 }
 
 define i1 @test_dcmplt(double %a, double %b) {
+; CHECK-LABEL: test_dcmplt:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 0
+; CHECK-NEXT:    efdcmplt 0, 3, 5
+; CHECK-NEXT:    li 3, 1
+; CHECK-NEXT:    bclr 12, 1, 0
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp olt double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmplt
-; CHECK: efdcmplt
-; CHECK: blr
 }
 
 define i1 @test_dcmpult(double %a, double %b) {
+; CHECK-LABEL: test_dcmpult:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpeq 0, 3, 3
+; CHECK-NEXT:    efdcmpeq 1, 5, 5
+; CHECK-NEXT:    efdcmplt 5, 3, 5
+; CHECK-NEXT:    crnand 24, 5, 1
+; CHECK-NEXT:    crnor 20, 21, 24
+; CHECK-NEXT:    bc 12, 20, .LBB46_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB46_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp ult double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpult
-; CHECK: efdcmplt
-; CHECK: blr
 }
 
 define i1 @test_dcmpge(double %a, double %b) {
+; CHECK-LABEL: test_dcmpge:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    evmergelo 4, 5, 6
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmpeq 0, 4, 4
+; CHECK-NEXT:    efdcmpeq 1, 3, 3
+; CHECK-NEXT:    efdcmplt 5, 3, 4
+; CHECK-NEXT:    crand 24, 5, 1
+; CHECK-NEXT:    crorc 20, 21, 24
+; CHECK-NEXT:    bc 12, 20, .LBB47_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB47_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp oge double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpge
-; CHECK: efdcmplt
-; CHECK: blr
 }
 
 define i1 @test_dcmpuge(double %a, double %b) {
+; CHECK-LABEL: test_dcmpuge:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    li 7, 1
+; CHECK-NEXT:    efdcmplt 0, 3, 5
+; CHECK-NEXT:    bc 12, 1, .LBB48_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    ori 3, 7, 0
+; CHECK-NEXT:    blr
+; CHECK-NEXT:  .LBB48_2: # %entry
+; CHECK-NEXT:    addi 3, 0, 0
+; CHECK-NEXT:    blr
   entry:
   %r = fcmp uge double %a, %b
   ret i1 %r
-; CHECK-LABEL: test_dcmpuge
-; CHECK: efdcmplt
-; CHECK: blr
 }
 
 define double @test_dselect(double %a, double %b, i1 %c) {
+; CHECK-LABEL: test_dselect:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    andi. 7, 7, 1
+; CHECK-NEXT:    evmergelo 5, 5, 6
+; CHECK-NEXT:    evmergelo 4, 3, 4
+; CHECK-NEXT:    bc 12, 1, .LBB49_2
+; CHECK-NEXT:  # %bb.1: # %entry
+; CHECK-NEXT:    evor 4, 5, 5
+; CHECK-NEXT:  .LBB49_2: # %entry
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    blr
 entry:
   %r = select i1 %c, double %a, double %b
   ret double %r
-; CHECK-LABEL: test_dselect
-; CHECK: andi.
-; CHECK: bc
-; CHECK: evor
-; CHECK: evmergehi
-; CHECK: blr
 }
 
 define i32 @test_dtoui(double %a) {
+; CHECK-LABEL: test_dtoui:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    efdctuiz 3, 3
+; CHECK-NEXT:    blr
 entry:
   %v = fptoui double %a to i32
   ret i32 %v
-; CHECK-LABEL: test_dtoui
-; CHECK: efdctuiz
 }
 
 define i32 @test_dtosi(double %a) {
+; CHECK-LABEL: test_dtosi:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    efdctsiz 3, 3
+; CHECK-NEXT:    blr
 entry:
   %v = fptosi double %a to i32
   ret i32 %v
-; CHECK-LABEL: test_dtosi
-; CHECK: efdctsiz
 }
 
 define double @test_dfromui(i32 %a) {
+; CHECK-LABEL: test_dfromui:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efdcfui 4, 3
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    blr
 entry:
   %v = uitofp i32 %a to double
   ret double %v
-; CHECK-LABEL: test_dfromui
-; CHECK: efdcfui
 }
 
 define double @test_dfromsi(i32 %a) {
+; CHECK-LABEL: test_dfromsi:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    efdcfsi 4, 3
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    blr
 entry:
   %v = sitofp i32 %a to double
   ret double %v
-; CHECK-LABEL: test_dfromsi
-; CHECK: efdcfsi
 }
 
 define i32 @test_dasmconst(double %x) {
+; CHECK-LABEL: test_dasmconst:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    stwu 1, -16(1)
+; CHECK-NEXT:    .cfi_def_cfa_offset 16
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    evstdd 3, 8(1)
+; CHECK-NEXT:    #APP
+; CHECK-NEXT:    efdctsi 3, 3
+; CHECK-NEXT:    #NO_APP
+; CHECK-NEXT:    addi 1, 1, 16
+; CHECK-NEXT:    blr
 entry:
   %x.addr = alloca double, align 8
   store double %x, double* %x.addr, align 8
   %0 = load double, double* %x.addr, align 8
   %1 = call i32 asm sideeffect "efdctsi $0, $1", "=d,d"(double %0)
   ret i32 %1
-; CHECK-LABEL: test_dasmconst
-; CHECK: evmergelo
-; CHECK: #APP
-; CHECK: efdctsi
-; CHECK: #NO_APP
 }
 
 declare double @test_spill_spe_regs(double, double);
 define dso_local void @test_func2() #0 {
+; CHECK-LABEL: test_func2:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    blr
 entry:
   ret void
 }
@@ -532,6 +920,120 @@ entry:
 declare void @test_memset(i8* nocapture writeonly, i8, i32, i1)
 @global_var1 = global i32 0, align 4
 define double @test_spill(double %a, i32 %a1, i64 %a2, i8 * %a3, i32 *%a4, i32* %a5) nounwind {
+; CHECK-LABEL: test_spill:
+; CHECK:       # %bb.0: # %entry
+; CHECK-NEXT:    mflr 0
+; CHECK-NEXT:    stw 0, 4(1)
+; CHECK-NEXT:    stwu 1, -352(1)
+; CHECK-NEXT:    li 5, 256
+; CHECK-NEXT:    evstddx 30, 1, 5 # 8-byte Folded Spill
+; CHECK-NEXT:    li 5, 264
+; CHECK-NEXT:    evstddx 31, 1, 5 # 8-byte Folded Spill
+; CHECK-NEXT:    li 5, .LCPI56_0 at l
+; CHECK-NEXT:    lis 6, .LCPI56_0 at ha
+; CHECK-NEXT:    evlddx 5, 6, 5
+; CHECK-NEXT:    stw 14, 280(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 15, 284(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 16, 288(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 17, 292(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 18, 296(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 19, 300(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 20, 304(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 21, 308(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 22, 312(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 23, 316(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 24, 320(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 25, 324(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 26, 328(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 27, 332(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 28, 336(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 29, 340(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 30, 344(1) # 4-byte Folded Spill
+; CHECK-NEXT:    stw 31, 348(1) # 4-byte Folded Spill
+; CHECK-NEXT:    evstdd 14, 128(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 15, 136(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 16, 144(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 17, 152(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 18, 160(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 19, 168(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 20, 176(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 21, 184(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 22, 192(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 23, 200(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 24, 208(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 25, 216(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 26, 224(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 27, 232(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 28, 240(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evstdd 29, 248(1) # 8-byte Folded Spill
+; CHECK-NEXT:    evmergelo 3, 3, 4
+; CHECK-NEXT:    lwz 4, 360(1)
+; CHECK-NEXT:    efdadd 3, 3, 3
+; CHECK-NEXT:    efdadd 3, 3, 5
+; CHECK-NEXT:    evstdd 3, 24(1) # 8-byte Folded Spill
+; CHECK-NEXT:    stw 4, 20(1) # 4-byte Folded Spill
+; CHECK-NEXT:    #APP
+; CHECK-NEXT:    #NO_APP
+; CHECK-NEXT:    addi 3, 1, 76
+; CHECK-NEXT:    li 4, 0
+; CHECK-NEXT:    li 5, 24
+; CHECK-NEXT:    li 6, 1
+; CHECK-NEXT:    li 30, 0
+; CHECK-NEXT:    bl test_memset
+; CHECK-NEXT:    lwz 3, 20(1) # 4-byte Folded Reload
+; CHECK-NEXT:    stw 30, 0(3)
+; CHECK-NEXT:    bl test_func2
+; CHECK-NEXT:    addi 3, 1, 32
+; CHECK-NEXT:    li 4, 0
+; CHECK-NEXT:    li 5, 20
+; CHECK-NEXT:    li 6, 1
+; CHECK-NEXT:    bl test_memset
+; CHECK-NEXT:    evldd 4, 24(1) # 8-byte Folded Reload
+; CHECK-NEXT:    li 5, 264
+; CHECK-NEXT:    evmergehi 3, 4, 4
+; CHECK-NEXT:    evlddx 31, 1, 5 # 8-byte Folded Reload
+; CHECK-NEXT:    li 5, 256
+; CHECK-NEXT:    evlddx 30, 1, 5 # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 29, 248(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 28, 240(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 27, 232(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 26, 224(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 25, 216(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 24, 208(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 23, 200(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 22, 192(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 21, 184(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 20, 176(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 19, 168(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 18, 160(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 17, 152(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 16, 144(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 15, 136(1) # 8-byte Folded Reload
+; CHECK-NEXT:    evldd 14, 128(1) # 8-byte Folded Reload
+; CHECK-NEXT:    # kill: def $r3 killed $r3 killed $s3
+; CHECK-NEXT:    # kill: def $r4 killed $r4 killed $s4
+; CHECK-NEXT:    lwz 31, 348(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 30, 344(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 29, 340(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 28, 336(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 27, 332(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 26, 328(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 25, 324(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 24, 320(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 23, 316(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 22, 312(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 21, 308(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 20, 304(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 19, 300(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 18, 296(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 17, 292(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 16, 288(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 15, 284(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 14, 280(1) # 4-byte Folded Reload
+; CHECK-NEXT:    lwz 0, 356(1)
+; CHECK-NEXT:    addi 1, 1, 352
+; CHECK-NEXT:    mtlr 0
+; CHECK-NEXT:    blr
 entry:
   %v1 = alloca [13 x i32], align 4
   %v2 = alloca [11 x i32], align 4
@@ -549,11 +1051,4 @@ entry:
 return:
   ret double %1
 
-; CHECK-LABEL: test_spill
-; CHECK: li [[VREG:[0-9]+]], 256
-; CHECK: evstddx {{[0-9]+}}, {{[0-9]+}}, [[VREG]]
-; CHECK-NOT: evstdd {{[0-9]+}}, 256({{[0-9]+}}
-; CHECK: evstdd
-; CHECK: efdadd
-; CHECK: evldd
 }


        


More information about the llvm-commits mailing list