blob: d07fea72677011d4892a0e8629d88a3e4df4b8e3 [file] [log] [blame]
Chris Lattner447da712009-08-25 20:57:38 +00001; 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
4
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
7
Jim Laskey64c32dd2006-11-17 16:54:21 +00008
Chris Lattner447da712009-08-25 20:57:38 +00009target triple = "powerpc-apple-darwin8"
10
11define i32* @f1() nounwind {
Tanya Lattner6f729d62008-03-25 04:26:08 +000012 %tmp = alloca i32, i32 8191 ; <i32*> [#uses=1]
13 ret i32* %tmp
Jim Laskey64c32dd2006-11-17 16:54:21 +000014}
Tanya Lattner6f729d62008-03-25 04:26:08 +000015
Chris Lattner447da712009-08-25 20:57:38 +000016; PPC32-NOFP: _f1:
17; PPC32-NOFP: lis r0, -1
18; PPC32-NOFP: ori r0, r0, 32704
19; PPC32-NOFP: stwux r1, r1, r0
Hal Finkel2e95afa2011-12-30 00:34:00 +000020; PPC32-NOFP: addi r3, r1, 68
Chris Lattner447da712009-08-25 20:57:38 +000021; PPC32-NOFP: lwz r1, 0(r1)
22; PPC32-NOFP: blr
23
Hal Finkel24575442011-12-02 04:58:12 +000024
Chris Lattner447da712009-08-25 20:57:38 +000025; PPC32-FP: _f1:
Chris Lattner447da712009-08-25 20:57:38 +000026; PPC32-FP: lis r0, -1
Hal Finkel24575442011-12-02 04:58:12 +000027; PPC32-FP: stw r31, -4(r1)
Chris Lattner447da712009-08-25 20:57:38 +000028; PPC32-FP: ori r0, r0, 32704
29; PPC32-FP: stwux r1, r1, r0
Hal Finkel2e95afa2011-12-30 00:34:00 +000030; PPC32-FP: mr r31, r1
31; PPC32-FP: addi r3, r31, 64
Chris Lattner447da712009-08-25 20:57:38 +000032; PPC32-FP: lwz r1, 0(r1)
Dale Johannesenf7801b42009-11-24 22:59:02 +000033; PPC32-FP: lwz r31, -4(r1)
Chris Lattner447da712009-08-25 20:57:38 +000034; PPC32-FP: blr
35
36
37; PPC64-NOFP: _f1:
38; PPC64-NOFP: lis r0, -1
39; PPC64-NOFP: ori r0, r0, 32656
40; PPC64-NOFP: stdux r1, r1, r0
Hal Finkel2e95afa2011-12-30 00:34:00 +000041; PPC64-NOFP: addi r3, r1, 116
Chris Lattner447da712009-08-25 20:57:38 +000042; PPC64-NOFP: ld r1, 0(r1)
43; PPC64-NOFP: blr
44
45
46; PPC64-FP: _f1:
Chris Lattner447da712009-08-25 20:57:38 +000047; PPC64-FP: lis r0, -1
Hal Finkel24575442011-12-02 04:58:12 +000048; PPC64-FP: std r31, -8(r1)
Dale Johannesenf7801b42009-11-24 22:59:02 +000049; PPC64-FP: ori r0, r0, 32640
Chris Lattner447da712009-08-25 20:57:38 +000050; PPC64-FP: stdux r1, r1, r0
Hal Finkel2e95afa2011-12-30 00:34:00 +000051; PPC64-FP: mr r31, r1
52; PPC64-FP: addi r3, r31, 124
Chris Lattner447da712009-08-25 20:57:38 +000053; PPC64-FP: ld r1, 0(r1)
Dale Johannesenf7801b42009-11-24 22:59:02 +000054; PPC64-FP: ld r31, -8(r1)
Chris Lattner447da712009-08-25 20:57:38 +000055; PPC64-FP: blr