mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
9168f717c9
Unfortunately, even with the workaround of disabling the linker TLS optimizations in Clang restored (which has already been done), this still breaks self-hosting on my P7 machine (-O3 -DNDEBUG -mcpu=native). Bill is currently working on an alternate implementation to address the TLS issue in a way that also fully elides the linker bug (which, unfortunately, this approach did not fully), so I'm reverting this now. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@228460 91177308-0d34-0410-b5e6-96231b3b80d8
26 lines
589 B
LLVM
26 lines
589 B
LLVM
; RUN: llc -mcpu=pwr7 < %s | FileCheck %s
|
|
target datalayout = "E-m:e-i64:64-n32:64"
|
|
target triple = "powerpc64-unknown-linux-gnu"
|
|
|
|
; Function Attrs: nounwind readnone
|
|
define i8* @test1() #0 {
|
|
entry:
|
|
%0 = tail call i8* @llvm.returnaddress(i32 0)
|
|
ret i8* %0
|
|
}
|
|
|
|
; CHECK-LABEL: @test1
|
|
; CHECK: mflr 0
|
|
; CHECK: std 0, 16(1)
|
|
; FIXME: These next two lines don't both need to load the same value.
|
|
; CHECK-DAG: ld 3, 16(1)
|
|
; CHECK-DAG: ld 0, 16(1)
|
|
; CHECK: mtlr 0
|
|
; CHECK: blr
|
|
|
|
; Function Attrs: nounwind readnone
|
|
declare i8* @llvm.returnaddress(i32) #0
|
|
|
|
attributes #0 = { nounwind readnone }
|
|
|