2012-02-22 21:11:47 +00:00
|
|
|
; RUN: llc < %s -mtriple=powerpc64-unknown-linux-gnu -mcpu=g5 | FileCheck %s
|
|
|
|
|
2012-02-27 20:42:19 +00:00
|
|
|
; CHECK: .section .opd,"aw",@progbits
|
|
|
|
; CHECK-NEXT: test1:
|
2012-02-27 20:20:47 +00:00
|
|
|
; CHECK-NEXT: .align 3
|
|
|
|
; CHECK-NEXT: .quad .L.test1
|
|
|
|
; CHECK-NEXT: .quad .TOC.@tocbase
|
2012-09-18 16:55:29 +00:00
|
|
|
; CHECK-NEXT: .quad 0
|
2012-02-27 20:20:47 +00:00
|
|
|
; CHECK-NEXT: .text
|
2012-02-22 21:11:47 +00:00
|
|
|
; CHECK-NEXT: .L.test1:
|
|
|
|
|
|
|
|
define i32 @test1(i32 %a) nounwind {
|
|
|
|
entry:
|
|
|
|
ret i32 %a
|
|
|
|
}
|
|
|
|
|
|
|
|
; Until recently, binutils accepted the .size directive as:
|
|
|
|
; .size test1, .Ltmp0-test1
|
|
|
|
; however, using this directive with recent binutils will result in the error:
|
|
|
|
; .size expression for XXX does not evaluate to a constant
|
|
|
|
; so we must use the label which actually tags the start of the function.
|
|
|
|
; CHECK: .size test1, .Ltmp0-.L.test1
|