
SUMMARY: SUMMARY for a source file "test.c" void foo() {}; llc will generate assembly code as (assembly patch) .globl foo .globl .foo .csect foo[DS] foo: .long .foo .long TOC[TC0] .long 0 and symbol table as (xcoff object file) [4] m 0x00000004 .data 1 unamex foo [5] a4 0x0000000c 0 0 SD DS 0 0 [6] m 0x00000004 .data 1 extern foo [7] a4 0x00000004 0 0 LD DS 0 0 After first patch, the assembly will be as .globl foo[DS] # -- Begin function foo .globl .foo .align 2 .csect foo[DS] .long .foo .long TOC[TC0] .long 0 and symbol table will as [6] m 0x00000004 .data 1 extern foo [7] a4 0x00000004 0 0 DS DS 0 0 Change the code for the assembly path and xcoff objectfile patch for llc. Reviewers: Jason Liu Subscribers: wuzish, nemanjai, hiraditya Differential Revision: https://reviews.llvm.org/D76162
72 lines
1.5 KiB
LLVM
72 lines
1.5 KiB
LLVM
; RUN: llc -mtriple powerpc-ibm-aix-xcoff < %s | \
|
|
; RUN: FileCheck --check-prefixes=CHECK,32BIT %s
|
|
|
|
; RUN: llc -mtriple powerpc64-ibm-aix-xcoff < %s | \
|
|
; RUN: FileCheck --check-prefixes=CHECK,64BIT %s
|
|
|
|
|
|
define i32 @foo() {
|
|
entry:
|
|
ret i32 3
|
|
}
|
|
|
|
define i32 @main() {
|
|
entry:
|
|
%0 = call i32 @foo()
|
|
%1 = call i32 bitcast (i32 (...)* @extern_foo to i32 ()*)()
|
|
%2 = call i32 @static_foo()
|
|
%3 = add nsw i32 %0, %1
|
|
%4 = add nsw i32 %3, %2
|
|
ret i32 %4
|
|
}
|
|
|
|
declare i32 @extern_foo(...)
|
|
|
|
define internal i32 @static_foo() {
|
|
entry:
|
|
ret i32 3
|
|
}
|
|
|
|
; CHECK: .globl foo[DS]
|
|
; CHECK: .globl .foo
|
|
; CHECK: .csect foo[DS]
|
|
; 32BIT: .long .foo
|
|
; 32BIT-NEXT: .long TOC[TC0]
|
|
; 32BIT-NEXT: .long 0
|
|
; 64BIT: .llong .foo
|
|
; 64BIT-NEXT: .llong TOC[TC0]
|
|
; 64BIT-NEXT: .llong 0
|
|
; CHECK-NEXT: .csect .text[PR]
|
|
; CHECK-LABEL: .foo:
|
|
|
|
; CHECK: .globl main[DS]
|
|
; CHECK: .globl .main
|
|
; CHECK: .csect main[DS]
|
|
; 32BIT: .long .main
|
|
; 32BIT-NEXT: .long TOC[TC0]
|
|
; 32BIT-NEXT: .long 0
|
|
; 64BIT: .llong .main
|
|
; 64BIT-NEXT: .llong TOC[TC0]
|
|
; 64BIT-NEXT: .llong 0
|
|
; CHECK-NEXT: .csect .text[PR]
|
|
; CHECK-LABEL: .main:
|
|
; CHECK: bl .foo
|
|
; CHECK: bl .extern_foo
|
|
; CHECK: bl .static_foo
|
|
|
|
; CHECK: .lglobl .static_foo
|
|
; CHECK: .csect static_foo[DS]
|
|
; 32BIT: .long .static_foo
|
|
; 32BIT-NEXT: .long TOC[TC0]
|
|
; 32BIT-NEXT: .long 0
|
|
; 64BIT: .llong .static_foo
|
|
; 64BIT-NEXT: .llong TOC[TC0]
|
|
; 64BIT-NEXT: .llong 0
|
|
; CHECK-NEXT: .csect .text[PR]
|
|
; CHECK-LABEL: .static_foo:
|
|
|
|
; CHECK-NOT: .csect extern_foo
|
|
|
|
; CHECK: .toc
|
|
; CHECK-NOT: .tc
|