Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / CodeGen / PowerPC / Frames-large.ll
blobfda2e4ff9ce9bb8dee566fc40370ab1522df6771
1 ; RUN: llvm-as < %s > %t.bc
2 ; RUN: llc < %t.bc -march=ppc32 | FileCheck %s -check-prefix=PPC32-NOFP
3 ; RUN: llc < %t.bc -march=ppc32 -disable-fp-elim | FileCheck %s -check-prefix=PPC32-FP
5 ; RUN: llc < %t.bc -march=ppc64 | FileCheck %s -check-prefix=PPC64-NOFP
6 ; RUN: llc < %t.bc -march=ppc64 -disable-fp-elim | FileCheck %s -check-prefix=PPC64-FP
9 target triple = "powerpc-apple-darwin8"
11 define i32* @f1() nounwind {
12         %tmp = alloca i32, i32 8191             ; <i32*> [#uses=1]
13         ret i32* %tmp
16 ; PPC32-NOFP: _f1:
17 ; PPC32-NOFP:   lis r0, -1
18 ; PPC32-NOFP:   ori r0, r0, 32704
19 ; PPC32-NOFP:   stwux r1, r1, r0
20 ; PPC32-NOFP:   addi r3, r1, 68
21 ; PPC32-NOFP:   lwz r1, 0(r1)
22 ; PPC32-NOFP:   blr 
24 ; PPC32-FP: _f1:
25 ; PPC32-FP:     stw r31, 20(r1)
26 ; PPC32-FP:     lis r0, -1
27 ; PPC32-FP:     ori r0, r0, 32704
28 ; PPC32-FP:     stwux r1, r1, r0
29 ; ...
30 ; PPC32-FP:     lwz r1, 0(r1)
31 ; PPC32-FP:     lwz r31, 20(r1)
32 ; PPC32-FP:     blr 
35 ; PPC64-NOFP: _f1:
36 ; PPC64-NOFP:   lis r0, -1
37 ; PPC64-NOFP:   ori r0, r0, 32656
38 ; PPC64-NOFP:   stdux r1, r1, r0
39 ; PPC64-NOFP:   addi r3, r1, 116
40 ; PPC64-NOFP:   ld r1, 0(r1)
41 ; PPC64-NOFP:   blr 
44 ; PPC64-FP: _f1:
45 ; PPC64-FP:     std r31, 40(r1)
46 ; PPC64-FP:     lis r0, -1
47 ; PPC64-FP:     ori r0, r0, 32656
48 ; PPC64-FP:     stdux r1, r1, r0
49 ; ...
50 ; PPC64-FP:     ld r1, 0(r1)
51 ; PPC64-FP:     ld r31, 40(r1)
52 ; PPC64-FP:     blr