[X86] X86DAGToDAGISel - attempt to merge XMM/YMM loads with YMM/ZMM loads of the...
[llvm-project.git] / llvm / test / CodeGen / PowerPC / ppc64-notoc-rm-relocation.ll
blob0c9432e6484e6bcbfa2cb4e4ee95c2d902ed7a00
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \
3 ; RUN:   -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \
4 ; RUN:   < %s | FileCheck %s --check-prefix LE-P10
5 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu \
6 ; RUN:   -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \
7 ; RUN:   < %s | FileCheck %s --check-prefix BE-P10
8 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \
9 ; RUN:   -mcpu=pwr9 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \
10 ; RUN:   < %s | FileCheck %s --check-prefix LE-P9
11 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu \
12 ; RUN:   -mcpu=pwr9 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \
13 ; RUN:   < %s | FileCheck %s --check-prefix BE-P9
15 ; Function Attrs: nounwind strictfp
16 define dso_local signext i32 @main() #0 {
17 ; LE-P10-LABEL: main:
18 ; LE-P10:       # %bb.0: # %_main_entry
19 ; LE-P10-NEXT:    mflr r0
20 ; LE-P10-NEXT:    std r0, 16(r1)
21 ; LE-P10-NEXT:    stdu r1, -32(r1)
22 ; LE-P10-NEXT:    bl callee@notoc
23 ; LE-P10-NEXT:    li r3, 0
24 ; LE-P10-NEXT:    addi r1, r1, 32
25 ; LE-P10-NEXT:    ld r0, 16(r1)
26 ; LE-P10-NEXT:    mtlr r0
27 ; LE-P10-NEXT:    blr
29 ; BE-P10-LABEL: main:
30 ; BE-P10:       # %bb.0: # %_main_entry
31 ; BE-P10-NEXT:    mflr r0
32 ; BE-P10-NEXT:    std r0, 16(r1)
33 ; BE-P10-NEXT:    stdu r1, -112(r1)
34 ; BE-P10-NEXT:    bl callee
35 ; BE-P10-NEXT:    nop
36 ; BE-P10-NEXT:    li r3, 0
37 ; BE-P10-NEXT:    addi r1, r1, 112
38 ; BE-P10-NEXT:    ld r0, 16(r1)
39 ; BE-P10-NEXT:    mtlr r0
40 ; BE-P10-NEXT:    blr
42 ; LE-P9-LABEL: main:
43 ; LE-P9:       # %bb.0: # %_main_entry
44 ; LE-P9-NEXT:    mflr r0
45 ; LE-P9-NEXT:    stdu r1, -32(r1)
46 ; LE-P9-NEXT:    std r0, 48(r1)
47 ; LE-P9-NEXT:    bl callee
48 ; LE-P9-NEXT:    nop
49 ; LE-P9-NEXT:    li r3, 0
50 ; LE-P9-NEXT:    addi r1, r1, 32
51 ; LE-P9-NEXT:    ld r0, 16(r1)
52 ; LE-P9-NEXT:    mtlr r0
53 ; LE-P9-NEXT:    blr
55 ; BE-P9-LABEL: main:
56 ; BE-P9:       # %bb.0: # %_main_entry
57 ; BE-P9-NEXT:    mflr r0
58 ; BE-P9-NEXT:    stdu r1, -112(r1)
59 ; BE-P9-NEXT:    std r0, 128(r1)
60 ; BE-P9-NEXT:    bl callee
61 ; BE-P9-NEXT:    nop
62 ; BE-P9-NEXT:    li r3, 0
63 ; BE-P9-NEXT:    addi r1, r1, 112
64 ; BE-P9-NEXT:    ld r0, 16(r1)
65 ; BE-P9-NEXT:    mtlr r0
66 ; BE-P9-NEXT:    blr
67 _main_entry:
68   call void @callee() #1
69   ret i32 0
72 ; Function Attrs: strictfp
73 declare void @callee() #1
75 attributes #0 = { nounwind strictfp }
76 attributes #1 = { strictfp }