1 ; RUN: llc -mtriple powerpc-ibm-aix-xcoff < %s | \
2 ; RUN: FileCheck --check-prefixes=CHECK,32BIT %s
4 ; RUN: llc -mtriple powerpc64-ibm-aix-xcoff < %s | \
5 ; RUN: FileCheck --check-prefixes=CHECK,64BIT %s
16 %1 = call i32 @extern_foo()
17 %2 = call i32 @static_foo()
18 %3 = add nsw i32 %0, %1
19 %4 = add nsw i32 %3, %2
23 declare i32 @extern_foo(...)
25 define internal i32 @static_foo() {
30 ; CHECK: .globl foo[DS]
32 ; 32BIT: .csect foo[DS],2
33 ; 32BIT-NEXT: .vbyte 4, .foo
34 ; 32BIT-NEXT: .vbyte 4, TOC[TC0]
35 ; 32BIT-NEXT: .vbyte 4, 0
36 ; 64BIT: .csect foo[DS],3
37 ; 64BIT-NEXT: .vbyte 8, .foo
38 ; 64BIT-NEXT: .vbyte 8, TOC[TC0]
39 ; 64BIT-NEXT: .vbyte 8, 0
40 ; CHECK-NEXT: .csect [PR],5
43 ; CHECK: .globl main[DS]
45 ; 32BIT: .csect main[DS],2
46 ; 32BIT-NEXT: .vbyte 4, .main
47 ; 32BIT-NEXT: .vbyte 4, TOC[TC0]
48 ; 32BIT-NEXT: .vbyte 4, 0
49 ; 64BIT: .csect main[DS],3
50 ; 64BIT-NEXT: .vbyte 8, .main
51 ; 64BIT-NEXT: .vbyte 8, TOC[TC0]
52 ; 64BIT-NEXT: .vbyte 8, 0
53 ; CHECK-NEXT: .csect [PR],5
56 ; CHECK: bl .extern_foo
57 ; CHECK: bl .static_foo
59 ; CHECK: .lglobl static_foo[DS]
60 ; CHECK: .lglobl .static_foo
61 ; 32BIT: .csect static_foo[DS],2
62 ; 32BIT-NEXT: .vbyte 4, .static_foo
63 ; 32BIT-NEXT: .vbyte 4, TOC[TC0]
64 ; 32BIT-NEXT: .vbyte 4, 0
65 ; 64BIT: .csect static_foo[DS],3
66 ; 64BIT-NEXT: .vbyte 8, .static_foo
67 ; 64BIT-NEXT: .vbyte 8, TOC[TC0]
68 ; 64BIT-NEXT: .vbyte 8, 0
69 ; CHECK-NEXT: .csect [PR],5
70 ; CHECK-LABEL: .static_foo:
72 ; CHECK-NOT: .csect extern_foo