[llvm] 1f169a7 - [PowerPC][AIX] Re-generate test aix-framepointer-save-restore.ll. NFC.

Kai Luo via llvm-commits llvm-commits at lists.llvm.org
Tue Jun 29 22:38:42 PDT 2021


Author: Kai Luo
Date: 2021-06-30T05:37:49Z
New Revision: 1f169a774cb865659cefe085e70a56a884e3711e

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

LOG: [PowerPC][AIX] Re-generate test aix-framepointer-save-restore.ll. NFC.

Added: 
    

Modified: 
    llvm/test/CodeGen/PowerPC/aix-framepointer-save-restore.ll

Removed: 
    


################################################################################
diff  --git a/llvm/test/CodeGen/PowerPC/aix-framepointer-save-restore.ll b/llvm/test/CodeGen/PowerPC/aix-framepointer-save-restore.ll
index 4b3759f3e931..e92789c51300 100644
--- a/llvm/test/CodeGen/PowerPC/aix-framepointer-save-restore.ll
+++ b/llvm/test/CodeGen/PowerPC/aix-framepointer-save-restore.ll
@@ -1,3 +1,4 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
 ; RUN: llc -verify-machineinstrs < %s -mcpu=pwr4 -mattr=-altivec \
 ; RUN:     -mtriple=powerpc-ibm-aix-xcoff | \
 ; RUN:   FileCheck %s -check-prefix=AIX32
@@ -9,19 +10,124 @@
 declare void @clobber(i32*)
 
 define dso_local float @frameptr_only(i32 %n, float %f) {
+; AIX32-LABEL: frameptr_only:
+; AIX32:       # %bb.0: # %entry
+; AIX32-NEXT:    mflr 0
+; AIX32-NEXT:    stw 31, -12(1)
+; AIX32-NEXT:    stw 0, 8(1)
+; AIX32-NEXT:    stwu 1, -80(1)
+; AIX32-NEXT:    slwi 3, 3, 2
+; AIX32-NEXT:    mr 31, 1
+; AIX32-NEXT:    stfd 31, 72(31) # 8-byte Folded Spill
+; AIX32-NEXT:    fmr 31, 1
+; AIX32-NEXT:    addi 3, 3, 15
+; AIX32-NEXT:    addi 4, 31, 80
+; AIX32-NEXT:    rlwinm 3, 3, 0, 0, 27
+; AIX32-NEXT:    neg 3, 3
+; AIX32-NEXT:    stwux 4, 1, 3
+; AIX32-NEXT:    addi 3, 1, 64
+; AIX32-NEXT:    bl .clobber[PR]
+; AIX32-NEXT:    nop
+; AIX32-NEXT:    fmr 1, 31
+; AIX32-NEXT:    lfd 31, 72(31) # 8-byte Folded Reload
+; AIX32-NEXT:    lwz 1, 0(1)
+; AIX32-NEXT:    lwz 0, 8(1)
+; AIX32-NEXT:    mtlr 0
+; AIX32-NEXT:    lwz 31, -12(1)
+; AIX32-NEXT:    blr
+;
+; AIX64-LABEL: frameptr_only:
+; AIX64:       # %bb.0: # %entry
+; AIX64-NEXT:    mflr 0
+; AIX64-NEXT:    std 31, -16(1)
+; AIX64-NEXT:    std 0, 16(1)
+; AIX64-NEXT:    stdu 1, -144(1)
+; AIX64-NEXT:    rldic 3, 3, 2, 30
+; AIX64-NEXT:    mr 31, 1
+; AIX64-NEXT:    stfd 31, 136(31) # 8-byte Folded Spill
+; AIX64-NEXT:    fmr 31, 1
+; AIX64-NEXT:    addi 3, 3, 15
+; AIX64-NEXT:    addi 4, 31, 144
+; AIX64-NEXT:    rldicl 3, 3, 60, 4
+; AIX64-NEXT:    rldicl 3, 3, 4, 29
+; AIX64-NEXT:    neg 3, 3
+; AIX64-NEXT:    stdux 4, 1, 3
+; AIX64-NEXT:    addi 3, 1, 112
+; AIX64-NEXT:    bl .clobber[PR]
+; AIX64-NEXT:    nop
+; AIX64-NEXT:    fmr 1, 31
+; AIX64-NEXT:    lfd 31, 136(31) # 8-byte Folded Reload
+; AIX64-NEXT:    ld 1, 0(1)
+; AIX64-NEXT:    ld 0, 16(1)
+; AIX64-NEXT:    mtlr 0
+; AIX64-NEXT:    ld 31, -16(1)
+; AIX64-NEXT:    blr
 entry:
   %0 = alloca i32, i32 %n
   call void @clobber(i32* %0)
   ret float %f
 }
 
-; AIX32: stw 31, -12(1)
-; AIX32: stwu 1, -80(1)
-; AIX32: lwz 1, 0(1)
-; AIX32: lwz 31, -12(1)
-
-; AIX64: std 31, -16(1)
-; AIX64: stdu 1, -144(1)
-; AIX64: ld 1, 0(1)
-; AIX64: ld 31, -16(1)
-
+define dso_local void @frameptr_realigned(i32 %n) {
+; AIX32-LABEL: frameptr_realigned:
+; AIX32:       # %bb.0:
+; AIX32-NEXT:    mflr 0
+; AIX32-NEXT:    stw 31, -4(1)
+; AIX32-NEXT:    stw 30, -8(1)
+; AIX32-NEXT:    mr 30, 1
+; AIX32-NEXT:    stw 0, 8(1)
+; AIX32-NEXT:    clrlwi 0, 1, 26
+; AIX32-NEXT:    subfic 0, 0, -192
+; AIX32-NEXT:    stwux 1, 1, 0
+; AIX32-NEXT:    slwi 3, 3, 2
+; AIX32-NEXT:    lwz 4, 0(1)
+; AIX32-NEXT:    li 5, -64
+; AIX32-NEXT:    addi 3, 3, 15
+; AIX32-NEXT:    mr 31, 1
+; AIX32-NEXT:    rlwinm 3, 3, 0, 0, 27
+; AIX32-NEXT:    neg 3, 3
+; AIX32-NEXT:    and 5, 3, 5
+; AIX32-NEXT:    stwux 4, 1, 5
+; AIX32-NEXT:    addi 3, 1, 64
+; AIX32-NEXT:    bl .clobber[PR]
+; AIX32-NEXT:    nop
+; AIX32-NEXT:    mr 1, 30
+; AIX32-NEXT:    lwz 0, 8(1)
+; AIX32-NEXT:    mtlr 0
+; AIX32-NEXT:    lwz 31, -4(1)
+; AIX32-NEXT:    lwz 30, -8(1)
+; AIX32-NEXT:    blr
+;
+; AIX64-LABEL: frameptr_realigned:
+; AIX64:       # %bb.0:
+; AIX64-NEXT:    mflr 0
+; AIX64-NEXT:    std 31, -8(1)
+; AIX64-NEXT:    std 30, -16(1)
+; AIX64-NEXT:    mr 30, 1
+; AIX64-NEXT:    std 0, 16(1)
+; AIX64-NEXT:    clrldi 0, 1, 58
+; AIX64-NEXT:    subfic 0, 0, -256
+; AIX64-NEXT:    stdux 1, 1, 0
+; AIX64-NEXT:    rldic 3, 3, 2, 30
+; AIX64-NEXT:    ld 4, 0(1)
+; AIX64-NEXT:    li 5, -64
+; AIX64-NEXT:    addi 3, 3, 15
+; AIX64-NEXT:    mr 31, 1
+; AIX64-NEXT:    rldicl 3, 3, 60, 4
+; AIX64-NEXT:    rldicl 3, 3, 4, 29
+; AIX64-NEXT:    neg 3, 3
+; AIX64-NEXT:    and 5, 3, 5
+; AIX64-NEXT:    stdux 4, 1, 5
+; AIX64-NEXT:    addi 3, 1, 128
+; AIX64-NEXT:    bl .clobber[PR]
+; AIX64-NEXT:    nop
+; AIX64-NEXT:    mr 1, 30
+; AIX64-NEXT:    ld 0, 16(1)
+; AIX64-NEXT:    mtlr 0
+; AIX64-NEXT:    ld 31, -8(1)
+; AIX64-NEXT:    ld 30, -16(1)
+; AIX64-NEXT:    blr
+  %ptr = alloca i32, i32 %n, align 64
+  call void @clobber(i32* %ptr)
+  ret void
+}


        


More information about the llvm-commits mailing list